# Phase 5: Test Hardening and Commit Hygiene - Context
**Gathered:** 2026-04-07
**Status:** Ready for planning
## Phase Boundary
本阶段聚焦“测试与提交卫生”收口,不新增产品能力:
1. 巩固 E2E 覆盖与可执行稳定性(尤其是历史/fixture 波动场景);
2. 收敛测试断言策略(前端可控优先,后端不稳定可解释);
3. 将现有改动按 concern(style / logic / tests / docs)整理为审阅友好的提交结构;
4. 输出可审阅验证记录,支撑最终合并。
## Implementation Decisions
### 测试硬化策略
- **D-01:** 以现有 e2e 集合为基础(`thread-routing`、`welcome-and-routing`、`input-and-compose`、`message-and-history`、`artifacts-and-thread-reuse`)做稳定性收敛,不新建大规模测试体系。
- **D-02:** 对依赖后端/fixture 的断言统一采用“可执行 + 可解释”策略:可验证前端状态优先,缺少数据时 skip 并附明确 reason。
- **D-03:** 对核心路径(路由、输入发送、导出、selectedSkill)保持强断言;对环境敏感路径(历史条数、todos可见性)采用弹性断言。
### 提交卫生策略
- **D-04:** 按 concern 组织提交:
- style(纯视觉)
- logic(行为/容错)
- tests(测试与断言)
- docs(planning/UAT/SUMMARY)
- **D-05:** 每个提交保证“可独立解释 + 通过最小验证命令”,避免混杂不可审阅 diff。
- **D-06:** 不重写历史已提交内容,仅整理当前工作区未提交变更。
### 审阅与验证输出
- **D-07:** Phase 5 输出中必须包含“哪些用例 pass / 哪些 skip / skip 原因”摘要,避免 reviewer 误解为未执行。
- **D-08:** 对高风险文件(`use-thread-chat.ts`、`use-selected-skill-listener.ts`、E2E helper)提供 reviewer 导向说明。
### the agent's Discretion
- 具体 commit 粒度(一个或多个提交)。
- 断言细节中的超时时间与 selector 选择。
## Specific Ideas
- 现状已有多次 phase 执行痕迹,Phase 5 不追求“全绿无 skip”,而追求“结果可信 + 原因透明 + 可持续回归”。
- 对于 `logs/langgraph.log` 暴露的后端波动,前端测试层面只做防级联,不在本阶段改后端。
- 以 reviewer 读 diff 的效率为核心目标:减少跨 concern 混改。
## Canonical References
**Downstream agents MUST read these before planning or implementing.**
### 规划与上游结果
- `.planning/ROADMAP.md` — Phase 5 目标定义。
- `.planning/phases/03-legacy-visual-alignment-pass/03-UAT.md` — Phase 3 问题与修复来源。
- `.planning/phases/04-iframe-markdown-new-system-stabilization/04-UAT.md` — Phase 4 验证结论与 skip 背景。
- `.planning/phases/04-iframe-markdown-new-system-stabilization/04-SUMMARY.md` — Phase 4 改动范围。
### E2E 与辅助
- `frontend/tests/e2e/welcome-and-routing.spec.ts`
- `frontend/tests/e2e/thread-routing.spec.ts`
- `frontend/tests/e2e/input-and-compose.spec.ts`
- `frontend/tests/e2e/message-and-history.spec.ts`
- `frontend/tests/e2e/artifacts-and-thread-reuse.spec.ts`
- `frontend/tests/e2e/support/chat-helpers.ts`
### 高风险逻辑文件
- `frontend/src/components/workspace/chats/use-thread-chat.ts`
- `frontend/src/hooks/use-selected-skill-listener.ts`
- `frontend/src/core/iframe-messages.ts`
- `frontend/src/core/threads/export.ts`
## Existing Code Insights
### Reusable Assets
- `chat-helpers.ts` 已沉淀线程 URL 构建、等待策略、skip helper,可作为全套 E2E 的统一基座。
- `playwright.config.ts` 已具备 `.env/.env.local` 加载与基础配置,可直接扩展执行策略。
### Established Patterns
- 近期测试收敛统一采用“前端可控断言优先”。
- 近期文档节奏为 `CONTEXT -> PLAN -> SUMMARY -> UAT`,Phase 5 需保持一致。
### Integration Points
- E2E 断言与 `use-thread-chat` / `message-list` 的 DOM 结构耦合较高,修改时需同步检查 selector 稳定性。
- 提交分组需与实际文件归属一致,避免 mixed concern。
## Deferred Ideas
- 后端 history/todos fixture 机制重构(属于后端/数据工程范围,非本 phase)。
- 引入更重的 E2E 数据工厂或全链路 mock 平台(可作为后续提升项)。
---
*Phase: 05-test-hardening-and-commit-hygiene*
*Context gathered: 2026-04-07*