7b33516686
Adds the M5.3 deliverable scoped to local-dev (stage doesn't exist yet,
so the CI e2e job is gated behind the repo variable RUN_E2E='true' —
defaults off).
Layout:
playwright.config.ts chromium project; baseURL defaults to
http://acme.localhost:3000 (subdomain routing
fires). PLAYWRIGHT_BASE_URL / APEX_URL / etc.
env vars override for stage.
tests/e2e/apex.spec.ts landing page renders
tests/e2e/tenant.spec.ts signed-out dashboard shows Sign in
button; unknown slug returns 404
tests/e2e/health.spec.ts every dev-stack endpoint reachable
(portal /api/auth/providers, tenant-
registry /healthz, KC realm metadata)
Run locally with the full dev stack up:
cd platform/orca-platform && make dev-up
cd platform/tenant-registry && make dev
cd platform/portal && make dev
cd platform/portal && make e2e
OIDC click-through not asserted yet — Keycloak in headless mode is
flaky and depends on a stable test-user password. The current gate
(Sign-in button visible) catches the more common 'auth completely
broken' regression; the deeper smoke lands when stage has its own
test fixture.
tsconfig now excludes tests/e2e so vitest + tsc don't fight over
Playwright type imports.
Refs: M5.3
33 lines
1.3 KiB
TypeScript
33 lines
1.3 KiB
TypeScript
import { expect, test } from "@playwright/test";
|
|
|
|
// Health checks — confirm the underlying services are reachable before the
|
|
// stack-dependent tests run. Skips with a clear reason if anything is down,
|
|
// so we don't waste 30s on a slow OIDC redirect when Keycloak isn't running.
|
|
|
|
test.describe("dev stack health @needs-stack", () => {
|
|
test("portal /api/auth/providers responds", async ({ request }) => {
|
|
const r = await request.get("/api/auth/providers");
|
|
expect(r.status()).toBe(200);
|
|
const data = await r.json();
|
|
expect(data).toHaveProperty("keycloak");
|
|
});
|
|
|
|
test("tenant-registry /healthz responds", async ({ request }) => {
|
|
const url =
|
|
process.env.PLAYWRIGHT_TENANT_REGISTRY_URL ?? "http://localhost:8090";
|
|
const r = await request.get(`${url}/healthz`);
|
|
expect(r.status()).toBe(200);
|
|
expect(await r.json()).toMatchObject({ status: "ok" });
|
|
});
|
|
|
|
test("keycloak realm metadata is exposed", async ({ request }) => {
|
|
const url =
|
|
process.env.PLAYWRIGHT_KEYCLOAK_URL ??
|
|
"http://localhost:8080/realms/breakpilot-dev";
|
|
const r = await request.get(`${url}/.well-known/openid-configuration`);
|
|
expect(r.status()).toBe(200);
|
|
const cfg = await r.json();
|
|
expect(cfg.issuer).toContain("breakpilot-dev");
|
|
});
|
|
});
|