-
Notifications
You must be signed in to change notification settings - Fork 181
/
Copy pathrust-cargo-tests.el
72 lines (62 loc) · 2.62 KB
/
rust-cargo-tests.el
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
;;; rust-cargo-tests.el --- ERT tests for rust-cargo.el -*- lexical-binding: t; -*-
(require 'rust-cargo)
(require 'rust-rustfmt)
(require 'ert)
(defun rust-test--wait-process-exit ()
"Wait for comint process for current buffer to exit."
(let ((proc (get-buffer-process (current-buffer))))
(while (not (eq (process-status proc) 'exit))
(sit-for 0.2))))
(defun rust-test--send-process-string (string)
"Send STRING to comint process for current buffer."
(let ((proc (get-buffer-process (current-buffer))))
(comint-send-string proc string)))
(defmacro rust-test--with-main-file-buffer (expr)
`(let* ((test-dir (expand-file-name "test-project/" default-directory))
(main-file (expand-file-name "src/main.rs" test-dir)))
(save-current-buffer
(find-file main-file)
,expr)))
(defun rust-test--find-string (string)
"Find STRING in current buffer."
(goto-char (point-min))
(not (null (search-forward string nil t))))
(ert-deftest rust-test-compile ()
(skip-unless (executable-find rust-cargo-bin))
(setq rust-cargo-default-arguments "")
(rust-test--with-main-file-buffer
(with-current-buffer (rust-compile)
(rust-test--wait-process-exit)
(should (rust-test--find-string "Compilation finished")))))
(ert-deftest rust-test-run ()
(skip-unless (executable-find rust-cargo-bin))
(setq rust-cargo-default-arguments "")
(rust-test--with-main-file-buffer
(with-current-buffer (rust-run)
(rust-test--wait-process-exit)
(should (rust-test--find-string "***run not interactive")))))
(ert-deftest rust-test-run-interactive ()
(skip-unless (executable-find rust-cargo-bin))
(setq rust-cargo-default-arguments "interactive")
(rust-test--with-main-file-buffer
;; '(4) is default value when called interactively with universal argument
(with-current-buffer (rust-run '(4))
(rust-test--send-process-string "1234\n")
(rust-test--wait-process-exit)
(should (rust-test--find-string "***run interactive: 1234")))))
(ert-deftest rust-test-rustfmt ()
(skip-unless (executable-find "rustfmt"))
(rust-test--with-main-file-buffer
(let ((old-content (buffer-string))
(ret (rust-format-buffer)))
(should (string= ret "Formatted buffer with rustfmt."))
(should (string= old-content (buffer-string))))))
(ert-deftest rust-test-rustfmt-parsing-errors ()
(skip-unless (executable-find "rustfmt"))
(with-temp-buffer
(insert "fn main() {")
(rust-format-buffer)
(with-current-buffer "*rustfmt*"
(should (eq major-mode 'rust-format-mode))
(should (rust-test--find-string "error:")))
(kill-buffer "*rustfmt*")))