mirror of
https://github.com/azaion/ui.git
synced 2026-06-21 17:51:10 +00:00
38eb87fb08
Scaffolds the Blackbox test project per AZ-456 / environment.md across
the three profiles:
- fast : Vitest 3.x + jsdom + MSW 2.x + RTL/jest-dom; tests/setup.ts
boots the MSW Node server with onUnhandledRequest:'error',
afterEach resets handlers, clears bearer + navigate-to-login
spy. Default handlers ship for every suite service plus OWM
and tile stand-ins. Fixtures mirror seed_* in test-data.md.
- e2e : Playwright ^1.49 with chromium + firefox projects against the
suite docker-compose stack; owm-stub + tile-stub Bun servers,
playwright-runner image, seeds.sql for the test-db.
- static: scripts/run-tests.sh extended — tsc --noEmit (test config),
vite build, ripgrep checks (with grep -r fallback), CSV
report at test-output/static-report.csv per AC-7 columns.
Smoke tests cover AC-3, AC-4 (fast, 5 tests, PASS) and AC-1, AC-2,
AC-5, AC-8 (e2e, gated by Risk 4 docker availability). Static profile
(13 checks) PASS — STC-SEC1 (no literal OWM key) lifted from
QUARANTINE per AZ-447 with a narrowed pattern.
Files:
+24 tests/**, +10 e2e/**, +vitest.config.ts, +tsconfig.test.json
~package.json (test scripts + devDeps for vitest, @testing-library/*,
msw, @playwright/test, jsdom, @types/node, @vitest/coverage-v8)
~scripts/run-tests.sh, scripts/run-performance-tests.sh — switched
RESULTS_DIR to test-output/, compose path to project-local
~.gitignore — added /test-output/
Verification:
bun run test:fast → 11 / 11 PASS
./scripts/run-tests.sh → static 13/13 + fast 11/11 PASS, exit 0
Tracker: AZ-456 → In Testing.
Co-authored-by: Cursor <cursoragent@cursor.com>
59 lines
1.8 KiB
TypeScript
59 lines
1.8 KiB
TypeScript
// owm-stub — OpenWeatherMap stand-in for the e2e profile (AZ-456 AC-2).
|
|
// Returns canned `/data/2.5/weather` responses keyed by lat,lon. A request log
|
|
// is exposed at `/mock/log` for resilience tests; `/mock/config` swaps the
|
|
// canned set without restarting the container.
|
|
|
|
interface WindResponse {
|
|
wind: { speed: number; deg: number }
|
|
name: string
|
|
coord: { lat: number; lon: number }
|
|
}
|
|
|
|
const PORT = Number(process.env.PORT ?? 8081)
|
|
|
|
let cannedResponses: Record<string, WindResponse> = {
|
|
'0,0': { wind: { speed: 5.0, deg: 270 }, name: 'TestCity', coord: { lat: 0, lon: 0 } },
|
|
'50.45,30.52': { wind: { speed: 7.5, deg: 90 }, name: 'Kyiv', coord: { lat: 50.45, lon: 30.52 } },
|
|
}
|
|
|
|
const requestLog: Array<{ ts: string; method: string; url: string }> = []
|
|
|
|
function key(lat: string | null, lon: string | null): string {
|
|
return `${lat ?? '0'},${lon ?? '0'}`
|
|
}
|
|
|
|
const server = Bun.serve({
|
|
port: PORT,
|
|
fetch(req) {
|
|
const url = new URL(req.url)
|
|
requestLog.push({ ts: new Date().toISOString(), method: req.method, url: url.pathname + url.search })
|
|
|
|
if (url.pathname === '/health') {
|
|
return new Response('ok', { status: 200 })
|
|
}
|
|
|
|
if (url.pathname === '/mock/log') {
|
|
return Response.json(requestLog)
|
|
}
|
|
|
|
if (url.pathname === '/mock/config' && req.method === 'POST') {
|
|
return req.json().then((body) => {
|
|
cannedResponses = body as Record<string, WindResponse>
|
|
return new Response(null, { status: 204 })
|
|
})
|
|
}
|
|
|
|
if (url.pathname === '/data/2.5/weather') {
|
|
const lat = url.searchParams.get('lat')
|
|
const lon = url.searchParams.get('lon')
|
|
const k = key(lat, lon)
|
|
const payload = cannedResponses[k] ?? cannedResponses['0,0']
|
|
return Response.json(payload)
|
|
}
|
|
|
|
return new Response('not found', { status: 404 })
|
|
},
|
|
})
|
|
|
|
console.log(`[owm-stub] listening on :${server.port}`)
|