summaryrefslogtreecommitdiff
path: root/internal/ui/table_test.go
diff options
context:
space:
mode:
authorPaul Bütow <1224732+snonux@users.noreply.github.com>2025-06-20 20:52:35 +0300
committerGitHub <noreply@github.com>2025-06-20 20:52:35 +0300
commit2f77a810ab95f32316979b32405cb7f9d28fdd59 (patch)
treec64e08fe7ad7848c9279330cf9cb85b343ecf9ab /internal/ui/table_test.go
parent724ace9c282440bc258f93cf70fadbd5da216e00 (diff)
parentcc23fc723cdc7306b03539422b685c71da5b2fd9 (diff)
Merge pull request #34 from snonux/codex/change-hotkey--d--to--d--and-add-new-hotkey-for-due-date
Add due-date hotkey and update done hotkey
Diffstat (limited to 'internal/ui/table_test.go')
-rw-r--r--internal/ui/table_test.go53
1 files changed, 52 insertions, 1 deletions
diff --git a/internal/ui/table_test.go b/internal/ui/table_test.go
index b7c61d2..061b418 100644
--- a/internal/ui/table_test.go
+++ b/internal/ui/table_test.go
@@ -160,7 +160,7 @@ func TestDoneHotkey(t *testing.T) {
t.Fatalf("New: %v", err)
}
- mv, _ := m.Update(tea.KeyMsg{Type: tea.KeyRunes, Runes: []rune{'d'}})
+ mv, _ := m.Update(tea.KeyMsg{Type: tea.KeyRunes, Runes: []rune{'D'}})
m = mv.(Model)
data, err := os.ReadFile(doneFile)
@@ -172,3 +172,54 @@ func TestDoneHotkey(t *testing.T) {
t.Fatalf("done not called: %q", data)
}
}
+
+func TestDueDateHotkey(t *testing.T) {
+ tmp := t.TempDir()
+ taskPath := filepath.Join(tmp, "task")
+ dueFile := filepath.Join(tmp, "due.txt")
+
+ script := "#!/bin/sh\n" +
+ "if echo \"$@\" | grep -q export; then\n" +
+ " echo '{\"id\":1,\"uuid\":\"x\",\"description\":\"d\",\"status\":\"pending\",\"entry\":\"\",\"priority\":\"\",\"urgency\":0}'\n" +
+ " exit 0\n" +
+ "fi\n" +
+ "echo \"$@\" > " + dueFile + "\n"
+
+ if err := os.WriteFile(taskPath, []byte(script), 0o755); err != nil {
+ t.Fatal(err)
+ }
+
+ origPath := os.Getenv("PATH")
+ os.Setenv("PATH", tmp+":"+origPath)
+ t.Cleanup(func() { os.Setenv("PATH", origPath) })
+
+ os.Setenv("TASKDATA", tmp)
+ os.Setenv("TASKRC", "/dev/null")
+ t.Cleanup(func() {
+ os.Unsetenv("TASKDATA")
+ os.Unsetenv("TASKRC")
+ })
+
+ m, err := New("")
+ if err != nil {
+ t.Fatalf("New: %v", err)
+ }
+
+ mv, _ := m.Update(tea.KeyMsg{Type: tea.KeyRunes, Runes: []rune{'d'}})
+ m = mv.(Model)
+ for _, r := range "2024-12-31" {
+ mv, _ = m.Update(tea.KeyMsg{Type: tea.KeyRunes, Runes: []rune{r}})
+ m = mv.(Model)
+ }
+ mv, _ = m.Update(tea.KeyMsg{Type: tea.KeyEnter})
+ m = mv.(Model)
+
+ data, err := os.ReadFile(dueFile)
+ if err != nil {
+ t.Fatalf("read due: %v", err)
+ }
+
+ if strings.TrimSpace(string(data)) != "1 modify due:2024-12-31" {
+ t.Fatalf("due not set: %q", data)
+ }
+}