mirror of
https://github.com/glittercowboy/get-shit-done
synced 2026-04-25 17:25:23 +02:00
#2388 (plan-phase silently renames feature branch): add explicit Git Branch Invariant section to plan-phase.md prohibiting branch creation/rename/switch during planning; phase slug changes are plan-level only and must not affect the git branch. #2431 (worktree teardown silently swallows errors): replace `git worktree remove --force 2>/dev/null || true` with a lock-aware block in quick.md and execute-phase.md that detects locked worktrees, attempts unlock+retry, and surfaces a user-visible recovery message when removal still fails. #2396 (hardcoded test commands bypass Makefile): add a three-tier test command resolver (project config → Makefile/Justfile → language sniff) in execute-phase.md, verify-phase.md, and audit-fix.md. Makefile with a `test:` target now takes priority over npm/cargo/go. #2376 (OpenCode @$HOME not mapped on Windows): add platform guard in bin/install.js so OpenCode on win32 uses the absolute path instead of `$HOME/...`, which OpenCode does not expand in @file references on Windows. Tests: 29 new assertions across 4 regression test files (all passing). Co-authored-by: Claude Sonnet 4.6 <noreply@anthropic.com>
62 lines
2.2 KiB
JavaScript
62 lines
2.2 KiB
JavaScript
/**
|
|
* Regression test for #2388: plan-phase silently renames feature branch
|
|
* when phase slug has changed since the branch was created.
|
|
*
|
|
* Fix: plan-phase.md must include an explicit instruction not to create,
|
|
* rename, or switch git branches during the planning workflow.
|
|
*/
|
|
|
|
'use strict';
|
|
|
|
const { describe, test } = require('node:test');
|
|
const assert = require('node:assert/strict');
|
|
const fs = require('fs');
|
|
const path = require('path');
|
|
|
|
const PLAN_PHASE_PATH = path.join(__dirname, '..', 'get-shit-done', 'workflows', 'plan-phase.md');
|
|
|
|
describe('bug-2388: plan-phase must not rename or create git branches', () => {
|
|
test('plan-phase.md exists', () => {
|
|
assert.ok(fs.existsSync(PLAN_PHASE_PATH), 'plan-phase.md should exist');
|
|
});
|
|
|
|
test('plan-phase.md contains explicit no-branch-rename instruction', () => {
|
|
const content = fs.readFileSync(PLAN_PHASE_PATH, 'utf-8');
|
|
// Must say "do not" and mention branch in the context of phase slug/rename
|
|
const hasBranchGuard = (
|
|
/do not.{0,80}branch/i.test(content) ||
|
|
/branch.{0,80}do not/i.test(content) ||
|
|
/NEVER.{0,80}branch/i.test(content) ||
|
|
/branch.{0,80}NEVER/i.test(content)
|
|
);
|
|
assert.ok(
|
|
hasBranchGuard,
|
|
'plan-phase.md must include an explicit instruction not to create or rename git branches'
|
|
);
|
|
});
|
|
|
|
test('plan-phase.md mentions phase rename does not affect branch name', () => {
|
|
const content = fs.readFileSync(PLAN_PHASE_PATH, 'utf-8');
|
|
// Should explain that a phase rename in ROADMAP.md is plan-level, not git-level
|
|
const hasPlanLevelExplanation = (
|
|
content.includes('phase rename') ||
|
|
content.includes('phase_slug') ||
|
|
content.includes('branch identity') ||
|
|
content.includes('branch name')
|
|
);
|
|
assert.ok(
|
|
hasPlanLevelExplanation,
|
|
'plan-phase.md should clarify that phase slug changes do not change the git branch'
|
|
);
|
|
});
|
|
|
|
test('plan-phase.md does not contain git checkout -b instruction', () => {
|
|
const content = fs.readFileSync(PLAN_PHASE_PATH, 'utf-8');
|
|
// The workflow should not instruct the LLM to run git checkout -b
|
|
assert.ok(
|
|
!content.includes('git checkout -b'),
|
|
'plan-phase.md must not instruct LLM to create a new branch via git checkout -b'
|
|
);
|
|
});
|
|
});
|