summaryrefslogtreecommitdiff
path: root/internal/handlers/timeline_logic_test.go
diff options
context:
space:
mode:
authorPeter Stone <thepeterstone@gmail.com>2026-03-23 00:42:44 +0000
committerPeter Stone <thepeterstone@gmail.com>2026-03-23 00:42:44 +0000
commit6c767194d9470b368f8d337e0719795f235f683c (patch)
tree9ffbef1dfa45add88a821877a2e6c8ceb94f52f8 /internal/handlers/timeline_logic_test.go
parent8abc63efdbc0bb96cd6c9aa99d6e9166e0bcabae (diff)
fix: parse Todoist local datetimes, show near-future tasks, add undated tasks to timeline
- parseDueDate: handle date field containing "YYYY-MM-DDTHH:MM:SS" (local time, no tz offset) — Todoist REST API v1 uses this format for recurring tasks with a set time, causing due dates to silently parse as nil - IsFuture threshold: widen from tomorrow to 7 days out so tasks due this week show in the main tasks section with dates visible (not collapsed) - BuildTimeline: include undated Todoist tasks in the Today section (mirrors existing Google Tasks behavior) - GetUndatedTasks: new store method for tasks with due_date IS NULL Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
Diffstat (limited to 'internal/handlers/timeline_logic_test.go')
-rw-r--r--internal/handlers/timeline_logic_test.go30
1 files changed, 30 insertions, 0 deletions
diff --git a/internal/handlers/timeline_logic_test.go b/internal/handlers/timeline_logic_test.go
index b42ad4c..8104a96 100644
--- a/internal/handlers/timeline_logic_test.go
+++ b/internal/handlers/timeline_logic_test.go
@@ -462,6 +462,36 @@ func TestSaveAndGetCalendarEvents(t *testing.T) {
}
}
+func TestBuildTimeline_IncludesUndatedTodoistTasks(t *testing.T) {
+ s := setupTestStore(t)
+
+ // Save a task with no due date
+ _ = s.SaveTasks([]models.Task{
+ {ID: "undated1", Content: "Take out recycling"}, // DueDate is nil
+ })
+
+ start := time.Date(2023, 1, 1, 0, 0, 0, 0, time.UTC)
+ end := time.Date(2023, 1, 2, 0, 0, 0, 0, time.UTC)
+
+ items, err := BuildTimeline(context.Background(), s, nil, start, end)
+ if err != nil {
+ t.Fatalf("BuildTimeline failed: %v", err)
+ }
+
+ found := false
+ for _, item := range items {
+ if item.ID == "undated1" {
+ found = true
+ if item.DaySection != models.DaySectionToday {
+ t.Errorf("Undated task should be in Today section, got %s", item.DaySection)
+ }
+ }
+ }
+ if !found {
+ t.Error("Undated Todoist task should appear in timeline Today section")
+ }
+}
+
func timePtr(t time.Time) *time.Time {
return &t
}