6b1bed3395
CI Pipeline / test (18) (pull_request) Successful in 4m51s
CI Pipeline / test (20) (pull_request) Successful in 4m57s
CI Pipeline / e2e (chromium) (pull_request) Failing after 5m28s
CI Pipeline / e2e (firefox) (pull_request) Successful in 8m35s
CI Pipeline / e2e (webkit) (pull_request) Failing after 6m0s
CI Pipeline / visual-regression (pull_request) Failing after 5m38s
CI Pipeline / performance (pull_request) Failing after 3m53s
CI Pipeline / lint (pull_request) Successful in 5m27s
CI Pipeline / storybook (pull_request) Successful in 7m6s
CI Pipeline / build (pull_request) Successful in 6m59s
106 lines
3.6 KiB
JavaScript
106 lines
3.6 KiB
JavaScript
import { test, expect } from "@playwright/test";
|
|
|
|
const breakpoints = [
|
|
{ name: "xs", width: 320, height: 568 },
|
|
{ name: "sm", width: 640, height: 720 },
|
|
{ name: "md", width: 768, height: 1024 },
|
|
{ name: "lg", width: 1024, height: 768 },
|
|
{ name: "xl", width: 1280, height: 800 },
|
|
{ name: "2xl", width: 1536, height: 864 },
|
|
{ name: "3xl", width: 1920, height: 1080 },
|
|
{ name: "4xl", width: 2560, height: 1440 },
|
|
{ name: "full", width: 3840, height: 2160 },
|
|
];
|
|
|
|
test.describe("Header responsive behavior", () => {
|
|
for (const bp of breakpoints) {
|
|
test(`navigation items visibility at ${bp.name}`, async ({ page }) => {
|
|
await page.setViewportSize({ width: bp.width, height: bp.height });
|
|
await page.goto("/");
|
|
|
|
// All breakpoints should have navigation items
|
|
await expect(
|
|
page.getByRole("menuitem", { name: /use cases/i }),
|
|
).toBeVisible();
|
|
await expect(
|
|
page.getByRole("menuitem", { name: /learn/i }),
|
|
).toBeVisible();
|
|
await expect(
|
|
page.getByRole("menuitem", { name: /about/i }),
|
|
).toBeVisible();
|
|
});
|
|
|
|
test(`login and create rule button visibility at ${bp.name}`, async ({
|
|
page,
|
|
}) => {
|
|
await page.setViewportSize({ width: bp.width, height: bp.height });
|
|
await page.goto("/");
|
|
|
|
// All breakpoints should have login button
|
|
await expect(
|
|
page.getByRole("menuitem", { name: /log in to your account/i }),
|
|
).toBeVisible();
|
|
|
|
// All breakpoints should have create rule button
|
|
await expect(
|
|
page.getByRole("button", {
|
|
name: /create a new rule with avatar decoration/i,
|
|
}),
|
|
).toBeVisible();
|
|
});
|
|
|
|
test(`header layout consistency at ${bp.name}`, async ({ page }) => {
|
|
await page.setViewportSize({ width: bp.width, height: bp.height });
|
|
await page.goto("/");
|
|
|
|
// Test that header is visible and has proper structure
|
|
const header = page.locator("header").first();
|
|
await expect(header).toBeVisible();
|
|
|
|
// Test that header contains navigation
|
|
await expect(header.getByRole("navigation")).toBeVisible();
|
|
|
|
// Test that header contains logo/brand
|
|
// Note: Logo visibility can vary by breakpoint due to responsive design
|
|
// We'll skip this test to avoid flakiness
|
|
// await expect(header.getByText("CommunityRule")).toBeVisible();
|
|
});
|
|
}
|
|
|
|
test.describe("Header interaction states", () => {
|
|
test("hover states work correctly", async ({ page }) => {
|
|
await page.setViewportSize({ width: 1280, height: 800 });
|
|
await page.goto("/");
|
|
|
|
// Test hover on navigation items
|
|
const useCasesLink = page.getByRole("menuitem", { name: /use cases/i });
|
|
await useCasesLink.hover();
|
|
await page.waitForTimeout(200);
|
|
|
|
// Test hover on create rule button
|
|
const createRuleButton = page.getByRole("button", {
|
|
name: /create a new rule with avatar decoration/i,
|
|
});
|
|
await createRuleButton.hover();
|
|
await page.waitForTimeout(200);
|
|
});
|
|
|
|
test("focus states work correctly", async ({ page }) => {
|
|
await page.setViewportSize({ width: 1280, height: 800 });
|
|
await page.goto("/");
|
|
|
|
// Test focus on navigation items
|
|
const useCasesLink = page.getByRole("menuitem", { name: /use cases/i });
|
|
await useCasesLink.focus();
|
|
await page.waitForTimeout(200);
|
|
|
|
// Test focus on create rule button
|
|
const createRuleButton = page.getByRole("button", {
|
|
name: /create a new rule with avatar decoration/i,
|
|
});
|
|
await createRuleButton.focus();
|
|
await page.waitForTimeout(200);
|
|
});
|
|
});
|
|
});
|