Shorter task IDs, cleaner protocol
This commit is contained in:
@@ -12,28 +12,28 @@ func TestTaskPrompts(t *testing.T) {
|
||||
service := taskcp.New("my_service")
|
||||
project := service.AddProject()
|
||||
|
||||
task := project.InsertTaskBefore("", "Write unit tests", "", func(project *taskcp.Project, task *taskcp.Task) error { return nil })
|
||||
task := project.InsertTaskBefore(-1, "Write unit tests", "", func(project *taskcp.Project, task *taskcp.Task) error { return nil })
|
||||
|
||||
successPrompt := task.SuccessPrompt()
|
||||
require.Contains(t, successPrompt, "my_service.set_task_success")
|
||||
require.Contains(t, successPrompt, `project_id="`+project.ID+`"`)
|
||||
require.Contains(t, successPrompt, `task_id="`+task.ID+`"`)
|
||||
require.Contains(t, successPrompt, fmt.Sprintf(`project_id=%d`, project.ID))
|
||||
require.Contains(t, successPrompt, fmt.Sprintf(`task_id=%d`, task.ID))
|
||||
|
||||
failurePrompt := task.FailurePrompt()
|
||||
require.Contains(t, failurePrompt, "my_service.set_task_failure")
|
||||
require.Contains(t, failurePrompt, `project_id="`+project.ID+`"`)
|
||||
require.Contains(t, failurePrompt, `task_id="`+task.ID+`"`)
|
||||
require.Contains(t, failurePrompt, fmt.Sprintf(`project_id=%d`, project.ID))
|
||||
require.Contains(t, failurePrompt, fmt.Sprintf(`task_id=%d`, task.ID))
|
||||
}
|
||||
|
||||
func TestPlaceholderExpansion(t *testing.T) {
|
||||
service := taskcp.New("my_service")
|
||||
project := service.AddProject()
|
||||
|
||||
task1 := project.InsertTaskBefore("", "Please complete this task.", "{SUCCESS_PROMPT}", func(project *taskcp.Project, task *taskcp.Task) error { return nil })
|
||||
task1 := project.InsertTaskBefore(-1, "Please complete this task.", "{SUCCESS_PROMPT}", func(project *taskcp.Project, task *taskcp.Task) error { return nil })
|
||||
require.Contains(t, task1.Instructions, "my_service.set_task_success")
|
||||
require.NotContains(t, task1.Instructions, "{SUCCESS_PROMPT}")
|
||||
|
||||
task2 := project.InsertTaskBefore("", "Try this risky operation.", "{FAILURE_PROMPT}", func(project *taskcp.Project, task *taskcp.Task) error { return nil })
|
||||
task2 := project.InsertTaskBefore(-1, "Try this risky operation.", "{FAILURE_PROMPT}", func(project *taskcp.Project, task *taskcp.Task) error { return nil })
|
||||
require.Contains(t, task2.Instructions, "my_service.set_task_failure")
|
||||
require.NotContains(t, task2.Instructions, "{FAILURE_PROMPT}")
|
||||
}
|
||||
@@ -42,14 +42,14 @@ func TestTaskFlow(t *testing.T) {
|
||||
service := taskcp.New("test_service")
|
||||
project := service.AddProject()
|
||||
|
||||
var completed []string
|
||||
var completed []int
|
||||
|
||||
task1 := project.InsertTaskBefore("", "First task", "", func(project *taskcp.Project, task *taskcp.Task) error {
|
||||
task1 := project.InsertTaskBefore(-1, "First task", "", func(project *taskcp.Project, task *taskcp.Task) error {
|
||||
completed = append(completed, task.ID)
|
||||
return nil
|
||||
})
|
||||
|
||||
task2 := project.InsertTaskBefore("", "Second task", "", func(project *taskcp.Project, task *taskcp.Task) error {
|
||||
task2 := project.InsertTaskBefore(-1, "Second task", "", func(project *taskcp.Project, task *taskcp.Task) error {
|
||||
completed = append(completed, task.ID)
|
||||
return nil
|
||||
})
|
||||
@@ -68,7 +68,7 @@ func TestTaskFlow(t *testing.T) {
|
||||
require.NoError(t, err)
|
||||
require.Nil(t, next2)
|
||||
|
||||
require.Equal(t, []string{task1.ID, task2.ID}, completed)
|
||||
require.Equal(t, []int{task1.ID, task2.ID}, completed)
|
||||
require.Equal(t, taskcp.TaskStateSuccess, project.Tasks[task1.ID].State)
|
||||
require.Equal(t, taskcp.TaskStateFailure, project.Tasks[task2.ID].State)
|
||||
}
|
||||
@@ -79,7 +79,7 @@ func TestCallbackError(t *testing.T) {
|
||||
|
||||
expectedErr := fmt.Errorf("callback error")
|
||||
|
||||
task := project.InsertTaskBefore("", "Task with error callback", "", func(project *taskcp.Project, task *taskcp.Task) error {
|
||||
task := project.InsertTaskBefore(-1, "Task with error callback", "", func(project *taskcp.Project, task *taskcp.Task) error {
|
||||
return expectedErr
|
||||
})
|
||||
|
||||
@@ -87,12 +87,10 @@ func TestCallbackError(t *testing.T) {
|
||||
require.NotNil(t, current)
|
||||
require.Equal(t, task.ID, current.ID)
|
||||
|
||||
// Test error propagation on success
|
||||
_, err := project.SetTaskSuccess(current.ID, "Result", "")
|
||||
require.Error(t, err)
|
||||
require.Equal(t, expectedErr, err)
|
||||
|
||||
// Test error propagation on failure
|
||||
_, err = project.SetTaskFailure(current.ID, "Task failed", "")
|
||||
require.Error(t, err)
|
||||
require.Equal(t, expectedErr, err)
|
||||
|
||||
Reference in New Issue
Block a user