test(sync): add unit tests for gitHasUncommittedBeadsChanges (bd-p7i2)
Extract parseGitStatusForBeadsChanges helper function from gitHasUncommittedBeadsChanges to enable unit testing without git setup. Add 14 test cases covering: - Empty/no changes - Modified files (staged, unstaged, both) - Added files (staged, with modifications) - Untracked files (should return false) - Deleted files (should return false) - Renamed/copied files - Edge cases (short status line) Part of GH#885 follow-up. 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
This commit is contained in:
100
cmd/bd/sync_git_test.go
Normal file
100
cmd/bd/sync_git_test.go
Normal file
@@ -0,0 +1,100 @@
|
||||
package main
|
||||
|
||||
import (
|
||||
"testing"
|
||||
)
|
||||
|
||||
func TestParseGitStatusForBeadsChanges(t *testing.T) {
|
||||
tests := []struct {
|
||||
name string
|
||||
status string
|
||||
expected bool
|
||||
}{
|
||||
// No changes
|
||||
{
|
||||
name: "empty status",
|
||||
status: "",
|
||||
expected: false,
|
||||
},
|
||||
{
|
||||
name: "whitespace only",
|
||||
status: " \n",
|
||||
expected: false,
|
||||
},
|
||||
|
||||
// Modified (should return true)
|
||||
{
|
||||
name: "staged modified",
|
||||
status: "M .beads/issues.jsonl",
|
||||
expected: true,
|
||||
},
|
||||
{
|
||||
name: "unstaged modified",
|
||||
status: " M .beads/issues.jsonl",
|
||||
expected: true,
|
||||
},
|
||||
{
|
||||
name: "staged and unstaged modified",
|
||||
status: "MM .beads/issues.jsonl",
|
||||
expected: true,
|
||||
},
|
||||
|
||||
// Added (should return true)
|
||||
{
|
||||
name: "staged added",
|
||||
status: "A .beads/issues.jsonl",
|
||||
expected: true,
|
||||
},
|
||||
{
|
||||
name: "added then modified",
|
||||
status: "AM .beads/issues.jsonl",
|
||||
expected: true,
|
||||
},
|
||||
|
||||
// Untracked (should return false)
|
||||
{
|
||||
name: "untracked file",
|
||||
status: "?? .beads/issues.jsonl",
|
||||
expected: false,
|
||||
},
|
||||
|
||||
// Deleted (should return false)
|
||||
{
|
||||
name: "staged deleted",
|
||||
status: "D .beads/issues.jsonl",
|
||||
expected: false,
|
||||
},
|
||||
{
|
||||
name: "unstaged deleted",
|
||||
status: " D .beads/issues.jsonl",
|
||||
expected: false,
|
||||
},
|
||||
|
||||
// Edge cases
|
||||
{
|
||||
name: "renamed file",
|
||||
status: "R old.jsonl -> .beads/issues.jsonl",
|
||||
expected: false,
|
||||
},
|
||||
{
|
||||
name: "copied file",
|
||||
status: "C source.jsonl -> .beads/issues.jsonl",
|
||||
expected: false,
|
||||
},
|
||||
{
|
||||
name: "status too short",
|
||||
status: "M",
|
||||
expected: false,
|
||||
},
|
||||
}
|
||||
|
||||
for _, tt := range tests {
|
||||
t.Run(tt.name, func(t *testing.T) {
|
||||
result := parseGitStatusForBeadsChanges(tt.status)
|
||||
if result != tt.expected {
|
||||
t.Errorf("parseGitStatusForBeadsChanges(%q) = %v, want %v",
|
||||
tt.status, result, tt.expected)
|
||||
}
|
||||
})
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user