blob: c840ac28dcba9812309085dc3cecd1562826d879 (
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
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
|
;;; test-wttrin--get-cache-entries-by-age.el --- Tests for cache entry sorting -*- lexical-binding: t; -*-
;; Copyright (C) 2024 Craig Jennings
;;; Commentary:
;; Tests for wttrin--get-cache-entries-by-age helper function.
;; This function extracts cache entries sorted by age (oldest first).
;;; Code:
(require 'ert)
(require 'wttrin)
;;; Normal Cases
(ert-deftest test-wttrin--get-cache-entries-by-age-empty-cache ()
"Should return empty list when cache is empty."
(let ((wttrin--cache (make-hash-table :test 'equal)))
(should (equal '() (wttrin--get-cache-entries-by-age)))))
(ert-deftest test-wttrin--get-cache-entries-by-age-single-entry ()
"Should return single entry in list."
(let ((wttrin--cache (make-hash-table :test 'equal)))
(puthash "Paris|m" (cons 1000.0 "weather data") wttrin--cache)
(let ((result (wttrin--get-cache-entries-by-age)))
(should (= 1 (length result)))
(should (equal "Paris|m" (car (car result))))
(should (= 1000.0 (cdr (car result)))))))
(ert-deftest test-wttrin--get-cache-entries-by-age-sorted-oldest-first ()
"Should return entries sorted by timestamp, oldest first."
(let ((wttrin--cache (make-hash-table :test 'equal)))
;; Add entries with different timestamps (not in sorted order)
(puthash "New York|u" (cons 3000.0 "newest data") wttrin--cache)
(puthash "Paris|m" (cons 1000.0 "oldest data") wttrin--cache)
(puthash "Tokyo|m" (cons 2000.0 "middle data") wttrin--cache)
(let ((result (wttrin--get-cache-entries-by-age)))
(should (= 3 (length result)))
;; Check order: oldest to newest
(should (equal "Paris|m" (car (nth 0 result))))
(should (= 1000.0 (cdr (nth 0 result))))
(should (equal "Tokyo|m" (car (nth 1 result))))
(should (= 2000.0 (cdr (nth 1 result))))
(should (equal "New York|u" (car (nth 2 result))))
(should (= 3000.0 (cdr (nth 2 result)))))))
(ert-deftest test-wttrin--get-cache-entries-by-age-returns-key-timestamp-pairs ()
"Should return (key . timestamp) pairs, not full cache values."
(let ((wttrin--cache (make-hash-table :test 'equal)))
;; Cache value is (timestamp . data)
(puthash "London|m" (cons 1500.0 "complete weather string with lots of data") wttrin--cache)
(let ((result (wttrin--get-cache-entries-by-age)))
(should (= 1 (length result)))
(let ((entry (car result)))
;; Entry should be (key . timestamp), not (key . (timestamp . data))
(should (equal "London|m" (car entry)))
(should (= 1500.0 (cdr entry)))
;; Should NOT contain the weather data string
(should-not (stringp (cdr entry)))))))
;;; Boundary Cases
(ert-deftest test-wttrin--get-cache-entries-by-age-same-timestamp ()
"Should handle entries with identical timestamps."
(let ((wttrin--cache (make-hash-table :test 'equal)))
(puthash "Location1|m" (cons 1000.0 "data1") wttrin--cache)
(puthash "Location2|m" (cons 1000.0 "data2") wttrin--cache)
(puthash "Location3|m" (cons 1000.0 "data3") wttrin--cache)
(let ((result (wttrin--get-cache-entries-by-age)))
(should (= 3 (length result)))
;; All should have same timestamp
(should (= 1000.0 (cdr (nth 0 result))))
(should (= 1000.0 (cdr (nth 1 result))))
(should (= 1000.0 (cdr (nth 2 result)))))))
(ert-deftest test-wttrin--get-cache-entries-by-age-float-timestamps ()
"Should correctly sort float timestamps with fractional seconds."
(let ((wttrin--cache (make-hash-table :test 'equal)))
(puthash "A|m" (cons 1000.123 "data") wttrin--cache)
(puthash "B|m" (cons 1000.789 "data") wttrin--cache)
(puthash "C|m" (cons 1000.456 "data") wttrin--cache)
(let ((result (wttrin--get-cache-entries-by-age)))
;; Should be sorted: 1000.123 < 1000.456 < 1000.789
(should (equal "A|m" (car (nth 0 result))))
(should (equal "C|m" (car (nth 1 result))))
(should (equal "B|m" (car (nth 2 result)))))))
(ert-deftest test-wttrin--get-cache-entries-by-age-many-entries ()
"Should handle cache at max capacity (50 entries)."
(let ((wttrin--cache (make-hash-table :test 'equal)))
;; Add 50 entries with timestamps 1000, 1001, 1002, ..., 1049
(dotimes (i 50)
(puthash (format "Location%d|m" i)
(cons (+ 1000.0 i) "data")
wttrin--cache))
(let ((result (wttrin--get-cache-entries-by-age)))
(should (= 50 (length result)))
;; First should be oldest (1000.0)
(should (= 1000.0 (cdr (car result))))
;; Last should be newest (1049.0)
(should (= 1049.0 (cdr (car (last result))))))))
;;; Error Cases
(ert-deftest test-wttrin--get-cache-entries-by-age-preserves-original-cache ()
"Should not modify the original cache hash table."
(let ((wttrin--cache (make-hash-table :test 'equal)))
(puthash "Paris|m" (cons 1000.0 "data") wttrin--cache)
(puthash "Tokyo|m" (cons 2000.0 "data") wttrin--cache)
(let ((original-count (hash-table-count wttrin--cache)))
(wttrin--get-cache-entries-by-age)
;; Cache should still have same number of entries
(should (= original-count (hash-table-count wttrin--cache)))
;; Original entries should still be present
(should (gethash "Paris|m" wttrin--cache))
(should (gethash "Tokyo|m" wttrin--cache)))))
(provide 'test-wttrin--get-cache-entries-by-age)
;;; test-wttrin--get-cache-entries-by-age.el ends here
|