4.3 KiB
4.3 KiB
测试补充执行文档(2026-03-03)
目标
- 为近期重构与修复引入的关键路径补齐高价值测试。
- 降低“请求契约回退”“状态错乱”“错误处理分散”三类回归风险。
- 每完成一个测试包:更新本文件状态并创建独立 git commit。
执行清单
T1 requestJson 统一请求层单测(src/lib/fetcher.ts)【已完成】
- 新增测试文件:
src/lib/fetcher.test.ts - 用例清单:
- 200 JSON 响应:返回解析后的对象。
- 带 body 请求:自动注入
Content-Type: application/json且正确序列化。 - 调用方自定义
Content-Type时不被覆盖。 - 204 响应:返回
undefined。 - 非 2xx 且 payload 含
{ error }:抛出ApiRequestError,message/status/payload 正确。 - 非 2xx 且纯文本响应:错误消息回退为文本内容。
- 响应对象无
text()仅有json()时仍可解析(兼容测试 mock)。
- 通过标准:
npx vitest run src/lib/fetcher.test.ts通过。npx tsc --noEmit通过。
- 完成记录:
- 已新增
src/lib/fetcher.test.ts,覆盖 7 个用例,执行通过(2026-03-03)。
T2 useBlindboxDraw 状态机补测(src/hooks/useBlindboxDraw.ts)【已完成】
- 新增测试文件:
src/hooks/useBlindboxDraw.test.ts - 用例清单:
poolCount=0:直接报错,不触发请求。- 抽取成功:调用
requestJson(仅提交roomId),并正确更新phase/poolCount/drawnHistory/revealedIdea。 - 抽取失败:回退到
pool,写入错误信息。
- 通过标准:
npx vitest run src/hooks/useBlindboxDraw.test.ts通过。npx tsc --noEmit通过。
- 完成记录:
- 已新增
src/hooks/useBlindboxDraw.test.ts,覆盖空池/成功/失败 3 条关键分支(2026-03-03)。
T3 useBlindboxRoom 关键交互补测(src/hooks/useBlindboxRoom.ts)【已完成】
- 新增测试文件:
src/hooks/useBlindboxRoom.test.ts - 用例清单:
- 初始化拉取房间成功后,成员判断正确(
isMember=true)。 handleJoinRoom仅提交code参数,成功后刷新成员状态。handleLeaveOrDelete二次确认流程正确,删除请求不再携带冗余 body。
- 通过标准:
npx vitest run src/hooks/useBlindboxRoom.test.ts通过。npx tsc --noEmit通过。
- 完成记录:
- 已新增
src/hooks/useBlindboxRoom.test.ts,覆盖初始化成员识别、仅 code 入参加入、二次确认删除(2026-03-03)。
T4 useBlindboxPlan 核心分支补测(src/hooks/useBlindboxPlan.ts)【已完成】
- 新增测试文件:
src/hooks/useBlindboxPlan.test.ts - 用例清单:
fetchAcceptedPlan正常读取已接受计划并写入activeContract。handleGeneratePlan在流式失败时走 fallback API,成功进入plan_reveal。handleAcceptPlan成功:设置planAccepted、更新activeContract、触发提示。handleAcceptPlan失败:不应误标记已接受,返回错误提示。
- 通过标准:
npx vitest run src/hooks/useBlindboxPlan.test.ts通过。npx tsc --noEmit通过。
- 完成记录:
- 已新增
src/hooks/useBlindboxPlan.test.ts,覆盖 latest、流式失败 fallback、accept 成功/失败四个关键分支(2026-03-03)。
T5 E2E 关键流程补测(Playwright)【已完成】
- 新增配置与测试:
playwright.config.tse2e/home-navigation.spec.tse2e/panic-join.spec.tse2e/invite-join.spec.ts
- 用例清单:
- 首页模式卡片导航:
/->/panic-> 返回 ->/blindbox。 - Panic 手动加入:房间号输入规范化(大写、过滤非法字符、截断 6 位)并成功跳转房间。
- 邀请页加入:展示房间人数,点击加入后成功跳转房间。
- 通过标准:
npm run test:e2e通过。
- 完成记录:
- 已补齐 Playwright 配置与 3 条 E2E 用例(2026-03-03)。
- Jenkins 已接入 E2E 门禁(
test:e2e:install+test:e2e)(2026-03-03)。 - 已安装
@playwright/test与 Chromium 浏览器,并实测npm run test:e2e通过(3/3)(2026-03-03)。
状态追踪
- T1:已完成(2026-03-03)
- T2:已完成(2026-03-03)
- T3:已完成(2026-03-03)
- T4:已完成(2026-03-03)
- T5:已完成(代码已补齐,2026-03-03)