Skip to content

Commit

Permalink
Write users spect for /pro/users
Browse files Browse the repository at this point in the history
  • Loading branch information
minkyngkm committed Feb 26, 2024
1 parent f61e4c6 commit fa99673
Show file tree
Hide file tree
Showing 2 changed files with 68 additions and 0 deletions.
3 changes: 3 additions & 0 deletions tests/playwright/helpers/utils.ts
Original file line number Diff line number Diff line change
Expand Up @@ -10,3 +10,6 @@ export const ENDPOINTS = {
preview: "/pro/purchase/preview*",
stripePaymentMethod : "https://api.stripe.com/v1/payment_methods",
};

export const getRandomEmail = () =>
`playwright-test-${Math.random().toString(36).substring(2,12)}@canonical.com`;
65 changes: 65 additions & 0 deletions tests/playwright/tests/pro/users.spec.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,65 @@
import { test, expect } from "@playwright/test";
import { acceptCookiePolicy, login } from "../../helpers/commands";
import { getRandomEmail } from "../../helpers/utils";

test.describe("/pro/users", () => {
const email = getRandomEmail();

test("It should add and delete a user correctly", async ({ page }) => {
await page.goto("/pro/users");
await login(page);
await acceptCookiePolicy(page);

await page.getByRole("button", { name: /Add new user/ }).click();
await page.getByLabel("Name").fill("Angela");
await page.getByLabel("email address").fill(email);
await page
.getByLabel("Role", { exact: true })
.selectOption({ label: "Technical" });

await page.route("/pro/accounts/*", async (route) => {
const request = route.request();
const postData = await request.postDataJSON();

if (request.method() === "POST") {
await route.fulfill({
status: 200,
contentType: "application/json",
body: JSON.stringify({ email: postData.email, role: postData.role }),
});
} else if (request.method() === "DELETE") {
await route.fulfill({
status: 200,
contentType: "application/json",
body: JSON.stringify({ email: postData.email }),
});
}
});

await page
.getByRole("button", { name: "Add new user", exact: true })
.click();

await page.waitForTimeout(3000);

await expect(page.getByText(/User added successfully/)).toBeVisible();

await page.getByPlaceholder("Search for users").fill(email);

await expect(page.getByText(email)).toBeVisible();

await page.getByLabel(`Edit user ${email}`).click();

await page.locator("button[aria-label='delete']").click();

await page.getByRole("button", { name: "Yes, remove user" }).click();

await page.waitForTimeout(3000);

await expect(page.getByText(/User deleted/)).toBeVisible();

await page.getByPlaceholder("Search for users").fill(email);

await expect(page.getByText(email)).not.toBeVisible();
});
});

0 comments on commit fa99673

Please sign in to comment.