aboutsummaryrefslogtreecommitdiff
path: root/tests/test-chime-day-wide-time-matching.el
diff options
context:
space:
mode:
authorCraig Jennings <c@cjennings.net>2026-04-04 12:40:27 -0500
committerCraig Jennings <c@cjennings.net>2026-04-04 12:40:27 -0500
commit69c8deb2d7821c78475dcbb08458df6b0e56d559 (patch)
treea55c1d8b3fc723fc25bf5ca47f668902a47bf4ed /tests/test-chime-day-wide-time-matching.el
parentfe5a31072bfa2f6451769008a63ad5b0d9a3de17 (diff)
downloadchime-69c8deb2d7821c78475dcbb08458df6b0e56d559.tar.gz
chime-69c8deb2d7821c78475dcbb08458df6b0e56d559.zip
Add 94 tests across 10 new test files and fix 2 bugs
New test coverage for previously untested functions: - filter-day-wide-events, time utilities, day-wide time matching - make-tooltip, event-is-today, get-tags, done-keywords-predicate - extract-title, propertize-modeline-string, warn-persistent-failures - log-silently Bug fixes discovered by new tests: - Fix pluralization in no-events tooltip ("1 hours" -> "1 hour", etc.) - Fix chime--get-tags returning ("") instead of nil for untagged headings
Diffstat (limited to 'tests/test-chime-day-wide-time-matching.el')
-rw-r--r--tests/test-chime-day-wide-time-matching.el150
1 files changed, 150 insertions, 0 deletions
diff --git a/tests/test-chime-day-wide-time-matching.el b/tests/test-chime-day-wide-time-matching.el
new file mode 100644
index 0000000..0e92093
--- /dev/null
+++ b/tests/test-chime-day-wide-time-matching.el
@@ -0,0 +1,150 @@
+;;; test-chime-day-wide-time-matching.el --- Tests for day-wide time matching -*- lexical-binding: t; -*-
+
+;; Copyright (C) 2024-2026 Craig Jennings
+
+;; Author: Craig Jennings <c@cjennings.net>
+
+;; This program is free software: you can redistribute it and/or modify
+;; it under the terms of the GNU General Public License as published by
+;; the Free Software Foundation, either version 3 of the License, or
+;; (at your option) any later version.
+
+;; This program is distributed in the hope that it will be useful,
+;; but WITHOUT ANY WARRANTY; without even the implied warranty of
+;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+;; GNU General Public License for more details.
+
+;; You should have received a copy of the GNU General Public License
+;; along with this program. If not, see <http://www.gnu.org/licenses/>.
+
+;;; Commentary:
+
+;; Unit tests for day-wide time matching functions:
+;; - chime-current-time-matches-time-of-day-string
+;; - chime-current-time-is-day-wide-time
+;;
+;; These functions determine when to fire notifications for all-day events
+;; by comparing the current time to configured alert times like "08:00".
+;;
+;; IMPORTANT: Mock times must be computed BEFORE entering with-test-time,
+;; because test-time-today-at calls current-time internally.
+
+;;; Code:
+
+;; Initialize package system for batch mode
+(when noninteractive
+ (package-initialize))
+
+(require 'ert)
+
+;; Load dependencies required by chime
+(require 'dash)
+(require 'alert)
+(require 'async)
+(require 'org-agenda)
+
+;; Load chime from parent directory
+(load (expand-file-name "../chime.el") nil t)
+
+;; Load test utilities
+(require 'testutil-general (expand-file-name "testutil-general.el"))
+(require 'testutil-time (expand-file-name "testutil-time.el"))
+
+;;;; Tests for chime-current-time-matches-time-of-day-string
+
+;;; Normal Cases
+
+(ert-deftest test-chime-time-matches-string-exact-match ()
+ "Should return truthy when current time matches the time-of-day string."
+ (let ((mock-time (test-time-today-at 8 0)))
+ (with-test-time mock-time
+ (should (chime-current-time-matches-time-of-day-string "8:00")))))
+
+(ert-deftest test-chime-time-matches-string-no-match ()
+ "Should return nil when current time does not match."
+ (let ((mock-time (test-time-today-at 9 0)))
+ (with-test-time mock-time
+ (should-not (chime-current-time-matches-time-of-day-string "8:00")))))
+
+(ert-deftest test-chime-time-matches-string-afternoon ()
+ "Should match afternoon times correctly."
+ (let ((mock-time (test-time-today-at 17 0)))
+ (with-test-time mock-time
+ (should (chime-current-time-matches-time-of-day-string "17:00")))))
+
+;;; Boundary Cases
+
+(ert-deftest test-chime-time-matches-string-midnight ()
+ "Should match midnight (00:00)."
+ (let ((mock-time (test-time-today-at 0 0)))
+ (with-test-time mock-time
+ (should (chime-current-time-matches-time-of-day-string "0:00")))))
+
+(ert-deftest test-chime-time-matches-string-end-of-day ()
+ "Should match 23:59."
+ (let ((mock-time (test-time-today-at 23 59)))
+ (with-test-time mock-time
+ (should (chime-current-time-matches-time-of-day-string "23:59")))))
+
+(ert-deftest test-chime-time-matches-string-off-by-one-minute ()
+ "One minute off should not match."
+ (let ((mock-time (test-time-today-at 8 1)))
+ (with-test-time mock-time
+ (should-not (chime-current-time-matches-time-of-day-string "8:00")))))
+
+(ert-deftest test-chime-time-matches-string-leading-zero ()
+ "Should match with leading zero in time string (08:00)."
+ (let ((mock-time (test-time-today-at 8 0)))
+ (with-test-time mock-time
+ (should (chime-current-time-matches-time-of-day-string "08:00")))))
+
+;;;; Tests for chime-current-time-is-day-wide-time
+
+;;; Normal Cases
+
+(ert-deftest test-chime-is-day-wide-time-matches-single-entry ()
+ "Should return truthy when current time matches the configured alert time."
+ (let ((mock-time (test-time-today-at 8 0)))
+ (with-test-time mock-time
+ (let ((chime-day-wide-alert-times '("08:00")))
+ (should (chime-current-time-is-day-wide-time))))))
+
+(ert-deftest test-chime-is-day-wide-time-matches-second-entry ()
+ "Should return truthy when current time matches any entry, not just first."
+ (let ((mock-time (test-time-today-at 17 0)))
+ (with-test-time mock-time
+ (let ((chime-day-wide-alert-times '("08:00" "17:00")))
+ (should (chime-current-time-is-day-wide-time))))))
+
+(ert-deftest test-chime-is-day-wide-time-no-match ()
+ "Should return nil when current time matches no configured alert times."
+ (let ((mock-time (test-time-today-at 12 0)))
+ (with-test-time mock-time
+ (let ((chime-day-wide-alert-times '("08:00" "17:00")))
+ (should-not (chime-current-time-is-day-wide-time))))))
+
+;;; Boundary Cases
+
+(ert-deftest test-chime-is-day-wide-time-empty-list ()
+ "Should return nil when alert times list is empty."
+ (let ((mock-time (test-time-today-at 8 0)))
+ (with-test-time mock-time
+ (let ((chime-day-wide-alert-times '()))
+ (should-not (chime-current-time-is-day-wide-time))))))
+
+(ert-deftest test-chime-is-day-wide-time-nil-list ()
+ "Should return nil when alert times list is nil."
+ (let ((mock-time (test-time-today-at 8 0)))
+ (with-test-time mock-time
+ (let ((chime-day-wide-alert-times nil))
+ (should-not (chime-current-time-is-day-wide-time))))))
+
+(ert-deftest test-chime-is-day-wide-time-matches-first-of-many ()
+ "Should return truthy when matching the first of several alert times."
+ (let ((mock-time (test-time-today-at 8 0)))
+ (with-test-time mock-time
+ (let ((chime-day-wide-alert-times '("08:00" "12:00" "17:00")))
+ (should (chime-current-time-is-day-wide-time))))))
+
+(provide 'test-chime-day-wide-time-matching)
+;;; test-chime-day-wide-time-matching.el ends here