]> code.delx.au - gnu-emacs/blob - test/automated/subr-tests.el
Update copyright year to 2016
[gnu-emacs] / test / automated / subr-tests.el
1 ;;; subr-tests.el --- Tests for subr.el
2
3 ;; Copyright (C) 2015-2016 Free Software Foundation, Inc.
4
5 ;; Author: Oleh Krehel <ohwoeowho@gmail.com>,
6 ;; Nicolas Petton <nicolas@petton.fr>
7 ;; Keywords:
8
9 ;; This file is part of GNU Emacs.
10
11 ;; GNU Emacs is free software: you can redistribute it and/or modify
12 ;; it under the terms of the GNU General Public License as published by
13 ;; the Free Software Foundation, either version 3 of the License, or
14 ;; (at your option) any later version.
15
16 ;; GNU Emacs is distributed in the hope that it will be useful,
17 ;; but WITHOUT ANY WARRANTY; without even the implied warranty of
18 ;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
19 ;; GNU General Public License for more details.
20
21 ;; You should have received a copy of the GNU General Public License
22 ;; along with GNU Emacs. If not, see <http://www.gnu.org/licenses/>.
23
24 ;;; Commentary:
25
26 ;;
27
28 ;;; Code:
29
30 (require 'ert)
31
32 (ert-deftest let-when-compile ()
33 ;; good case
34 (should (equal (macroexpand '(let-when-compile ((foo (+ 2 3)))
35 (setq bar (eval-when-compile (+ foo foo)))
36 (setq boo (eval-when-compile (* foo foo)))))
37 '(progn
38 (setq bar (quote 10))
39 (setq boo (quote 25)))))
40 ;; bad case: `eval-when-compile' omitted, byte compiler should catch this
41 (should (equal (macroexpand
42 '(let-when-compile ((foo (+ 2 3)))
43 (setq bar (+ foo foo))
44 (setq boo (eval-when-compile (* foo foo)))))
45 '(progn
46 (setq bar (+ foo foo))
47 (setq boo (quote 25)))))
48 ;; something practical
49 (should (equal (macroexpand
50 '(let-when-compile ((keywords '("true" "false")))
51 (font-lock-add-keywords
52 'c++-mode
53 `((,(eval-when-compile
54 (format "\\<%s\\>" (regexp-opt keywords)))
55 0 font-lock-keyword-face)))))
56 '(font-lock-add-keywords
57 (quote c++-mode)
58 (list
59 (cons (quote
60 "\\<\\(?:\\(?:fals\\|tru\\)e\\)\\>")
61 (quote
62 (0 font-lock-keyword-face))))))))
63
64 (ert-deftest string-comparison-test ()
65 (should (string-lessp "abc" "acb"))
66 (should (string-lessp "aBc" "abc"))
67 (should (string-lessp "abc" "abcd"))
68 (should (string-lessp "abc" "abcd"))
69 (should-not (string-lessp "abc" "abc"))
70 (should-not (string-lessp "" ""))
71
72 (should (string-greaterp "acb" "abc"))
73 (should (string-greaterp "abc" "aBc"))
74 (should (string-greaterp "abcd" "abc"))
75 (should (string-greaterp "abcd" "abc"))
76 (should-not (string-greaterp "abc" "abc"))
77 (should-not (string-greaterp "" ""))
78
79 ;; Symbols are also accepted
80 (should (string-lessp 'abc 'acb))
81 (should (string-lessp "abc" 'acb))
82 (should (string-greaterp 'acb 'abc))
83 (should (string-greaterp "acb" 'abc)))
84
85 (ert-deftest subr-test-when ()
86 (should (equal (when t 1) 1))
87 (should (equal (when t 2) 2))
88 (should (equal (when nil 1) nil))
89 (should (equal (when nil 2) nil))
90 (should (equal (when t 'x 1) 1))
91 (should (equal (when t 'x 2) 2))
92 (should (equal (when nil 'x 1) nil))
93 (should (equal (when nil 'x 2) nil))
94 (let ((x 1))
95 (should-not (when nil
96 (setq x (1+ x))
97 x))
98 (should (= x 1))
99 (should (= 2 (when t
100 (setq x (1+ x))
101 x)))
102 (should (= x 2)))
103 (should (equal (macroexpand-all '(when a b c d))
104 '(if a (progn b c d)))))
105
106 (ert-deftest subr-test-version-parsing ()
107 (should (equal (version-to-list ".5") '(0 5)))
108 (should (equal (version-to-list "0.9 alpha1") '(0 9 -3 1)))
109 (should (equal (version-to-list "0.9 snapshot") '(0 9 -4)))
110 (should (equal (version-to-list "0.9-alpha1") '(0 9 -3 1)))
111 (should (equal (version-to-list "0.9-snapshot") '(0 9 -4)))
112 (should (equal (version-to-list "0.9.snapshot") '(0 9 -4)))
113 (should (equal (version-to-list "0.9_snapshot") '(0 9 -4)))
114 (should (equal (version-to-list "0.9alpha1") '(0 9 -3 1)))
115 (should (equal (version-to-list "0.9snapshot") '(0 9 -4)))
116 (should (equal (version-to-list "1.0 git") '(1 0 -4)))
117 (should (equal (version-to-list "1.0 pre2") '(1 0 -1 2)))
118 (should (equal (version-to-list "1.0-git") '(1 0 -4)))
119 (should (equal (version-to-list "1.0-pre2") '(1 0 -1 2)))
120 (should (equal (version-to-list "1.0.1-a") '(1 0 1 1)))
121 (should (equal (version-to-list "1.0.1-f") '(1 0 1 6)))
122 (should (equal (version-to-list "1.0.1.a") '(1 0 1 1)))
123 (should (equal (version-to-list "1.0.1.f") '(1 0 1 6)))
124 (should (equal (version-to-list "1.0.1_a") '(1 0 1 1)))
125 (should (equal (version-to-list "1.0.1_f") '(1 0 1 6)))
126 (should (equal (version-to-list "1.0.1a") '(1 0 1 1)))
127 (should (equal (version-to-list "1.0.1f") '(1 0 1 6)))
128 (should (equal (version-to-list "1.0.7.5") '(1 0 7 5)))
129 (should (equal (version-to-list "1.0.git") '(1 0 -4)))
130 (should (equal (version-to-list "1.0.pre2") '(1 0 -1 2)))
131 (should (equal (version-to-list "1.0_git") '(1 0 -4)))
132 (should (equal (version-to-list "1.0_pre2") '(1 0 -1 2)))
133 (should (equal (version-to-list "1.0git") '(1 0 -4)))
134 (should (equal (version-to-list "1.0pre2") '(1 0 -1 2)))
135 (should (equal (version-to-list "22.8 beta3") '(22 8 -2 3)))
136 (should (equal (version-to-list "22.8-beta3") '(22 8 -2 3)))
137 (should (equal (version-to-list "22.8.beta3") '(22 8 -2 3)))
138 (should (equal (version-to-list "22.8_beta3") '(22 8 -2 3)))
139 (should (equal (version-to-list "22.8beta3") '(22 8 -2 3)))
140 (should (equal (version-to-list "6.9.30 Beta") '(6 9 30 -2)))
141 (should (equal (version-to-list "6.9.30-Beta") '(6 9 30 -2)))
142 (should (equal (version-to-list "6.9.30.Beta") '(6 9 30 -2)))
143 (should (equal (version-to-list "6.9.30Beta") '(6 9 30 -2)))
144 (should (equal (version-to-list "6.9.30_Beta") '(6 9 30 -2)))
145
146 (should (equal
147 (error-message-string (should-error (version-to-list "OTP-18.1.5")))
148 "Invalid version syntax: `OTP-18.1.5' (must start with a number)"))
149 (should (equal
150 (error-message-string (should-error (version-to-list "")))
151 "Invalid version syntax: `' (must start with a number)"))
152 (should (equal
153 (error-message-string (should-error (version-to-list "1.0..7.5")))
154 "Invalid version syntax: `1.0..7.5'"))
155 (should (equal
156 (error-message-string (should-error (version-to-list "1.0prepre2")))
157 "Invalid version syntax: `1.0prepre2'"))
158 (should (equal
159 (error-message-string (should-error (version-to-list "22.8X3")))
160 "Invalid version syntax: `22.8X3'"))
161 (should (equal
162 (error-message-string (should-error (version-to-list "beta22.8alpha3")))
163 "Invalid version syntax: `beta22.8alpha3' (must start with a number)"))
164 (should (equal
165 (error-message-string (should-error (version-to-list "honk")))
166 "Invalid version syntax: `honk' (must start with a number)"))
167 (should (equal
168 (error-message-string (should-error (version-to-list 9)))
169 "Version must be a string"))
170
171 (let ((version-separator "_"))
172 (should (equal (version-to-list "_5") '(0 5)))
173 (should (equal (version-to-list "0_9 alpha1") '(0 9 -3 1)))
174 (should (equal (version-to-list "0_9 snapshot") '(0 9 -4)))
175 (should (equal (version-to-list "0_9-alpha1") '(0 9 -3 1)))
176 (should (equal (version-to-list "0_9-snapshot") '(0 9 -4)))
177 (should (equal (version-to-list "0_9.alpha1") '(0 9 -3 1)))
178 (should (equal (version-to-list "0_9.snapshot") '(0 9 -4)))
179 (should (equal (version-to-list "0_9alpha1") '(0 9 -3 1)))
180 (should (equal (version-to-list "0_9snapshot") '(0 9 -4)))
181 (should (equal (version-to-list "1_0 git") '(1 0 -4)))
182 (should (equal (version-to-list "1_0 pre2") '(1 0 -1 2)))
183 (should (equal (version-to-list "1_0-git") '(1 0 -4)))
184 (should (equal (version-to-list "1_0.pre2") '(1 0 -1 2)))
185 (should (equal (version-to-list "1_0_1-a") '(1 0 1 1)))
186 (should (equal (version-to-list "1_0_1-f") '(1 0 1 6)))
187 (should (equal (version-to-list "1_0_1.a") '(1 0 1 1)))
188 (should (equal (version-to-list "1_0_1.f") '(1 0 1 6)))
189 (should (equal (version-to-list "1_0_1_a") '(1 0 1 1)))
190 (should (equal (version-to-list "1_0_1_f") '(1 0 1 6)))
191 (should (equal (version-to-list "1_0_1a") '(1 0 1 1)))
192 (should (equal (version-to-list "1_0_1f") '(1 0 1 6)))
193 (should (equal (version-to-list "1_0_7_5") '(1 0 7 5)))
194 (should (equal (version-to-list "1_0_git") '(1 0 -4)))
195 (should (equal (version-to-list "1_0pre2") '(1 0 -1 2)))
196 (should (equal (version-to-list "22_8 beta3") '(22 8 -2 3)))
197 (should (equal (version-to-list "22_8-beta3") '(22 8 -2 3)))
198 (should (equal (version-to-list "22_8.beta3") '(22 8 -2 3)))
199 (should (equal (version-to-list "22_8beta3") '(22 8 -2 3)))
200 (should (equal (version-to-list "6_9_30 Beta") '(6 9 30 -2)))
201 (should (equal (version-to-list "6_9_30-Beta") '(6 9 30 -2)))
202 (should (equal (version-to-list "6_9_30.Beta") '(6 9 30 -2)))
203 (should (equal (version-to-list "6_9_30Beta") '(6 9 30 -2)))
204
205 (should (equal
206 (error-message-string (should-error (version-to-list "1_0__7_5")))
207 "Invalid version syntax: `1_0__7_5'"))
208 (should (equal
209 (error-message-string (should-error (version-to-list "1_0prepre2")))
210 "Invalid version syntax: `1_0prepre2'"))
211 (should (equal
212 (error-message-string (should-error (version-to-list "22.8X3")))
213 "Invalid version syntax: `22.8X3'"))
214 (should (equal
215 (error-message-string (should-error (version-to-list "beta22_8alpha3")))
216 "Invalid version syntax: `beta22_8alpha3' (must start with a number)"))))
217
218 (provide 'subr-tests)
219 ;;; subr-tests.el ends here