- Implemented `grokkit docs` command for generating language-specific documentation comments (godoc, PEP 257, Doxygen, etc.) with previews, backups, and auto-apply option - Extracted message builder functions for commit, history, pr-describe, and review commands - Added comprehensive unit tests for all command message builders (commit_test.go, docs_test.go, history_test.go, lint_test.go, prdescribe_test.go, review_test.go) - Enforced 70% test coverage threshold in CI workflow - Added .golangci.yml configuration with linters like govet, errcheck, staticcheck - Updated Makefile to include -race in tests and add help target - Updated README.md with new docs command details, workflows, and quality features - Added .claude/ to .gitignore - Configured default model for docs command in config.go
53 lines
1.3 KiB
Go
53 lines
1.3 KiB
Go
package cmd
|
|
|
|
import (
|
|
"strings"
|
|
"testing"
|
|
)
|
|
|
|
func TestBuildCommitMessages(t *testing.T) {
|
|
tests := []struct {
|
|
name string
|
|
diff string
|
|
sysCheck string
|
|
usrCheck []string
|
|
}{
|
|
{
|
|
name: "normal diff",
|
|
diff: "diff --git a/foo.go b/foo.go\n+func bar() {}",
|
|
sysCheck: "conventional commit",
|
|
usrCheck: []string{"diff --git a/foo.go", "Staged changes:"},
|
|
},
|
|
{
|
|
name: "empty diff",
|
|
diff: "",
|
|
sysCheck: "conventional commit",
|
|
usrCheck: []string{"Staged changes:"},
|
|
},
|
|
}
|
|
|
|
for _, tt := range tests {
|
|
t.Run(tt.name, func(t *testing.T) {
|
|
msgs := buildCommitMessages(tt.diff)
|
|
|
|
if len(msgs) != 2 {
|
|
t.Fatalf("expected 2 messages, got %d", len(msgs))
|
|
}
|
|
if msgs[0]["role"] != "system" {
|
|
t.Errorf("first message role = %q, want %q", msgs[0]["role"], "system")
|
|
}
|
|
if msgs[1]["role"] != "user" {
|
|
t.Errorf("second message role = %q, want %q", msgs[1]["role"], "user")
|
|
}
|
|
if !strings.Contains(strings.ToLower(msgs[0]["content"]), strings.ToLower(tt.sysCheck)) {
|
|
t.Errorf("system prompt missing %q; got: %s", tt.sysCheck, msgs[0]["content"])
|
|
}
|
|
for _, check := range tt.usrCheck {
|
|
if !strings.Contains(msgs[1]["content"], check) {
|
|
t.Errorf("user prompt missing %q", check)
|
|
}
|
|
}
|
|
})
|
|
}
|
|
}
|