diff options
| author | Paul Bütow <1224732+snonux@users.noreply.github.com> | 2025-06-21 23:51:57 +0300 |
|---|---|---|
| committer | Paul Bütow <1224732+snonux@users.noreply.github.com> | 2025-06-21 23:51:57 +0300 |
| commit | c1585e94cf4a0eeb8ebd49103291119b97e097a8 (patch) | |
| tree | 224f417c19f324674f5a240dc98583725061049a /internal/ui/table_test.go | |
| parent | c5d91ea346ac91e58ba8f2b40e6289cc926fb257 (diff) | |
Swap recurrence and random due date hotkeys
Diffstat (limited to 'internal/ui/table_test.go')
| -rw-r--r-- | internal/ui/table_test.go | 57 |
1 files changed, 56 insertions, 1 deletions
diff --git a/internal/ui/table_test.go b/internal/ui/table_test.go index 18a471b..4e2679d 100644 --- a/internal/ui/table_test.go +++ b/internal/ui/table_test.go @@ -289,6 +289,61 @@ func TestDueDateHotkey(t *testing.T) { } } +func TestRandomDueDateHotkey(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(nil) + if err != nil { + t.Fatalf("New: %v", err) + } + + mv, _ := m.Update(tea.KeyMsg{Type: tea.KeyRunes, Runes: []rune{'r'}}) + m = mv.(Model) + + data, err := os.ReadFile(dueFile) + if err != nil { + t.Fatalf("read due: %v", err) + } + + parts := strings.Split(strings.TrimSpace(string(data)), " ") + if len(parts) != 3 { + t.Fatalf("unexpected command: %q", data) + } + dueStr := strings.TrimPrefix(parts[2], "due:") + dueTime, err := time.Parse("2006-01-02", dueStr) + if err != nil { + t.Fatalf("parse due: %v", err) + } + days := int(time.Until(dueTime).Hours() / 24) + if days < 7 || days > 37 { + t.Fatalf("due date out of range: %d", days) + } +} + func TestRecurrenceHotkey(t *testing.T) { tmp := t.TempDir() taskPath := filepath.Join(tmp, "task") @@ -321,7 +376,7 @@ func TestRecurrenceHotkey(t *testing.T) { t.Fatalf("New: %v", err) } - mv, _ := m.Update(tea.KeyMsg{Type: tea.KeyRunes, Runes: []rune{'r'}}) + mv, _ := m.Update(tea.KeyMsg{Type: tea.KeyRunes, Runes: []rune{'R'}}) m = mv.(Model) for _, r := range "daily" { mv, _ = m.Update(tea.KeyMsg{Type: tea.KeyRunes, Runes: []rune{r}}) |
