1 ;;; abbrev-tests.el --- Test suite for abbrevs -*- lexical-binding: t; -*-
3 ;; Copyright (C) 2015-2017 Free Software Foundation, Inc.
5 ;; Author: Eli Zaretskii <eliz@gnu.org>
8 ;; This file is part of GNU Emacs.
10 ;; GNU Emacs is free software: you can redistribute it and/or modify
11 ;; it under the terms of the GNU General Public License as published by
12 ;; the Free Software Foundation, either version 3 of the License, or
13 ;; (at your option) any later version.
15 ;; GNU Emacs is distributed in the hope that it will be useful,
16 ;; but WITHOUT ANY WARRANTY; without even the implied warranty of
17 ;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
18 ;; GNU General Public License for more details.
20 ;; You should have received a copy of the GNU General Public License
21 ;; along with GNU Emacs. If not, see <http://www.gnu.org/licenses/>.
25 ;; `kill-all-abbrevs-test' will remove all user *and* system abbrevs
26 ;; if called noninteractively with the init file loaded.
34 ;; set up test abbrev table and abbrev entry
35 (defun setup-test-abbrev-table ()
36 (defvar ert-test-abbrevs nil
)
37 (define-abbrev-table 'ert-test-abbrevs
'(("a-e-t" "abbrev-ert-test")))
38 (abbrev-table-put ert-test-abbrevs
:ert-test
"ert-test-value")
41 (ert-deftest abbrev-table-p-test
()
42 (should-not (abbrev-table-p 42))
43 (should-not (abbrev-table-p "aoeu"))
44 (should-not (abbrev-table-p '()))
45 (should-not (abbrev-table-p []))
46 ;; Missing :abbrev-table-modiff counter:
47 (should-not (abbrev-table-p (obarray-make)))
48 (should (abbrev-table-empty-p (make-abbrev-table))))
50 (ert-deftest abbrev-make-abbrev-table-test
()
51 ;; Table without properties:
52 (let ((table (make-abbrev-table)))
53 (should (abbrev-table-p table
))
54 (should (= (length table
) obarray-default-size
)))
55 ;; Table with one property 'foo with value 'bar:
56 (let ((table (make-abbrev-table '(foo bar
))))
57 (should (abbrev-table-p table
))
58 (should (= (length table
) obarray-default-size
))
59 (should (eq (abbrev-table-get table
'foo
) 'bar
))))
61 (ert-deftest abbrev-table-get-put-test
()
62 (let ((table (make-abbrev-table)))
63 (should-not (abbrev-table-get table
'foo
))
64 (should (= (abbrev-table-put table
'foo
42) 42))
65 (should (= (abbrev-table-get table
'foo
) 42))
66 (should (eq (abbrev-table-put table
'foo
'bar
) 'bar
))
67 (should (eq (abbrev-table-get table
'foo
) 'bar
))))
69 (ert-deftest copy-abbrev-table-test
()
70 (defvar foo-abbrev-table nil
) ; Avoid compiler warning
71 (define-abbrev-table 'foo-abbrev-table
73 (should (abbrev-table-p foo-abbrev-table
))
75 (let ((new-foo-abbrev-table
77 (copy-abbrev-table foo-abbrev-table
)
79 (should (abbrev-table-p new-foo-abbrev-table
)))
80 (should-not (string-equal (buffer-name) "*Backtrace*")))
82 (ert-deftest abbrev-table-empty-p-test
()
83 (should-error (abbrev-table-empty-p 42))
84 (should-error (abbrev-table-empty-p "aoeu"))
85 (should-error (abbrev-table-empty-p '()))
86 (should-error (abbrev-table-empty-p []))
87 ;; Missing :abbrev-table-modiff counter:
88 (should-error (abbrev-table-empty-p (obarray-make)))
89 (let* ((table (obarray-make)))
90 (abbrev-table-put table
:abbrev-table-modiff
42)
91 (should (abbrev-table-empty-p table
))))
93 (ert-deftest kill-all-abbrevs-test
()
94 "Test undefining all defined abbrevs"
95 (unless noninteractive
96 (ert-skip "Cannot test kill-all-abbrevs in interactive mode"))
99 ;; ensure at least one abbrev exists
100 (should (abbrev-table-p (setup-test-abbrev-table)))
101 (setf num-tables
(length abbrev-table-name-list
))
104 ;; no tables should have been removed/added
105 (should (= num-tables
(length abbrev-table-name-list
)))
106 ;; number of empty tables should be the same as number of tables
107 (should (= num-tables
(length (seq-filter
109 (abbrev-table-empty-p (symbol-value table
)))
110 abbrev-table-name-list
))))))
112 (ert-deftest abbrev-table-name-test
()
113 "Test returning name of abbrev-table"
114 (let ((ert-test-abbrevs (setup-test-abbrev-table))
116 (should (equal 'ert-test-abbrevs
(abbrev-table-name ert-test-abbrevs
)))
117 (should (equal nil
(abbrev-table-name no-such-table
)))))
119 (ert-deftest clear-abbrev-table-test
()
120 "Test clearing single abbrev table"
121 (let ((ert-test-abbrevs (setup-test-abbrev-table)))
122 (should (equal "abbrev-ert-test" (abbrev-expansion "a-e-t" ert-test-abbrevs
)))
123 (clear-abbrev-table ert-test-abbrevs
)
124 (should (equal nil
(abbrev-expansion "a-e-t" ert-test-abbrevs
)))
125 (should (equal t
(abbrev-table-empty-p ert-test-abbrevs
)))))
127 (ert-deftest list-abbrevs-test
()
128 "Test generation of abbrev list buffer"
129 ;; Somewhat redundant as prepare-abbrev-list-buffer is also tested.
131 (let ((abbrev-buffer (prepare-abbrev-list-buffer)))
132 (should (equal "*Abbrevs*" (buffer-name abbrev-buffer
)))
133 (kill-buffer abbrev-buffer
))
134 ;; mode-specific abbrevs
135 (let ((abbrev-buffer (prepare-abbrev-list-buffer t
)))
136 (should (equal "*Abbrevs*" (buffer-name abbrev-buffer
)))
137 (kill-buffer abbrev-buffer
)))
139 (ert-deftest prepare-abbrev-list-buffer-test
()
140 "Test generation of abbrev list buffer"
142 (let ((ert-test-abbrevs (setup-test-abbrev-table)))
143 (with-current-buffer (prepare-abbrev-list-buffer)
144 ;; Check for a couple of abbrev-table names in buffer.
146 (goto-char (point-min))
147 (search-forward (symbol-name (abbrev-table-name ert-test-abbrevs
))))
149 (goto-char (point-min))
150 (search-forward "global-abbrev-table"))))
151 (should (equal 'edit-abbrevs-mode major-mode
))
152 (kill-buffer "*Abbrevs*")))
154 ;; mode-specific abbrevs (temp buffer uses fundamental-mode)
156 (prepare-abbrev-list-buffer t
)
157 (with-current-buffer "*Abbrevs*"
159 (goto-char (point-min))
160 (search-forward "fundamental-mode-abbrev-table")))
162 (goto-char (point-min))
163 (search-forward "global-abbrev-table")))
164 (should-not (equal 'edit-abbrevs-mode major-mode
))
165 (kill-buffer "*Abbrevs*"))))
167 (ert-deftest insert-abbrevs-test
()
168 "Test inserting abbrev definitions into buffer"
172 (goto-char (point-min))
173 (search-forward "global-abbrev-table")))))
175 (ert-deftest edit-abbrevs-test
()
176 "Test editing abbrevs from buffer"
177 (defvar ert-edit-abbrevs-test-table nil
)
178 (let ((ert-test-abbrevs (setup-test-abbrev-table)))
180 ;; insert test table and new abbrev, redefine, check definition
181 (goto-char (point-min))
182 (insert "(ert-edit-abbrevs-test-table)\n")
183 (insert "\n" "\"e-a-t\"\t" "0\t" "\"edit-abbrevs-test\"\n")
184 ;; check test table before redefine
185 (should (equal "abbrev-ert-test"
186 (abbrev-expansion "a-e-t" ert-test-abbrevs
)))
187 (edit-abbrevs-redefine)
188 (should-not (abbrev-expansion "a-e-t" ert-test-abbrevs
))
189 (should (equal "edit-abbrevs-test"
190 (abbrev-expansion "e-a-t" ert-edit-abbrevs-test-table
))))))
192 (ert-deftest define-abbrevs-test
()
193 "Test defining abbrevs from buffer"
194 (defvar ert-bad-abbrev-table nil
)
195 (defvar ert-good-abbrev-table nil
)
196 (defvar ert-redefine-abbrev-table nil
)
198 ;; insert bad abbrev data and attempt define
199 (goto-char (point-min))
200 (insert "ert-bad-abbrev-table\n")
201 (insert "\n" "\"b-a-t\"\t" "0\t" "\n")
202 (should-not (define-abbrevs))
203 (should (equal nil
(abbrev-expansion "b-a-t" ert-bad-abbrev-table
)))
204 (delete-region (point-min) (point-max))
205 ;; try with valid abbrev data
206 (goto-char (point-min))
207 (insert "(ert-good-abbrev-table)\n")
208 (insert "\n" "\"g-a-t\"\t" "0\t" "\"good-abbrev-table\"\n")
210 (should (equal "good-abbrev-table"
211 (abbrev-expansion "g-a-t" ert-good-abbrev-table
)))
212 ;; redefine from buffer
213 (delete-region (point-min) (point-max))
214 (insert "(ert-redefine-abbrev-table)\n")
215 (insert "\n" "\"r-a-t\"\t" "0\t" "\"redefine-abbrev-table\"\n")
216 ;; arg = kill-all-abbrevs
218 (should (equal "redefine-abbrev-table"
219 (abbrev-expansion "r-a-t" ert-redefine-abbrev-table
)))
220 (should (equal nil
(abbrev-expansion "g-a-t" ert-good-abbrev-table
)))))
222 (ert-deftest read-write-abbrev-file-test
()
223 "Test reading and writing abbrevs from file"
224 (let ((temp-test-file (make-temp-file "ert-abbrev-test"))
225 (ert-test-abbrevs (setup-test-abbrev-table)))
226 (write-abbrev-file temp-test-file
)
227 (clear-abbrev-table ert-test-abbrevs
)
228 (should (abbrev-table-empty-p ert-test-abbrevs
))
229 (read-abbrev-file temp-test-file
)
230 (should (equal "abbrev-ert-test" (abbrev-expansion "a-e-t" ert-test-abbrevs
)))
231 (delete-file temp-test-file
)))
233 (ert-deftest abbrev-edit-save-to-file-test
()
234 "Test saving abbrev definitions in buffer to file"
235 (defvar ert-save-test-table nil
)
236 (let ((temp-test-file (make-temp-file "ert-abbrev-test"))
237 (ert-test-abbrevs (setup-test-abbrev-table)))
239 (goto-char (point-min))
240 (insert "(ert-save-test-table)\n")
241 (insert "\n" "\"s-a-t\"\t" "0\t" "\"save-abbrevs-test\"\n")
242 (should (equal "abbrev-ert-test"
243 (abbrev-expansion "a-e-t" ert-test-abbrevs
)))
244 ;; clears abbrev tables
245 (abbrev-edit-save-to-file temp-test-file
)
246 (should-not (abbrev-expansion "a-e-t" ert-test-abbrevs
))
247 (read-abbrev-file temp-test-file
)
248 (should (equal "save-abbrevs-test"
249 (abbrev-expansion "s-a-t" ert-save-test-table
)))
250 (delete-file temp-test-file
))))
252 (provide 'abbrev-tests
)
254 ;;; abbrev-tests.el ends here