finishing-a-development-branch

star 0

Guides the completion of development work by verifying tests and presenting structured options for merge, PR, or cleanup. Use when implementation is complete and you need to decide how to integrate the work.

Fattastic By Fattastic schedule Updated 3/2/2026

name: finishing-a-development-branch description: Guides the completion of development work by verifying tests and presenting structured options for merge, PR, or cleanup. Use when implementation is complete and you need to decide how to integrate the work.

Finishing a Development Branch

When to use this skill

Guide completion of development work by presenting clear options and handling the chosen workflow.

Core principle: Verify tests → Present options → Execute choice → Clean up.

Announce at start: "I'm using the finishing-a-development-branch skill to complete this work."


How to use it

Step 1: Verify Tests

Run the project's test suite before anything else:

npm test / cargo test / pytest / go test ./...

If tests fail:

Tests failing (<N> failures). Must fix before completing:
[Show failures]
Cannot proceed with merge/PR until tests pass.

Stop. Do not proceed to Step 2.

If tests pass: Continue.


Step 2: Determine Base Branch

git merge-base HEAD main 2>/dev/null || git merge-base HEAD master 2>/dev/null

Or ask: "This branch split from main — is that correct?"


Step 3: Present Options

Present exactly these 4 options:

Implementation complete. What would you like to do?

1. Merge back to <base-branch> locally
2. Push and create a Pull Request
3. Keep the branch as-is (I'll handle it later)
4. Discard this work

Which option?

Don't add explanation — keep options concise.


Step 4: Execute Choice

Option 1 — Merge Locally

git checkout <base-branch>
git pull
git merge <feature-branch>
<test command>          # verify tests on merged result
git branch -d <feature-branch>

Then → Step 5: Cleanup worktree

Option 2 — Push and Create PR

git push -u origin <feature-branch>
gh pr create --title "<title>" --body "$(cat <<'EOF'
## Summary
<2-3 bullets of what changed>

## Test Plan
- [ ] <verification steps>
EOF
)"

Then → Step 5: Cleanup worktree

Option 3 — Keep As-Is

Report: "Keeping branch <name>. Worktree preserved at <path>."

Do not cleanup worktree.

Option 4 — Discard

Confirm first:

This will permanently delete:
- Branch <name>
- All commits: <commit-list>
- Worktree at <path>

Type 'discard' to confirm.

Wait for exact typed confirmation, then:

git checkout <base-branch>
git branch -D <feature-branch>

Then → Step 5: Cleanup worktree


Step 5: Cleanup Worktree

For Options 1, 2, 4 only — check if in a worktree:

git worktree list | grep $(git branch --show-current)

If yes:

git worktree remove <worktree-path>

For Option 3: Keep the worktree.


Quick Reference

Option Merge Push Keep Worktree Delete Branch
1. Merge locally
2. Create PR
3. Keep as-is
4. Discard ✅ (force)

Common Mistakes

❌ Mistake ✅ Fix
Skipping test verification Always verify before offering options
Open-ended "what next?" Present exactly 4 structured options
Auto-cleanup for Option 2 or 3 Only cleanup for Options 1 and 4
No confirmation for discard Require typed 'discard' confirmation

Red Flags

Never:

  • Proceed with failing tests
  • Merge without verifying tests on merged result
  • Delete work without explicit confirmation
  • Force-push without explicit request

Always:

  • Verify tests before offering options
  • Present exactly 4 options
  • Get typed confirmation for Option 4
  • Clean up worktree for Options 1 & 4 only

Integration

Skill Relationship
executing-plans Calls this skill after all batches complete
subagent-driven-development Calls this skill after all tasks complete
using-git-worktrees This skill cleans up the worktree it created
Install via CLI
npx skills add https://github.com/Fattastic/khawi-s-companion --skill finishing-a-development-branch
Repository Details
star Stars 0
call_split Forks 0
navigation Branch main
article Path SKILL.md
More from Creator