diff options
| author | Claudomator Agent <agent@claudomator> | 2026-03-16 20:33:25 +0000 |
|---|---|---|
| committer | Claudomator Agent <agent@claudomator> | 2026-03-16 20:33:25 +0000 |
| commit | 072652f617653dce74368cedb42b88189e5014fb (patch) | |
| tree | 2e3b9ac16b0d8d76dbda8b14d8a7ed9846f7bc2b /internal/storage/db_test.go | |
| parent | 1b2deb13daa788dc43d98caeaa9507254b1ca283 (diff) | |
feat: add project column to storage
Adds project TEXT column to tasks table via additive migration, updates
CreateTask INSERT, all SELECT queries, and scanTask to persist and
retrieve Task.Project.
Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
Diffstat (limited to 'internal/storage/db_test.go')
| -rw-r--r-- | internal/storage/db_test.go | 30 |
1 files changed, 30 insertions, 0 deletions
diff --git a/internal/storage/db_test.go b/internal/storage/db_test.go index 752c5b1..9b89e89 100644 --- a/internal/storage/db_test.go +++ b/internal/storage/db_test.go @@ -990,6 +990,36 @@ func TestAppendTaskInteraction_NotFound(t *testing.T) { } } +func TestCreateTask_Project_RoundTrip(t *testing.T) { + db := testDB(t) + now := time.Now().UTC().Truncate(time.Second) + + tk := &task.Task{ + ID: "proj-1", + Name: "Project Task", + Project: "my-project", + Agent: task.AgentConfig{Type: "claude", Instructions: "do it"}, + Priority: task.PriorityNormal, + Tags: []string{}, + DependsOn: []string{}, + Retry: task.RetryConfig{MaxAttempts: 1, Backoff: "linear"}, + State: task.StatePending, + CreatedAt: now, + UpdatedAt: now, + } + if err := db.CreateTask(tk); err != nil { + t.Fatalf("creating task: %v", err) + } + + got, err := db.GetTask("proj-1") + if err != nil { + t.Fatalf("getting task: %v", err) + } + if got.Project != "my-project" { + t.Errorf("project: want %q, got %q", "my-project", got.Project) + } +} + func TestExecution_StoreAndRetrieveChangestats(t *testing.T) { db := testDB(t) now := time.Now().UTC().Truncate(time.Second) |
