diff options
| author | Paul Bütow <1224732+snonux@users.noreply.github.com> | 2025-06-20 20:52:35 +0300 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2025-06-20 20:52:35 +0300 |
| commit | 2f77a810ab95f32316979b32405cb7f9d28fdd59 (patch) | |
| tree | c64e08fe7ad7848c9279330cf9cb85b343ecf9ab /internal/ui/table_test.go | |
| parent | 724ace9c282440bc258f93cf70fadbd5da216e00 (diff) | |
| parent | cc23fc723cdc7306b03539422b685c71da5b2fd9 (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.go | 53 |
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) + } +} |
