blob: 04d1a4d0dc2035c11ae3ee90e5a836c296334d40 (
about) (
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
|
;;; mumi -- Mediocre, uh, mail interface
;;; Copyright © 2020 Ricardo Wurmus <rekado@elephly.net>
;;;
;;; This program is free software: you can redistribute it and/or
;;; modify it under the terms of the GNU Affero 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
;;; Affero General Public License for more details.
;;;
;;; You should have received a copy of the GNU Affero General Public
;;; License along with this program. If not, see
;;; <http://www.gnu.org/licenses/>.
(define-module (test-xapian)
#:use-module (mumi xapian)
#:use-module (srfi srfi-19)
#:use-module (srfi srfi-64))
(define-syntax-rule (mock (module proc replacement) body ...)
"Within BODY, replace the definition of PROC from MODULE with the definition
given by REPLACEMENT."
(let* ((m (resolve-module 'module))
(original (module-ref m 'proc)))
(dynamic-wind
(lambda () (module-set! m 'proc replacement))
(lambda () body ...)
(lambda () (module-set! m 'proc original)))))
(test-begin "xapian")
(define (time->datestamp time)
(date->string (time-utc->date time) "~Y~m~d"))
(define sanitize
(@@ (mumi xapian) sanitize-date-range))
(test-equal "sanitize-date-range: turns \"today\" into datestamp"
(sanitize "date:today..today")
(let ((today (time->datestamp (current-time))))
(format #f "date:~a..~a" today today)))
(test-equal "sanitize-date-range: turns \"now\" into datestamp"
(sanitize "date:today..now")
(let ((today (time->datestamp (current-time))))
(format #f "date:~a..~a" today today)))
(test-equal "sanitize-date-range: turns \"yesterday\" into datestamp"
(sanitize "date:yesterday..today")
(let* ((today (current-time))
(yesterday (subtract-duration today (make-time time-duration 0 (* 60 60 24)))))
(format #f "date:~a..~a"
(time->datestamp yesterday)
(time->datestamp today))))
(test-equal "sanitize-date-range: pads short dates"
(sanitize "date:20..19")
"date:20000000..19000000")
(test-equal "sanitize-date-range: turns 1m into datestamp one month ago"
(sanitize "date:1m..now")
(let* ((today (current-time))
(1m (subtract-duration today (make-time time-duration 0 (* 60 60 24 30)))))
(format #f "date:~a..~a"
(time->datestamp 1m)
(time->datestamp today))))
(define tokenize
(@@ (mumi xapian) tokenize))
(test-equal "tokenize: keeps phrases intact 1"
(tokenize "subject:\"hello world\" how are you")
'("subject:\"hello world\"" "how" "are" "you"))
(test-equal "tokenize: keeps phrases intact 2"
(tokenize "subject:\"hello world\" how \"are\" you")
'("subject:\"hello world\"" "how" "\"are\"" "you"))
(test-end "xapian")
|