mirror of
https://github.com/thiloho/archtika.git
synced 2025-11-22 10:51:36 +01:00
Refactor playwright tests, change button text for better usability and validate mimetype in API layer
This commit is contained in:
149
web-app/tests/categories.spec.ts
Normal file
149
web-app/tests/categories.spec.ts
Normal file
@@ -0,0 +1,149 @@
|
||||
import { test, expect } from "@playwright/test";
|
||||
import { randomBytes, randomInt } from "node:crypto";
|
||||
import {
|
||||
userOwner,
|
||||
authenticate,
|
||||
permissionLevels,
|
||||
collabUsers,
|
||||
collabTestingWebsite
|
||||
} from "./shared";
|
||||
|
||||
const genCategoryName = () => randomBytes(12).toString("hex");
|
||||
const genCategoryWeight = (min = 10, max = 10000) => randomInt(min, max).toString();
|
||||
|
||||
test.describe("Website owner", () => {
|
||||
test.beforeEach(async ({ page }) => {
|
||||
await authenticate(userOwner, page);
|
||||
await page
|
||||
.locator("li")
|
||||
.filter({ hasText: collabTestingWebsite })
|
||||
.getByRole("link", { name: collabTestingWebsite })
|
||||
.click();
|
||||
await page.getByRole("link", { name: "Categories" }).click();
|
||||
});
|
||||
|
||||
test(`Create category`, async ({ page }) => {
|
||||
await page.getByRole("button", { name: "Create category" }).click();
|
||||
await page.locator("#create-category-modal").getByLabel("Name:").click();
|
||||
await page.locator("#create-category-modal").getByLabel("Name:").fill(genCategoryName());
|
||||
await page.locator("#create-category-modal").getByLabel("Weight:").click();
|
||||
await page.locator("#create-category-modal").getByLabel("Weight:").fill(genCategoryWeight());
|
||||
await page
|
||||
.locator("#create-category-modal")
|
||||
.getByRole("button", { name: "Create category" })
|
||||
.click();
|
||||
await expect(page.getByText("Successfully created category")).toBeVisible();
|
||||
await expect(page.getByRole("link", { name: "All categories" })).toBeVisible();
|
||||
});
|
||||
|
||||
test.describe("Modify", () => {
|
||||
test.beforeEach(async ({ page }) => {
|
||||
await page.getByRole("button", { name: "Create category" }).click();
|
||||
await page.locator("#create-category-modal").getByLabel("Name:").click();
|
||||
await page.locator("#create-category-modal").getByLabel("Name:").fill(genCategoryName());
|
||||
await page.locator("#create-category-modal").getByLabel("Weight:").click();
|
||||
await page.locator("#create-category-modal").getByLabel("Weight:").fill(genCategoryWeight());
|
||||
await page
|
||||
.locator("#create-category-modal")
|
||||
.getByRole("button", { name: "Create category" })
|
||||
.click();
|
||||
});
|
||||
|
||||
test(`Update category`, async ({ page }) => {
|
||||
await page.getByRole("button", { name: "Update" }).first().click();
|
||||
const modalName = page.url().split("#")[1];
|
||||
await page.locator(`#${modalName}`).getByLabel("Name:").click();
|
||||
await page.locator(`#${modalName}`).getByLabel("Name:").fill(genCategoryName());
|
||||
await page.locator(`#${modalName}`).getByLabel("Weight:").click();
|
||||
await page.locator(`#${modalName}`).getByLabel("Weight:").fill(genCategoryWeight());
|
||||
await page.getByRole("button", { name: "Update category" }).click();
|
||||
await expect(page.getByText("Successfully updated category")).toBeVisible();
|
||||
});
|
||||
|
||||
test(`Delete category`, async ({ page }) => {
|
||||
await page.getByRole("button", { name: "Delete" }).first().click();
|
||||
await page.getByRole("button", { name: "Delete category" }).click();
|
||||
await expect(page.getByText("Successfully deleted category")).toBeVisible();
|
||||
});
|
||||
});
|
||||
});
|
||||
|
||||
for (const permissionLevel of permissionLevels) {
|
||||
test.describe(`Website collaborator (Permission level: ${permissionLevel})`, () => {
|
||||
test.beforeEach(async ({ page }) => {
|
||||
await authenticate(collabUsers.get(permissionLevel)!, page);
|
||||
await page
|
||||
.locator("li")
|
||||
.filter({ hasText: collabTestingWebsite })
|
||||
.getByRole("link", { name: collabTestingWebsite })
|
||||
.click();
|
||||
await page.getByRole("link", { name: "Categories" }).click();
|
||||
});
|
||||
|
||||
test(`Create category`, async ({ page }) => {
|
||||
await page.getByRole("button", { name: "Create category" }).click();
|
||||
await page.locator("#create-category-modal").getByLabel("Name:").click();
|
||||
await page.locator("#create-category-modal").getByLabel("Name:").fill(genCategoryName());
|
||||
await page.locator("#create-category-modal").getByLabel("Weight:").click();
|
||||
await page.locator("#create-category-modal").getByLabel("Weight:").fill(genCategoryWeight());
|
||||
await page
|
||||
.locator("#create-category-modal")
|
||||
.getByRole("button", { name: "Create category" })
|
||||
.evaluate((node) => node.removeAttribute("disabled"));
|
||||
await page
|
||||
.locator("#create-category-modal")
|
||||
.getByRole("button", { name: "Create category" })
|
||||
.click();
|
||||
|
||||
if (permissionLevel === 10) {
|
||||
await expect(page.getByText("Insufficient permissions")).toBeVisible();
|
||||
} else {
|
||||
await expect(page.getByText("Successfully created category")).toBeVisible();
|
||||
await expect(page.getByRole("link", { name: "All categories" })).toBeVisible();
|
||||
}
|
||||
});
|
||||
|
||||
test(`Update category`, async ({ page }) => {
|
||||
await page.getByRole("button", { name: "Update" }).first().click();
|
||||
const modalName = page.url().split("#")[1];
|
||||
await page.locator(`#${modalName}`).getByLabel("Name:").click();
|
||||
await page.locator(`#${modalName}`).getByLabel("Name:").fill(genCategoryName());
|
||||
await page.locator(`#${modalName}`).getByLabel("Weight:").click();
|
||||
await page.locator(`#${modalName}`).getByLabel("Weight:").fill(genCategoryWeight());
|
||||
await page
|
||||
.getByRole("button", { name: "Update category" })
|
||||
.evaluate((node) => node.removeAttribute("disabled"));
|
||||
await page.getByRole("button", { name: "Update category" }).click();
|
||||
|
||||
if (permissionLevel === 10) {
|
||||
await expect(page.getByText("Insufficient permissions")).toBeVisible();
|
||||
} else {
|
||||
await expect(page.getByText("Successfully updated category")).toBeVisible();
|
||||
}
|
||||
});
|
||||
|
||||
test(`Delete category`, async ({ page }) => {
|
||||
await page.getByRole("button", { name: "Delete" }).first().click();
|
||||
await page
|
||||
.getByRole("button", { name: "Delete category" })
|
||||
.evaluate((node) => node.removeAttribute("disabled"));
|
||||
await page.getByRole("button", { name: "Delete category" }).click();
|
||||
|
||||
switch (permissionLevel) {
|
||||
case 10:
|
||||
await expect(page.getByText("Insufficient permissions")).toBeVisible();
|
||||
break;
|
||||
case 20:
|
||||
await expect(
|
||||
page
|
||||
.getByText("Successfully deleted category")
|
||||
.or(page.getByText("Insufficient permissions"))
|
||||
).toBeVisible();
|
||||
break;
|
||||
case 30:
|
||||
await expect(page.getByText("Successfully deleted category")).toBeVisible();
|
||||
break;
|
||||
}
|
||||
});
|
||||
});
|
||||
}
|
||||
Reference in New Issue
Block a user