summaryrefslogtreecommitdiff
path: root/tests/xapian.scm
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")