summaryrefslogtreecommitdiff
path: root/tests/test-calendar-sync--event-start-time.el
blob: 1a9a5f7ea526cb3d1ded11386476c391bf54b556 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
;;; test-calendar-sync--event-start-time.el --- Tests for event start time extraction -*- lexical-binding: t; -*-

;;; Commentary:
;; Tests for calendar-sync--event-start-time. Extracts comparable time value from event plist.

;;; Code:

(require 'ert)
(require 'testutil-calendar-sync)
(require 'calendar-sync)

;;; Normal Cases

(ert-deftest test-calendar-sync--event-start-time-normal-timed ()
  "Timed event returns non-zero time value."
  (let ((event (list :start '(2026 3 15 14 30) :summary "Test")))
    (should (not (equal 0 (calendar-sync--event-start-time event))))))

(ert-deftest test-calendar-sync--event-start-time-normal-ordering ()
  "Earlier event has smaller time value than later event."
  (let ((early (list :start '(2026 3 15 9 0)))
        (late (list :start '(2026 3 15 17 0))))
    (should (time-less-p (calendar-sync--event-start-time early)
                         (calendar-sync--event-start-time late)))))

;;; Boundary Cases

(ert-deftest test-calendar-sync--event-start-time-boundary-all-day ()
  "All-day event (nil hour/minute) uses 0 for time components."
  (let ((event (list :start '(2026 3 15 nil nil))))
    (should (not (equal 0 (calendar-sync--event-start-time event))))))

;;; Error Cases

(ert-deftest test-calendar-sync--event-start-time-error-no-start ()
  "Event without :start returns 0."
  (let ((event (list :summary "No start")))
    (should (equal 0 (calendar-sync--event-start-time event)))))

(provide 'test-calendar-sync--event-start-time)
;;; test-calendar-sync--event-start-time.el ends here