Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Adding E2E tests for my-posts page Part 1 #1187

Merged
Merged
8 changes: 4 additions & 4 deletions e2e/articles.spec.ts
Original file line number Diff line number Diff line change
Expand Up @@ -17,10 +17,10 @@ test.describe("Unauthenticated Articles Page", () => {
test("Should be able to navigate directly to an article", async ({
page,
}) => {
await page.goto("http://localhost:3000/articles/e2e-test-slug-eqj0ozor");
await page.goto("http://localhost:3000/articles/e2e-test-slug-published");
await expect(page.getByText("Lorem ipsum dolor sit amet,")).toBeVisible();
await expect(
page.getByRole("heading", { name: "Test Article" }),
page.getByRole("heading", { name: "Published Article" }),
).toBeVisible();
await expect(
page.getByRole("heading", { name: "Written by E2E Test User One" }),
Expand Down Expand Up @@ -291,14 +291,14 @@ test.describe("Authenticated Articles Page", () => {
});

test("Should be able reply to a comment", async ({ page }) => {
await page.goto("http://localhost:3000/articles/e2e-test-slug-eqj0ozor");
await page.goto("http://localhost:3000/articles/e2e-test-slug-published");
const numberOfCommentsIntially = await page
.locator("div")
.filter({ hasText: /^Thanks for the positive feedback!$/ })
.count();
await expect(page.getByText("Lorem ipsum dolor sit amet,")).toBeVisible();
await expect(
page.getByRole("heading", { name: "Test Article" }),
page.getByRole("heading", { name: "Published Article" }),
).toBeVisible();
await expect(
page.getByRole("heading", { name: "Written by E2E Test User One" }),
Expand Down
53 changes: 48 additions & 5 deletions e2e/my-posts.spec.ts
Original file line number Diff line number Diff line change
@@ -1,15 +1,58 @@
import test from "@playwright/test";
import test, { expect } from "@playwright/test";
import { loggedInAsUserOne } from "./utils";

test.describe("Unauthenticated my-posts Page", () => {
//
// Replace with tests for unauthenticated users
test("Unauthenticed users should be redirected to get-started page if they access my-posts directly", async ({
page,
}) => {
await page.goto("http://localhost:3000/my-posts");
await page.waitForURL("http://localhost:3000/get-started");
expect(page.url()).toEqual("http://localhost:3000/get-started");
});
});

test.describe("Authenticated my-posts Page", () => {
test.beforeEach(async ({ page }) => {
await loggedInAsUserOne(page);
});
//
// Replace with tests for authenticated users

test("Tabs for different type of posts should be visible", async ({
page,
}) => {
await page.goto("http://localhost:3000/my-posts");

await expect(page.getByRole("link", { name: "Drafts" })).toBeVisible();
await expect(page.getByRole("link", { name: "Scheduled" })).toBeVisible();
await expect(page.getByRole("link", { name: "Published" })).toBeVisible();
});

test("Different article tabs should correctly display articles matching that type", async ({
page,
}) => {
await page.goto("http://localhost:3000/my-posts");

await expect(page.getByRole("link", { name: "Drafts" })).toBeVisible();
await expect(page.getByRole("link", { name: "Scheduled" })).toBeVisible();
await expect(page.getByRole("link", { name: "Published" })).toBeVisible();

await page.getByRole("link", { name: "Drafts" }).click();
await expect(
page.getByRole("heading", { name: "Draft Article" }),
).toBeVisible();
await expect(page.getByText("Lorem ipsum dolor sit amet")).toBeVisible();

await page.getByRole("link", { name: "Scheduled" }).click();
await expect(
page.getByRole("heading", { name: "Scheduled Article" }),
).toBeVisible();
await expect(page.getByText("Lorem ipsum dolor sit amet")).toBeVisible();

await page.getByRole("link", { name: "Published" }).click();
await expect(
page.getByRole("heading", { name: "Published Article" }),
).toBeVisible();
await expect(
page.getByText("Lorem ipsum dolor sit amet", { exact: true }),
).toBeVisible();
});
});
80 changes: 62 additions & 18 deletions e2e/setup.ts
Original file line number Diff line number Diff line change
Expand Up @@ -19,29 +19,73 @@ export const setup = async () => {
authorId: string,
commenterId: string,
) => {
const postId = "1nFnMmN5";
const publishedPostId = "1nFnMmN1";
const scheduledPostId = "1nFnMmN2";
const draftPostId = "1nFnMmN3";
const now = new Date().toISOString();
await db
.insert(post)
.values({
id: postId,
published: now,
excerpt: "Lorem ipsum dolor sit amet",
updatedAt: now,
slug: "e2e-test-slug-eqj0ozor",
likes: 10,
readTimeMins: 3,
title: "Test Article",
body: "Lorem ipsum dolor sit amet, consectetur adipiscing elit. Maecenas vitae ipsum id metus vestibulum rutrum eget a diam. Integer eget vulputate risus, ac convallis nulla. Mauris sed augue nunc. Class aptent taciti sociosqu ad litora torquent per conubia nostra, per inceptos himenaeos. Nam congue posuere tempor. Pellentesque habitant morbi tristique senectus et netus et malesuada fames ac turpis egestas. Ut ac augue non libero ullamcorper ornare. Ut commodo ligula vitae malesuada maximus. Pellentesque habitant morbi tristique senectus et netus et malesuada fames ac turpis egestas. Etiam sagittis justo non justo placerat, a dapibus sapien volutpat. Nullam ullamcorper sodales justo sed.",
userId: authorId,
})
.onConflictDoNothing()
.returning();
const articleContent =
"Lorem ipsum dolor sit amet, consectetur adipiscing elit. Maecenas vitae ipsum id metus vestibulum rutrum eget a diam. Integer eget vulputate risus, ac convallis nulla. Mauris sed augue nunc. Class aptent taciti sociosqu ad litora torquent per conubia nostra, per inceptos himenaeos. Nam congue posuere tempor. Pellentesque habitant morbi tristique senectus et netus et malesuada fames ac turpis egestas. Ut ac augue non libero ullamcorper ornare. Ut commodo ligula vitae malesuada maximus. Pellentesque habitant morbi tristique senectus et netus et malesuada fames ac turpis egestas. Etiam sagittis justo non justo placerat, a dapibus sapien volutpat. Nullam ullamcorper sodales justo sed.";

const oneYearFromToday = new Date(now);
oneYearFromToday.setFullYear(oneYearFromToday.getFullYear() + 1);

await Promise.all([
await db
.insert(post)
.values({
id: publishedPostId,
published: now,
excerpt: "Lorem ipsum dolor sit amet",
updatedAt: now,
slug: "e2e-test-slug-published",
likes: 10,
readTimeMins: 3,
title: "Published Article",
body: articleContent,
userId: authorId,
})
.onConflictDoNothing()
.returning(),

await db
.insert(post)
.values({
id: scheduledPostId,
published: null,
excerpt: "Lorem ipsum dolor sit amet",
updatedAt: now,
slug: "e2e-test-slug-draft",
likes: 10,
readTimeMins: 3,
title: "Draft Article",
body: articleContent,
userId: authorId,
})
.onConflictDoNothing()
.returning(),

await db
.insert(post)
.values({
id: draftPostId,
published: oneYearFromToday.toISOString(),
excerpt: "Lorem ipsum dolor sit amet",
updatedAt: now,
slug: "e2e-test-slug-scheduled",
likes: 10,
readTimeMins: 3,
title: "Scheduled Article",
body: articleContent,
userId: authorId,
})
.onConflictDoNothing()
.returning(),
]);

await db
.insert(comment)
.values({
postId,
postId: publishedPostId,
body: "What a great article! Thanks for sharing",
userId: commenterId,
})
Expand Down
Loading