- Replace deprecated strings.Title with manual capitalize - Fix race: set codexClient.onMessage before starting reader goroutine - Remove unused msgCh parameter from codexClient.handleLine - Route agent stderr through logger instead of dumping to os.Stderr - Use deterministic agent order in ensurePaired (prefer codex) - Increase message channel buffer from 64 to 256 - Rename test to match function rename (buildPrompt) Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
63 lines
1.5 KiB
Go
63 lines
1.5 KiB
Go
package main
|
|
|
|
import (
|
|
"os"
|
|
"path/filepath"
|
|
"strings"
|
|
"testing"
|
|
)
|
|
|
|
func TestNormalizeServerBaseURL(t *testing.T) {
|
|
t.Parallel()
|
|
|
|
got, err := normalizeServerBaseURL("ws://localhost:8080/ws")
|
|
if err != nil {
|
|
t.Fatalf("normalizeServerBaseURL returned error: %v", err)
|
|
}
|
|
if got != "http://localhost:8080" {
|
|
t.Fatalf("expected http://localhost:8080, got %s", got)
|
|
}
|
|
}
|
|
|
|
func TestResolveTaskWorkdirUsesRepoPathWhenPresent(t *testing.T) {
|
|
t.Parallel()
|
|
|
|
root := t.TempDir()
|
|
repoPath := filepath.Join(root, "repo")
|
|
if err := os.Mkdir(repoPath, 0o755); err != nil {
|
|
t.Fatalf("mkdir repo: %v", err)
|
|
}
|
|
|
|
got, err := resolveTaskWorkdir(root, &daemonRepoRef{Path: "repo"})
|
|
if err != nil {
|
|
t.Fatalf("resolveTaskWorkdir returned error: %v", err)
|
|
}
|
|
if got != repoPath {
|
|
t.Fatalf("expected %s, got %s", repoPath, got)
|
|
}
|
|
}
|
|
|
|
func TestBuildPromptIncludesIssueAndSkills(t *testing.T) {
|
|
t.Parallel()
|
|
|
|
prompt := buildPrompt(daemonTask{
|
|
Context: daemonTaskContext{
|
|
Issue: daemonIssueContext{
|
|
Title: "Fix failing test",
|
|
Description: "Investigate and fix the test failure.",
|
|
AcceptanceCriteria: []string{"tests pass"},
|
|
ContextRefs: []string{"log snippet"},
|
|
},
|
|
Agent: daemonAgentContext{
|
|
Name: "Local Codex",
|
|
Skills: "Be concise.",
|
|
},
|
|
},
|
|
}, "/tmp/work")
|
|
|
|
for _, want := range []string{"Fix failing test", "Investigate and fix the test failure.", "tests pass", "log snippet", "Be concise."} {
|
|
if !strings.Contains(prompt, want) {
|
|
t.Fatalf("prompt missing %q", want)
|
|
}
|
|
}
|
|
}
|