blob: 9668146189836f00374c49eac2830c7a6fff8fc7 (
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
83
84
85
86
87
88
89
90
91
92
93
94
|
;;; test-vterm-toggle--buffer-filter.el --- Tests for F12's buffer filter -*- lexical-binding: t; -*-
;;; Commentary:
;; Three closely-related helpers determine which vterm buffers F12
;; manages: the predicate `cj/--vterm-toggle-buffer-p', the MRU list
;; `cj/--vterm-toggle-buffers', and the per-frame window finder
;; `cj/--vterm-toggle-displayed-window'. All three exclude claude-
;; prefixed buffers so claude has its own F9 surface.
;;; Code:
(require 'ert)
(add-to-list 'load-path (expand-file-name "modules" user-emacs-directory))
(add-to-list 'load-path (expand-file-name "tests" user-emacs-directory))
(require 'eshell-vterm-config)
(require 'testutil-vterm-buffers)
(defun test-vterm-toggle--cleanup ()
"Kill leftover claude- and *test-vterm- prefixed buffers."
(cj/test--kill-claude-buffers)
(cj/test--kill-test-vterm-buffers))
(ert-deftest test-vterm-toggle--buffer-p-accepts-vterm-mode ()
"Normal: a vterm-mode buffer with non-claude name qualifies."
(test-vterm-toggle--cleanup)
(let ((buf (cj/test--make-fake-vterm-buffer "*test-vterm-1*")))
(unwind-protect
(should (cj/--vterm-toggle-buffer-p buf))
(kill-buffer buf))))
(ert-deftest test-vterm-toggle--buffer-p-rejects-claude ()
"Boundary: claude-prefixed vterm buffers are excluded from F12's set."
(test-vterm-toggle--cleanup)
(let ((buf (cj/test--make-fake-vterm-buffer "claude [project-a]")))
(unwind-protect
(should-not (cj/--vterm-toggle-buffer-p buf))
(kill-buffer buf))))
(ert-deftest test-vterm-toggle--buffer-p-rejects-non-vterm ()
"Boundary: a regular buffer (not vterm-mode, no vterm name prefix) -> nil."
(test-vterm-toggle--cleanup)
(let ((buf (get-buffer-create "*test-vterm-regular*")))
(unwind-protect
(should-not (cj/--vterm-toggle-buffer-p buf))
(kill-buffer buf))))
(ert-deftest test-vterm-toggle--buffer-p-rejects-dead-buffer ()
"Boundary: nil and dead buffers -> nil."
(should-not (cj/--vterm-toggle-buffer-p nil))
(let ((buf (cj/test--make-fake-vterm-buffer "*test-vterm-dead*")))
(kill-buffer buf)
(should-not (cj/--vterm-toggle-buffer-p buf))))
(ert-deftest test-vterm-toggle--buffers-filters-claude ()
"Normal: returns vterm buffers but excludes claude-prefixed ones."
(test-vterm-toggle--cleanup)
(let ((normal (cj/test--make-fake-vterm-buffer "*test-vterm-normal*"))
(claude (cj/test--make-fake-vterm-buffer "claude [for-test]")))
(unwind-protect
(let ((result (cj/--vterm-toggle-buffers)))
(should (memq normal result))
(should-not (memq claude result)))
(kill-buffer normal)
(kill-buffer claude))))
(ert-deftest test-vterm-toggle--displayed-window-finds-vterm ()
"Normal: vterm in a window -> returns that window."
(test-vterm-toggle--cleanup)
(let ((vt (cj/test--make-fake-vterm-buffer "*test-vterm-shown*")))
(unwind-protect
(save-window-excursion
(delete-other-windows)
(let ((win (split-window-right)))
(set-window-buffer win vt)
(let ((result (cj/--vterm-toggle-displayed-window)))
(should (windowp result))
(should (eq (window-buffer result) vt)))))
(kill-buffer vt))))
(ert-deftest test-vterm-toggle--displayed-window-skips-claude ()
"Boundary: only a claude vterm is displayed -> nil (claude not F12-managed)."
(test-vterm-toggle--cleanup)
(let ((claude (cj/test--make-fake-vterm-buffer "claude [skip-test]")))
(unwind-protect
(save-window-excursion
(delete-other-windows)
(let ((win (split-window-right)))
(set-window-buffer win claude)
(should-not (cj/--vterm-toggle-displayed-window))))
(kill-buffer claude))))
(provide 'test-vterm-toggle--buffer-filter)
;;; test-vterm-toggle--buffer-filter.el ends here
|