cal/playwright/event-types.test.ts
2021-10-20 15:18:50 +01:00

80 lines
2.1 KiB
TypeScript

import { kont } from "kont";
import { loginProvider } from "./lib/loginProvider";
import { randomString } from "./lib/testUtils";
jest.setTimeout(60e3);
jest.retryTimes(3);
describe("pro user", () => {
const ctx = kont()
.useBeforeEach(
loginProvider({
user: "pro",
path: "/event-types",
waitForSelector: "[data-testid=event-types]",
})
)
.done();
test("has at least 2 events", async () => {
const { page } = ctx;
const $eventTypes = await page.$$("[data-testid=event-types] > *");
expect($eventTypes.length).toBeGreaterThanOrEqual(2);
for (const $el of $eventTypes) {
expect(await $el.getAttribute("data-disabled")).toBe("0");
}
});
test("can add new event type", async () => {
const { page } = ctx;
await page.click("[data-testid=new-event-type]");
const nonce = randomString(3);
const eventTitle = `hello ${nonce}`;
await page.fill("[name=title]", eventTitle);
await page.fill("[name=length]", "10");
await page.click("[type=submit]");
await page.waitForNavigation({
url(url) {
return url.pathname !== "/event-types";
},
});
await page.goto("http://localhost:3000/event-types");
await expect(page).toHaveSelector(`text='${eventTitle}'`);
});
});
describe("free user", () => {
const ctx = kont()
.useBeforeEach(
loginProvider({
user: "free",
path: "/event-types",
waitForSelector: "[data-testid=event-types]",
})
)
.done();
test("has at least 2 events where first is enabled", async () => {
const { page } = ctx;
const $eventTypes = await page.$$("[data-testid=event-types] > *");
expect($eventTypes.length).toBeGreaterThanOrEqual(2);
const [$first] = $eventTypes;
const $last = $eventTypes.pop()!;
expect(await $first.getAttribute("data-disabled")).toBe("0");
expect(await $last.getAttribute("data-disabled")).toBe("1");
});
test("can not add new event type", async () => {
const { page } = ctx;
await expect(page.$("[data-testid=new-event-type]")).toBeDisabled();
});
});