mirror of
https://github.com/azaion/ui.git
synced 2026-06-21 08:01:10 +00:00
ed81034511
Batch 2 of testability refactor under epic AZ-447. All three changes are minimal-surgical and preserve production behavior. AZ-448 (C01) — Externalize OWM API key - src/features/flights/flightPlanUtils.ts: read VITE_OWM_API_KEY at call time; if unset, getWeatherData returns null (matches the existing try/catch fallback contract, AC-3). - Hardcoded literal removed; grep src/ for the old key returns no hits (AC-2 / NFT-SEC-09 static-string check now green). - AC-1 honored: when the key is set, the outbound URL contains appid=<key>. AZ-449 (C02) — Externalize OWM base URL - Same call site reads VITE_OWM_BASE_URL with trim-trailing-slash normalization; falls back to the public api.openweathermap.org/data/2.5 endpoint when unset (AC-1). - Stub-friendly: VITE_OWM_BASE_URL=http://owm-stub:8081/data/2.5 redirects every call to the e2e stub (AC-2). AZ-453 (C06) — Wrap login redirect in setNavigateToLogin accessor - src/api/client.ts: navigateToLoginImpl module-level fn defaults to the existing window.location.href = '/login' write; setNavigateToLogin(fn) lets tests assert "redirect invoked" without globally stubbing window.location. - request() now calls navigateToLoginImpl() instead of writing window.location directly. Batch 1 task specs (AZ-450/451/452/454) moved from _docs/02_tasks/todo/ to _docs/02_tasks/done/. State pointer advanced to refactor Phase 4 (implement, batch 2 of 2). Static checks: - bun run tsc --noEmit: 0 errors - grep '335799082893fad97fa36118b131f919' src/: 0 hits - grep 'window.location.href' src/: 2 hits, both inside the navigateToLoginImpl default (jsdoc + the default impl body) — no caller writes window.location directly. Co-authored-by: Cursor <cursoragent@cursor.com>
988 B
988 B
Autodev State
Current Step
flow: existing-code step: 4 name: Code Testability Revision status: in_progress sub_step: phase: 4 name: refactor-phase-4-implement detail: "batch 2 of 2 — AZ-448, AZ-449, AZ-453" retry_count: 0 cycle: 1 step_4_5_glossary_vision: confirmed step_2_baseline_routing: per-finding-recommended (option A) step_3_results_report_authoring: agent (option A) step_3_ac_gap_handling: rollback-to-6c (option A)
Notes
- Phase A baseline cycle. Step 1 (Document) complete; see
_docs/02_document/state.json,FINAL_report.md,architecture.md,glossary.md, plus_docs/01_solution/solution.mdand_docs/00_problem/{problem,acceptance_criteria,restrictions,security_approach}.md. - Suite-level architecture:
../_docs/. UI design:_docs/ui_design/. - Legacy reference:
_docs/legacy/wpf-era.md+ research copy atsuite/annotations-research(detached @22529c2). - /document scope was src/ AND mission-planner/ (two disjoint groups).