diff options
Diffstat (limited to 'internal/askcli/command_info_add_test.go')
| -rw-r--r-- | internal/askcli/command_info_add_test.go | 56 |
1 files changed, 52 insertions, 4 deletions
diff --git a/internal/askcli/command_info_add_test.go b/internal/askcli/command_info_add_test.go index 3dc83ed..74b2380 100644 --- a/internal/askcli/command_info_add_test.go +++ b/internal/askcli/command_info_add_test.go @@ -3,6 +3,7 @@ package askcli import ( "bytes" "context" + "encoding/json" "io" "path/filepath" "strings" @@ -136,6 +137,53 @@ func TestHandleInfo_AliasSelector(t *testing.T) { } } +func TestHandleInfo_JSONIncludesAliasID(t *testing.T) { + dir := t.TempDir() + oldRoot := taskAliasCacheRoot + oldNow := nowTaskAliasCache + taskAliasCacheRoot = func() (string, error) { return filepath.Join(dir, "hexai"), nil } + nowTaskAliasCache = func() time.Time { return time.Date(2026, 3, 26, 12, 0, 0, 0, time.UTC) } + defer func() { + taskAliasCacheRoot = oldRoot + nowTaskAliasCache = oldNow + }() + + writeTaskAliasCacheForTest(t, taskAliasCache{ + NextID: 1, + Entries: []taskAliasCacheEntry{ + {UUID: "test-uuid", Alias: "0", CreatedAt: nowTaskAliasCache()}, + }, + }) + + jsonData := `[{"uuid":"test-uuid","description":"Test task","status":"pending","priority":"H","tags":["cli"],"urgency":15.0,"depends":[]}]` + d := NewDispatcher(&spyRunner{runFn: func(ctx context.Context, args []string, stdin io.Reader, stdout, stderr io.Writer) (int, error) { + if len(args) > 0 && strings.HasPrefix(args[0], "uuid:test-uuid") { + _, _ = io.WriteString(stdout, jsonData) + } + return 0, nil + }}) + + var stdout, stderr bytes.Buffer + code, _ := d.Dispatch(context.Background(), []string{"--json", "info", "0"}, nil, &stdout, &stderr) + if code != 0 { + t.Fatalf("info code = %d, want 0", code) + } + + var parsed []map[string]any + if err := json.Unmarshal(bytes.TrimSpace(stdout.Bytes()), &parsed); err != nil { + t.Fatalf("failed to parse JSON output: %v", err) + } + if len(parsed) != 1 { + t.Fatalf("parsed len = %d, want 1", len(parsed)) + } + if got := parsed[0]["id"]; got != "0" { + t.Fatalf("json id = %#v, want 0", got) + } + if got := parsed[0]["uuid"]; got != "test-uuid" { + t.Fatalf("json uuid = %#v, want test-uuid", got) + } +} + func TestHandleInfo_NumericID(t *testing.T) { d := NewDispatcher(&spyRunner{runFn: func(ctx context.Context, args []string, stdin io.Reader, stdout, stderr io.Writer) (int, error) { return 0, nil @@ -231,8 +279,8 @@ func TestHandleAdd_Success(t *testing.T) { if code != 0 { t.Fatalf("add code = %d, want 0", code) } - if got := strings.TrimSpace(stdout.String()); got != "1" { - t.Fatalf("stdout = %q, want alias 1", stdout.String()) + if got := strings.TrimSpace(stdout.String()); got != "created task 1" { + t.Fatalf("stdout = %q, want created task 1", stdout.String()) } cache := readTaskAliasCacheSnapshot(t) entry := findTaskAliasEntry(t, cache, "abc-123-def") @@ -406,8 +454,8 @@ func TestHandleAdd_WithDependencies(t *testing.T) { if code != 0 { t.Fatalf("add code = %d, want 0: stderr=%s", code, stderr.String()) } - if got := strings.TrimSpace(stdout.String()); got != "2" { - t.Fatalf("stdout = %q, want alias 2", stdout.String()) + if got := strings.TrimSpace(stdout.String()); got != "created task 2" { + t.Fatalf("stdout = %q, want created task 2", stdout.String()) } if len(capturedAddArgs) < 6 { t.Fatalf("capturedAddArgs = %v, want add invocation with dependency modifier", capturedAddArgs) |
