80 lines
2.1 KiB
TypeScript
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();
|
|
});
|
|
});
|