annotate clang-tools-extra/clang-include-fixer/tool/clang-include-fixer-test.el @ 160:dbfec6499728

...
author anatofuz
date Wed, 18 Mar 2020 19:11:03 +0900
parents 1d019706d866
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
150
anatofuz
parents:
diff changeset
1 ;;; clang-include-fixer-test.el --- unit tests for clang-include-fixer.el -*- lexical-binding: t; -*-
anatofuz
parents:
diff changeset
2
anatofuz
parents:
diff changeset
3 ;;; Commentary:
anatofuz
parents:
diff changeset
4
anatofuz
parents:
diff changeset
5 ;; Unit tests for clang-include-fixer.el.
anatofuz
parents:
diff changeset
6
anatofuz
parents:
diff changeset
7 ;;; Code:
anatofuz
parents:
diff changeset
8
anatofuz
parents:
diff changeset
9 (require 'clang-include-fixer)
anatofuz
parents:
diff changeset
10
anatofuz
parents:
diff changeset
11 (require 'cc-mode)
anatofuz
parents:
diff changeset
12 (require 'ert)
anatofuz
parents:
diff changeset
13
anatofuz
parents:
diff changeset
14 (ert-deftest clang-include-fixer--insert-line ()
anatofuz
parents:
diff changeset
15 "Unit test for `clang-include-fixer--insert-line'."
anatofuz
parents:
diff changeset
16 (with-temp-buffer
anatofuz
parents:
diff changeset
17 (insert "aa\nab\nac\nad\n")
anatofuz
parents:
diff changeset
18 (let ((from (current-buffer)))
anatofuz
parents:
diff changeset
19 (with-temp-buffer
anatofuz
parents:
diff changeset
20 (insert "aa\nac\nad\n")
anatofuz
parents:
diff changeset
21 (let ((to (current-buffer)))
anatofuz
parents:
diff changeset
22 (should (clang-include-fixer--insert-line from to))
anatofuz
parents:
diff changeset
23 (should (equal (buffer-string) "aa\nab\nac\nad\n")))))
anatofuz
parents:
diff changeset
24 (should (equal (buffer-string) "aa\nab\nac\nad\n"))))
anatofuz
parents:
diff changeset
25
anatofuz
parents:
diff changeset
26 (ert-deftest clang-include-fixer--insert-line-diff-on-empty-line ()
anatofuz
parents:
diff changeset
27 "Unit test for `clang-include-fixer--insert-line'."
anatofuz
parents:
diff changeset
28 (with-temp-buffer
anatofuz
parents:
diff changeset
29 (insert "aa\nab\n\nac\nad\n")
anatofuz
parents:
diff changeset
30 (let ((from (current-buffer)))
anatofuz
parents:
diff changeset
31 (with-temp-buffer
anatofuz
parents:
diff changeset
32 (insert "aa\n\nac\nad\n")
anatofuz
parents:
diff changeset
33 (let ((to (current-buffer)))
anatofuz
parents:
diff changeset
34 (should (clang-include-fixer--insert-line from to))
anatofuz
parents:
diff changeset
35 (should (equal (buffer-string) "aa\nab\n\nac\nad\n")))))
anatofuz
parents:
diff changeset
36 (should (equal (buffer-string) "aa\nab\n\nac\nad\n"))))
anatofuz
parents:
diff changeset
37
anatofuz
parents:
diff changeset
38 (ert-deftest clang-include-fixer--symbol-at-point ()
anatofuz
parents:
diff changeset
39 "Unit test for `clang-include-fixer--symbol-at-point'."
anatofuz
parents:
diff changeset
40 (with-temp-buffer
anatofuz
parents:
diff changeset
41 (insert "a+bbb::cc")
anatofuz
parents:
diff changeset
42 (c++-mode)
anatofuz
parents:
diff changeset
43 (goto-char (point-min))
anatofuz
parents:
diff changeset
44 (should (equal (clang-include-fixer--symbol-at-point) "a"))
anatofuz
parents:
diff changeset
45 (forward-char)
anatofuz
parents:
diff changeset
46 ;; Emacs treats the character immediately following a symbol as part of the
anatofuz
parents:
diff changeset
47 ;; symbol.
anatofuz
parents:
diff changeset
48 (should (equal (clang-include-fixer--symbol-at-point) "a"))
anatofuz
parents:
diff changeset
49 (forward-char)
anatofuz
parents:
diff changeset
50 (should (equal (clang-include-fixer--symbol-at-point) "bbb::cc"))
anatofuz
parents:
diff changeset
51 (goto-char (point-max))
anatofuz
parents:
diff changeset
52 (should (equal (clang-include-fixer--symbol-at-point) "bbb::cc"))))
anatofuz
parents:
diff changeset
53
anatofuz
parents:
diff changeset
54 (ert-deftest clang-include-fixer--highlight ()
anatofuz
parents:
diff changeset
55 (with-temp-buffer
anatofuz
parents:
diff changeset
56 (insert "util::Status foo;\n")
anatofuz
parents:
diff changeset
57 (setq buffer-file-coding-system 'utf-8-unix)
anatofuz
parents:
diff changeset
58 (should (equal nil (clang-include-fixer--highlight
anatofuz
parents:
diff changeset
59 '((Range . ((Offset . 0) (Length . 0)))))))
anatofuz
parents:
diff changeset
60 (let ((overlay (clang-include-fixer--highlight
anatofuz
parents:
diff changeset
61 '((Range . ((Offset . 1) (Length . 12)))))))
anatofuz
parents:
diff changeset
62 (should (equal 2 (overlay-start overlay)))
anatofuz
parents:
diff changeset
63 (should (equal 14 (overlay-end overlay))))))
anatofuz
parents:
diff changeset
64
anatofuz
parents:
diff changeset
65 ;;; clang-include-fixer-test.el ends here