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); }); });