disable-model-invocation: true name: spec-debug description: > 诊断并修复 Spec 执行过程中发现的问题。由角色 spec-debugger 调用。 触发条件:(1) 角色 spec-debugger 接收到 TeamLead 转交的 bug handoff, (2) spec-executor 执行后出现 bug 或 writer/plan.md 中未考虑到的情况, (3) 运行时出现问题、依赖环境或配置问题。 不修改已确认的 writer/plan.md,而是在 debugger/ 下创建独立的诊断文档(debug-xxx.md)和修复总结(debug-xxx-fix.md)。 修复完成后向 TeamLead 提交重新验证请求,由 TeamLead 启动 spec-tester。
Spec Debug
运行契约
进入核心原则前先对齐这张表。它把本 Skill 当成一个有边界的循环单元:明确读什么、能动什么、怎么算完成、什么时候停、什么时候交还给人。
| 项 | 本 Skill 的约定 |
|---|---|
| 输入 | TeamLead 转交的 bug handoff(含复现步骤)、writer/plan.md、executor/summary.md、tester/test-report.md、exp-search 结果 |
| 权限 | 写 debugger/debug-xxx.md / debug-xxx-fix.md + 最小化修复代码;不改已确认的 writer/plan.md、不加新功能、不自行判定修复成功 |
| 验证 | 诊断含根因分析、修复总结含前后对比与本轮进展(新增根因/缩小范围/新增证据),由 spec-tester 重新验证 |
| 停止 | 受 Loop Budget 约束:rounds_used 达 max_rounds 或 no_progress_streak 达 max_no_progress_rounds 时停止修复 |
| 升级 | 预算未确认、触发预算上限、或根因涉及权限/计费/数据迁移/需绕过测试时,停止并交回 TeamLead 由用户决策 |
核心原则
- 不修改已确认的 writer/plan.md:通过创建 debug 文档记录问题,保持设计的可追溯性
- 闭环协作:接收 TeamLead 转交的 bug handoff → 修复 → 向 TeamLead 请求重新验证
- 用户确认诊断:创建 debug-xxx.md 后,由 TeamLead 向用户确认诊断结果
- 受预算约束:修复循环受
lead/team-context.md的Loop Budget约束(max_rounds/max_no_progress_rounds,由用户在进入循环前确认)。每轮修复后必须更新rounds_used和no_progress_streak,触发上限时停止并交还 TeamLead,不自行无限重试。
协作闭环
spec-tester 发现 bug
→ 向 TeamLead 提交 bug handoff(含复现步骤)
→ TeamLead 启动 spec-debugger
→ spec-debugger 调用 spec-debug
→ 诊断 → debugger/debug-xxx.md
→ TeamLead 向用户确认诊断
→ 修复 → debugger/debug-xxx-fix.md
→ spec-debugger 向 TeamLead 请求 spec-tester 重新验证
→ TeamLead 启动 spec-tester 重新验证
→ spec-tester 验证通过 → 记录到 tester/test-report.md
工作流程
步骤 1:收集问题信息
从 TeamLead 转交的 bug handoff 中获取:
- 问题现象和复现步骤
- 预期行为 vs 实际行为
- 相关测试用例编号
读取相关文档:writer/plan.md、executor/summary.md、tester/test-report.md(草稿)。
步骤 2:检索历史经验
/exp-search <关键词>
以问题关键词检索,参考历史解决方案。
步骤 3:复现并定位问题
尝试复现问题,使用日志、调试工具定位问题代码,确认边界条件。
步骤 4:分析根因
| 类型 | 说明 |
|---|---|
| 设计遗漏 | writer/plan.md 未考虑的边界情况 |
| 实现偏差 | 实现与 writer/plan.md 不一致 |
| 环境问题 | 依赖、配置、版本问题 |
| 集成问题 | 模块间交互问题 |
步骤 5:创建 debug-xxx.md 诊断文档
命名规范:debugger/debug-001.md(按发现顺序编号)
Frontmatter:
---
title: 问题诊断-简述
type: debug
category: 与 writer/plan.md 相同
status: 未确认
severity: 高/中/低
created: YYYY-MM-DD
plan: "[[../writer/plan|plan]]"
tags:
- spec
- debug
---
必须包含:问题现象、复现步骤、根因分析、修复方案、与 writer/plan.md 的关系。
详细格式见 references/debug-template.md。
步骤 6:通知 TeamLead 等待用户确认诊断
先更新当前 Spec 的 lead/team-context.md 共享区:
- 在
Problem Resolution Log中追加或更新对应问题行 owner写spec-debuggerartifacts指向debugger/debug-xxx.mdstatus标记为diagnosedupdated_by写spec-debugger- 只修改
Problem Resolution Log,不要修改 TeamLead 控制面区块
通知 TeamLead:debugger/debug-001.md 已创建,请向用户确认诊断结果。路径:{路径}
TeamLead 使用当前运行环境的确认方式向用户确认。等待确认通过后继续修复。
步骤 7:检查修复循环预算
开始本轮修复前,读取 lead/team-context.md 的 Loop Budget(test-debug 行):
- 如果
max_rounds/max_no_progress_rounds仍为「待确认」,说明 TeamLead 尚未与用户确认预算,先停止并请 TeamLead 用intent-confirmation确认预算(建议默认 3 轮 / 连续 2 轮无进展),不要在无预算的情况下进入修复。 - 如果
rounds_used已达到max_rounds,或no_progress_streak已达到max_no_progress_rounds,不要再修复,直接向 TeamLead 升级,由用户决定继续加预算、改方案还是暂停。 - 预算未触上限时,继续步骤 8 的修复。
步骤 8:执行修复
按照确认的修复方案修改代码:
- 最小化修改范围
- 不借机添加新功能
- 在代码注释中引用 debug 文档:
# 修复: debugger/debug-001.md
步骤 9:创建 debug-xxx-fix.md 修复总结
Frontmatter:
---
title: 修复总结-简述
type: debug-fix
category: 与 writer/plan.md 相同
status: 未确认
created: YYYY-MM-DD
plan: "[[../writer/plan|plan]]"
debug: "[[debug-001|debug-001]]"
tags:
- spec
- debug-fix
---
必须包含:修改的文件、关键修改前后对比、验证结果、本轮相对上一轮的进展(新增定位的根因 / 缩小的失败范围 / 新增证据)。
步骤 10:更新修复循环记账
更新 lead/team-context.md 的 Loop Budget(test-debug 行):
rounds_used加 1- 判断本轮是否「有进展」:是否定位到此前未知的根因、是否缩小了失败范围、是否产生了新的可验证证据。
- 有进展:
no_progress_streak归零 - 无进展(仅写了新总结但根因、范围、证据都没动):
no_progress_streak加 1
- 有进展:
- 若
rounds_used达到max_rounds或no_progress_streak达到max_no_progress_rounds,把status标为stopped-budget或stopped-no-progress,并在通知中要求 TeamLead 升级给用户;否则保持status=running updated_at使用当前时间
步骤 11:向 TeamLead 提交重新验证请求
先更新当前 Spec 的 lead/team-context.md 共享区:
- 在
Task Progress中追加或更新 spec-debugger 自己的调试修复任务行,artifact指向debugger/debug-xxx-fix.md - 在
Problem Resolution Log中更新对应问题行,resolution简述修复方案,artifacts包含debugger/debug-xxx.md/debugger/debug-xxx-fix.md status标记为fixed_pending_verificationcompleted_at使用当前时间,updated_by写spec-debugger- 只修改
Task Progress/Problem Resolution Log/Loop Budget,不要修改 TeamLead 其他控制面区块
如果预算未触上限:
通知 TeamLead:
- bug 已修复(第 {rounds_used} 轮)
- 本轮进展:[新增根因 / 缩小范围 / 新增证据]
- 请启动 spec-tester 重新验证测试用例 TC-XXX
- 修复详情:debugger/debug-001-fix.md
如果触发了预算上限(stopped-budget / stopped-no-progress):
通知 TeamLead:修复循环已达预算上限,停止修复并请升级给用户。
- 已用轮数:{rounds_used}/{max_rounds}
- 连续无进展轮数:{no_progress_streak}/{max_no_progress_rounds}
- 当前最接近的根因假设和剩余风险:[简述]
- 建议用户在「继续加预算 / 改方案 / 暂停」中决定下一步
与其他角色的协作
spec-tester → TeamLead → spec-debugger(本角色)
spec-debugger → 诊断 → 通知 TeamLead(用户确认)→ 修复
spec-debugger → TeamLead → spec-tester(重新验证)
- 不直接修改
writer/plan.md - 不在修复中添加新功能(使用 spec-update)
- 修复完成后必须向 TeamLead 请求 spec-tester 重新验证,不自行判断修复是否成功
- 不在
Loop Budget触发上限后继续修复,必须停止并升级给 TeamLead
后续动作
完成修复后确认:
debugger/debug-xxx.md已创建且用户已确认诊断debugger/debug-xxx-fix.md已创建- 已更新
lead/team-context.md的Task Progress、Problem Resolution Log和Loop Budget(rounds_used/no_progress_streak/status) - 已向 TeamLead 提交重新验证请求,或在触发预算上限时请求升级
- 未修改
writer/plan.md
常见陷阱
- 直接修改
writer/plan.md而不是创建 debug 文档 - 修复后未向 TeamLead 请求 spec-tester 重新验证(破坏闭环)
- 修复时引入了新功能(应使用 spec-update)
- 每轮都写新的 debug 文档但没有实质进展,却不更新
no_progress_streak(loop 在原地打转) - 在预算未确认或已触上限时仍继续修复(应停止并升级给 TeamLead)