4.4 KiB
4.4 KiB
Phase 5: Test Hardening and Commit Hygiene - Context
Gathered: 2026-04-07 Status: Ready for planning
## Phase Boundary本阶段聚焦“测试与提交卫生”收口,不新增产品能力:
- 巩固 E2E 覆盖与可执行稳定性(尤其是历史/fixture 波动场景);
- 收敛测试断言策略(前端可控优先,后端不稳定可解释);
- 将现有改动按 concern(style / logic / tests / docs)整理为审阅友好的提交结构;
- 输出可审阅验证记录,支撑最终合并。
测试硬化策略
- 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 选择。
- 现状已有多次 phase 执行痕迹,Phase 5 不追求“全绿无 skip”,而追求“结果可信 + 原因透明 + 可持续回归”。
- 对于
logs/langgraph.log暴露的后端波动,前端测试层面只做防级联,不在本阶段改后端。 - 以 reviewer 读 diff 的效率为核心目标:减少跨 concern 混改。
<canonical_refs>
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.tsfrontend/tests/e2e/thread-routing.spec.tsfrontend/tests/e2e/input-and-compose.spec.tsfrontend/tests/e2e/message-and-history.spec.tsfrontend/tests/e2e/artifacts-and-thread-reuse.spec.tsfrontend/tests/e2e/support/chat-helpers.ts
高风险逻辑文件
frontend/src/components/workspace/chats/use-thread-chat.tsfrontend/src/hooks/use-selected-skill-listener.tsfrontend/src/core/iframe-messages.tsfrontend/src/core/threads/export.ts
</canonical_refs>
<code_context>
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。
</code_context>
## Deferred Ideas- 后端 history/todos fixture 机制重构(属于后端/数据工程范围,非本 phase)。
- 引入更重的 E2E 数据工厂或全链路 mock 平台(可作为后续提升项)。
Phase: 05-test-hardening-and-commit-hygiene Context gathered: 2026-04-07