From 7eb6c0692d48b8c3d01efba8abcd2bfdfaa7cd31 Mon Sep 17 00:00:00 2001 From: Craig Jennings Date: Sun, 5 Apr 2026 06:51:20 -0500 Subject: test(calendar-sync): add 68 tests across 13 files for untested pure functions Covers core parsing (parse-ics-datetime, parse-timestamp, format-timestamp, split-events, parse-event), date utilities (add-months, add-days, weekday-to-number, date-weekday, event-start-time), and timezone (format-timezone-offset, convert-utc-to-local, localize-parsed-datetime). --- tests/test-calendar-sync--event-start-time.el | 41 +++++++++++++++++++++++++++ 1 file changed, 41 insertions(+) create mode 100644 tests/test-calendar-sync--event-start-time.el (limited to 'tests/test-calendar-sync--event-start-time.el') diff --git a/tests/test-calendar-sync--event-start-time.el b/tests/test-calendar-sync--event-start-time.el new file mode 100644 index 00000000..1a9a5f7e --- /dev/null +++ b/tests/test-calendar-sync--event-start-time.el @@ -0,0 +1,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 -- cgit v1.2.3