summaryrefslogtreecommitdiff
path: root/internal/task/task_test.go
diff options
context:
space:
mode:
authorPaul Bütow <1224732+snonux@users.noreply.github.com>2025-06-19 23:43:20 +0300
committerPaul Bütow <1224732+snonux@users.noreply.github.com>2025-06-19 23:43:20 +0300
commitdee37364c1c690207cb12c399f65e2b53537b5a1 (patch)
treeb216ff2bc2cb5fdebbf0987ef5dfedef614eb2d1 /internal/task/task_test.go
parent2235c13109b15f81a0c9635ae9133aaecb3d072a (diff)
Add Taskwarrior CLI tests
Diffstat (limited to 'internal/task/task_test.go')
-rw-r--r--internal/task/task_test.go56
1 files changed, 56 insertions, 0 deletions
diff --git a/internal/task/task_test.go b/internal/task/task_test.go
new file mode 100644
index 0000000..8940bfe
--- /dev/null
+++ b/internal/task/task_test.go
@@ -0,0 +1,56 @@
+package task
+
+import (
+ "os"
+ "testing"
+)
+
+func TestAddAndExport(t *testing.T) {
+ tmp := t.TempDir()
+ if err := os.Setenv("TASKDATA", tmp); err != nil {
+ t.Fatal(err)
+ }
+ if err := os.Setenv("TASKRC", "/dev/null"); err != nil {
+ t.Fatal(err)
+ }
+ t.Cleanup(func() {
+ os.Unsetenv("TASKDATA")
+ os.Unsetenv("TASKRC")
+ })
+
+ if err := Add("hello world", []string{"tag", "anothertag", "tasksamuraitesting"}); err != nil {
+ t.Fatalf("add task 1: %v", err)
+ }
+ if err := Add("hello universe", []string{"foo", "tasksamuraitesting"}); err != nil {
+ t.Fatalf("add task 2: %v", err)
+ }
+
+ tasks, err := Export()
+ if err != nil {
+ t.Fatalf("export: %v", err)
+ }
+
+ found := make(map[string]bool)
+ for _, task := range tasks {
+ hasTag := false
+ for _, tag := range task.Tags {
+ if tag == "tasksamuraitesting" {
+ hasTag = true
+ break
+ }
+ }
+ if hasTag {
+ found[task.Description] = true
+ }
+ }
+
+ if len(found) != 2 {
+ t.Fatalf("expected 2 tasks with tag, got %d", len(found))
+ }
+ if !found["hello world"] {
+ t.Errorf("missing task 'hello world'")
+ }
+ if !found["hello universe"] {
+ t.Errorf("missing task 'hello universe'")
+ }
+}