name: 完成开发分支 description: 当实现完成、所有测试通过时使用,需要决定如何整合工作 - 通过提供合并、PR或清理的结构化选项来指导开发工作的完成
完成开发分支
概述
通过提供清晰的选项并处理选择的工作流来指导开发工作的完成。
核心原则: 验证测试 → 呈现选项 → 执行选择 → 清理。
开始时宣布: “我正在使用完成开发分支技能来完成这项工作。”
过程
步骤 1: 验证测试
在呈现选项之前,验证测试通过:
# 运行项目的测试套件
npm test / cargo test / pytest / go test ./...
如果测试失败:
测试失败(<N> 个失败)。在完成前必须修复:
[显示失败]
在测试通过之前不能进行合并/PR。
停止。不要继续到步骤 2。
如果测试通过: 继续到步骤 2。
步骤 2: 确定基础分支
# 尝试常见的基础分支
git merge-base HEAD main 2>/dev/null || git merge-base HEAD master 2>/dev/null
或者询问:“这个分支是从 main 分支分离出来的 - 对吗?”
步骤 3: 呈现选项
呈现恰好这 4 个选项:
实现完成。您想做什么?
1. 本地合并回 <base-branch>
2. 推送并创建 Pull Request
3. 保持分支原样(我稍后处理)
4. 丢弃此工作
选择哪个选项?
不要添加解释 - 保持选项简洁。
步骤 4: 执行选择
选项 1: 本地合并
# 切换到基础分支
git checkout <base-branch>
# 拉取最新
git pull
# 合并功能分支
git merge <feature-branch>
# 验证合并后的测试
<test command>
# 如果测试通过
git branch -d <feature-branch>
然后:清理工作树(步骤 5)
选项 2: 推送并创建 PR
# 推送分支
git push -u origin <feature-branch>
# 创建 PR
gh pr create --title "<title>" --body "$(cat <<'EOF'
## 摘要
<2-3 个更改要点>
## 测试计划
- [ ] <验证步骤>
EOF
)"
然后:清理工作树(步骤 5)
选项 3: 保持原样
报告:“保留分支 <name>。工作树保存在 <path>。”
不要清理工作树。
选项 4: 丢弃
首先确认:
这将永久删除:
- 分支 <name>
- 所有提交:<commit-list>
- 工作树在 <path>
输入 'discard' 来确认。
等待确切的确认。
如果确认:
git checkout <base-branch>
git branch -D <feature-branch>
然后:清理工作树(步骤 5)
步骤 5: 清理工作树
对于选项 1, 2, 4:
检查是否在工作树中:
git worktree list | grep $(git branch --show-current)
如果是:
git worktree remove <worktree-path>
对于选项 3: 保留工作树。
快速参考
| 选项 | 合并 | 推送 | 保持工作树 | 清理分支 |
|---|---|---|---|---|
| 1. 本地合并 | ✓ | - | - | ✓ |
| 2. 创建 PR | - | ✓ | ✓ | - |
| 3. 保持原样 | - | - | ✓ | - |
| 4. 丢弃 | - | - | - | ✓ (强制) |
常见错误
跳过测试验证
- 问题: 合并破损的代码,创建失败的 PR
- 修复: 在提供选项前始终验证测试
开放性问题
- 问题: “接下来应该做什么?” → 模糊
- 修复: 呈现恰好 4 个结构化选项
自动工作树清理
- 问题: 在可能需要时移除工作树(选项 2, 3)
- 修复: 只清理选项 1 和 4
没有丢弃确认
- 问题: 意外删除工作
- 修复: 要求输入 “discard” 确认
红色标志
绝不:
- 在测试失败时继续
- 合并而不验证结果测试
- 删除工作而不确认
- 强制推送而没有明确请求
始终:
- 在提供选项前验证测试
- 呈现恰好 4 个选项
- 获取选项 4 的输入确认
- 只清理工作树对于选项 1 和 4
集成
由以下调用:
- subagent-driven-development(步骤 7)- 在所有任务完成后
- executing-plans(步骤 5)- 在所有批次完成后
与以下配对:
- using-git-worktrees - 清理由该技能创建的工作树