FinishingaDevelopmentBranch finishing-a-development-branch

用于指导完成开发工作,通过呈现清晰的选项和处理所选工作流程,确保代码质量并高效地集成开发成果。

DevOps 0 次安装 0 次浏览 更新于 3/4/2026

完成开发分支

概览

通过呈现清晰的选项和处理所选工作流程来指导完成开发工作。

核心原则: 验证测试 → 呈现选项 → 执行选择 → 清理。

开始时宣布: “我正在使用完成开发分支的技能来完成这项工作。”

流程

第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 "<标题>" --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 - 由该技能创建的工作树进行清理