feat(test): M5.3 — Playwright e2e harness for the dev stack
playwright.config.ts + tests/e2e/{apex,tenant,health}.spec.ts. make e2e for local. CI e2e job opt-in via RUN_E2E repo variable. OIDC click-through deferred to when stage is up.
Refs: M5.3
This commit was merged in pull request #8.
This commit is contained in:
@@ -0,0 +1,33 @@
|
||||
import { expect, test } from "@playwright/test";
|
||||
|
||||
// Tenant subdomain tests — no OIDC click-through (Keycloak in headless mode
|
||||
// is flaky); we just assert the SIGNED-OUT view of each protected route
|
||||
// renders the expected gate. Once the realm grows a service-account flow
|
||||
// for testing (M5.x), we'll bolt on a signed-in suite.
|
||||
|
||||
test.describe("tenant subdomain @needs-stack", () => {
|
||||
test("acme dashboard renders the Sign-in button when signed out", async ({ page }) => {
|
||||
await page.goto("/dashboard");
|
||||
await expect(page.getByRole("heading", { name: /Sign in to acme/i })).toBeVisible();
|
||||
await expect(page.getByRole("button", { name: /Sign in with Keycloak/i })).toBeVisible();
|
||||
});
|
||||
|
||||
test("acme /products requires sign-in", async ({ page }) => {
|
||||
await page.goto("/products");
|
||||
// Either the user is sent to dashboard's sign-in form, or the page renders
|
||||
// the canSee=false branch (NotAuthorized) depending on session state.
|
||||
// Both are legitimate; the assertion is that we do NOT see the empty
|
||||
// product tile body without a session.
|
||||
const isSignedIn = await page.getByRole("heading", { name: /Products/i }).isVisible();
|
||||
if (!isSignedIn) {
|
||||
await expect(
|
||||
page.getByRole("button", { name: /Sign in with Keycloak/i }),
|
||||
).toBeVisible();
|
||||
}
|
||||
});
|
||||
|
||||
test("unknown tenant slug 404s", async ({ page }) => {
|
||||
const resp = await page.goto("http://nope-nope.localhost:3000/dashboard");
|
||||
expect(resp?.status()).toBe(404);
|
||||
});
|
||||
});
|
||||
Reference in New Issue
Block a user