mirror of
https://github.com/lukevella/rallly.git
synced 2025-04-29 10:16:32 +02:00
91 lines
2.5 KiB
TypeScript
91 lines
2.5 KiB
TypeScript
import { expect, test } from "@playwright/test";
|
|
import smtpTester, { SmtpTester } from "smtp-tester";
|
|
|
|
test.describe.serial(() => {
|
|
let pollUrl: string;
|
|
|
|
let mailServer: SmtpTester;
|
|
test.beforeAll(async () => {
|
|
mailServer = smtpTester.init(4025);
|
|
});
|
|
|
|
test.afterAll(async () => {
|
|
mailServer.stop();
|
|
});
|
|
|
|
test("create a new poll", async ({ page }) => {
|
|
await page.goto("/new");
|
|
await page.type('[placeholder="Monthly Meetup"]', "Monthly Meetup");
|
|
// click on label to focus on input
|
|
await page.click('text="Location"');
|
|
await page.keyboard.type("Joe's Coffee Shop");
|
|
|
|
await page.click('text="Description"');
|
|
|
|
await page.keyboard.type("This is a test description");
|
|
|
|
await page.click('text="Continue"');
|
|
|
|
await page.click('[title="Next month"]');
|
|
|
|
// Select a few days
|
|
await page.click("text=/^5$/");
|
|
await page.click("text=/^7$/");
|
|
await page.click("text=/^10$/");
|
|
await page.click("text=/^15$/");
|
|
|
|
await page.click('text="Continue"');
|
|
|
|
await page.type('[placeholder="Jessie Smith"]', "John");
|
|
await page.type(
|
|
'[placeholder="jessie.smith@example.com"]',
|
|
"john.doe@example.com",
|
|
);
|
|
|
|
await page.click('text="Create poll"');
|
|
|
|
const title = page.getByTestId("poll-title");
|
|
|
|
await title.waitFor();
|
|
|
|
await expect(title).toHaveText("Monthly Meetup");
|
|
|
|
const { email } = await mailServer.captureOne("john.doe@example.com", {
|
|
wait: 5000,
|
|
});
|
|
|
|
expect(email.headers.subject).toBe("Let's find a date for Monthly Meetup");
|
|
|
|
pollUrl = page.url();
|
|
});
|
|
|
|
test("notifications", async ({ page }) => {
|
|
await page.goto(pollUrl);
|
|
await page.getByTestId("notifications-toggle").click();
|
|
|
|
expect(page.getByTestId("login-modal")).toBeVisible();
|
|
});
|
|
|
|
// delete the poll we just created
|
|
test("delete existing poll", async ({ page }) => {
|
|
await page.goto(pollUrl);
|
|
const manageButton = page.getByText("Manage");
|
|
await manageButton.waitFor();
|
|
await manageButton.click();
|
|
await page.click("text=Delete poll");
|
|
|
|
const deletePollForm = page.locator("data-testid=delete-poll-form");
|
|
|
|
// button should be disabled
|
|
await expect(deletePollForm.locator("text=Delete poll")).toBeDisabled();
|
|
|
|
// enter confirmation text
|
|
await page.type("[placeholder=delete-me]", "delete-me");
|
|
|
|
// button should now be enabled
|
|
await deletePollForm.locator("text=Delete poll").click();
|
|
|
|
// expect delete message to appear
|
|
await expect(page.locator("text=Deleted poll")).toBeVisible();
|
|
});
|
|
});
|