Labsco
obra logo

finishing-a-development-branch

โ˜… 245,900

by obra ยท part of obra/superpowers

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

๐Ÿ”ฅ๐Ÿ”ฅ๐Ÿ”ฅ๐Ÿ”ฅโœ“ VerifiedFreeQuick setup
๐Ÿงฉ One of 7 skills in the obra/superpowers package โ€” works on its own, and pairs well with its siblings.

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

Inspect the full instructions your agent will receiveExpand

This is the exact playbook injected into your agent when the skill activates โ€” shown here so you can audit it before installing. You don't need to read it to use the skill.

by obra

Use when implementation is complete, all tests pass, and you need to decide how to integrate the work - guides completion of development work by presenting structured options for merge, PR, or cleanup npx skills add https://github.com/obra/superpowers --skill finishing-a-development-branch Download ZIPGitHub245.9k

Finishing a Development Branch

Overview

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

Core principle: Verify tests โ†’ Detect environment โ†’ Present options โ†’ Execute choice โ†’ Clean up.

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

The Process

Step 1: Verify Tests

Before presenting options, verify tests pass:

Copy & paste โ€” that's it
# Run project's test suite
npm test / cargo test / pytest / go test ./...

If tests fail:

Copy & paste โ€” that's it
Tests failing ( failures). Must fix before completing:

[Show failures]

Cannot proceed with merge/PR until tests pass.

Stop. Don't proceed to Step 2.

If tests pass: Continue to Step 2.

Step 2: Detect Environment

Determine workspace state before presenting options:

Copy & paste โ€” that's it
GIT_DIR=$(cd "$(git rev-parse --git-dir)" 2>/dev/null && pwd -P)
GIT_COMMON=$(cd "$(git rev-parse --git-common-dir)" 2>/dev/null && pwd -P)

This determines which menu to show and how cleanup works:

State Menu Cleanup GIT_DIR == GIT_COMMON (normal repo) Standard 4 options No worktree to clean up GIT_DIR != GIT_COMMON, named branch Standard 4 options Provenance-based (see Step 6) GIT_DIR != GIT_COMMON, detached HEAD Reduced 3 options (no merge) No cleanup (externally managed)

Step 3: Determine Base Branch

Copy & paste โ€” that's it
# Try common base branches
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 4: Present Options

Normal repo and named-branch worktree โ€” present exactly these 4 options:

Copy & paste โ€” that's it
Implementation complete. What would you like to do?

1. Merge back to 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?

Detached HEAD โ€” present exactly these 3 options:

Copy & paste โ€” that's it
Implementation complete. You're on a detached HEAD (externally managed workspace).

1. Push as new branch and create a Pull Request
2. Keep as-is (I'll handle it later)
3. Discard this work

Which option?

Don't add explanation - keep options concise.

Step 5: Execute Choice

Option 1: Merge Locally

Copy & paste โ€” that's it
# Get main repo root for CWD safety
MAIN_ROOT=$(git -C "$(git rev-parse --git-common-dir)/.." rev-parse --show-toplevel)
cd "$MAIN_ROOT"

# Merge first โ€” verify success before removing anything
git checkout 
git pull
git merge 

# Verify tests on merged result
 

# Only after merge succeeds: cleanup worktree (Step 6), then delete branch

Then: Cleanup worktree (Step 6), then delete branch:

Copy & paste โ€” that's it
git branch -d 

Option 2: Push and Create PR

Copy & paste โ€” that's it
# Push branch
git push -u origin 

Do NOT clean up worktree โ€” user needs it alive to iterate on PR feedback.

Option 3: Keep As-Is

Report: "Keeping branch . Worktree preserved at ."

Don't cleanup worktree.

Option 4: Discard

Confirm first:

Copy & paste โ€” that's it
This will permanently delete:
- Branch 
- All commits: 
- Worktree at 

Type 'discard' to confirm.

Wait for exact confirmation.

If confirmed:

Copy & paste โ€” that's it
MAIN_ROOT=$(git -C "$(git rev-parse --git-common-dir)/.." rev-parse --show-toplevel)
cd "$MAIN_ROOT"

Then: Cleanup worktree (Step 6), then force-delete branch:

Copy & paste โ€” that's it
git branch -D 

Step 6: Cleanup Workspace

Only runs for Options 1 and 4. Options 2 and 3 always preserve the worktree.

Copy & paste โ€” that's it
GIT_DIR=$(cd "$(git rev-parse --git-dir)" 2>/dev/null && pwd -P)
GIT_COMMON=$(cd "$(git rev-parse --git-common-dir)" 2>/dev/null && pwd -P)
WORKTREE_PATH=$(git rev-parse --show-toplevel)

If GIT_DIR == GIT_COMMON: Normal repo, no worktree to clean up. Done.

If worktree path is under .worktrees/ or worktrees/: Superpowers created this worktree โ€” we own cleanup.

Copy & paste โ€” that's it
MAIN_ROOT=$(git -C "$(git rev-parse --git-common-dir)/.." rev-parse --show-toplevel)
cd "$MAIN_ROOT"
git worktree remove "$WORKTREE_PATH"
git worktree prune # Self-healing: clean up any stale registrations

Otherwise: The host environment (harness) owns this workspace. Do NOT remove it. If your platform provides a workspace-exit tool, use it. Otherwise, leave the workspace in place.

Quick Reference

Option Merge Push Keep Worktree Cleanup Branch

  1. Merge locally yes - - yes
  2. Create PR - yes yes -
  3. Keep as-is - - yes -
  4. Discard - - - yes (force)

Red Flags

Never:

  • Proceed with failing tests

  • Merge without verifying tests on result

  • Delete work without confirmation

  • Force-push without explicit request

  • Remove a worktree before confirming merge success

  • Clean up worktrees you didn't create (provenance check)

  • Run git worktree remove from inside the worktree

Always:

  • Verify tests before offering options

  • Detect environment before presenting menu

  • Present exactly 4 options (or 3 for detached HEAD)

  • Get typed confirmation for Option 4

  • Clean up worktree for Options 1 & 4 only

  • cd to main repo root before worktree removal

  • Run git worktree prune after removal