diff options
| author | Craig Jennings <c@cjennings.net> | 2026-06-20 10:34:45 -0400 |
|---|---|---|
| committer | Craig Jennings <c@cjennings.net> | 2026-06-20 10:34:45 -0400 |
| commit | bf52bb610469e9b0b4090a85f7af15fc9d108842 (patch) | |
| tree | 244509ed9d6d536b586b00c0f09340ce7919584f /tests | |
| parent | fe475547aa71e319a01723b41ce64738816cf570 (diff) | |
| download | dotemacs-bf52bb610469e9b0b4090a85f7af15fc9d108842.tar.gz dotemacs-bf52bb610469e9b0b4090a85f7af15fc9d108842.zip | |
feat(windows): pull a window away from a sole window with C-; b + arrow
When the selected window fills the frame there is no divider to resize, so the arrow now splits toward its direction with the previous buffer and the original window shrinks from that edge. Multi-window resize is unchanged.
Diffstat (limited to 'tests')
| -rw-r--r-- | tests/test-ui-navigation--window-resize.el | 39 |
1 files changed, 36 insertions, 3 deletions
diff --git a/tests/test-ui-navigation--window-resize.el b/tests/test-ui-navigation--window-resize.el index 3be0313b8..986ce1580 100644 --- a/tests/test-ui-navigation--window-resize.el +++ b/tests/test-ui-navigation--window-resize.el @@ -24,8 +24,11 @@ (should (eq (keymap-lookup cj/window-resize-map "<down>") #'windsize-down))) (ert-deftest test-ui-navigation-window-resize-sticky-dispatches-and-arms () - "Normal: `cj/window-resize-sticky' runs the `windsize' command matching the -arrow key that triggered it, then arms the sticky-repeat map." + "Normal: with more than one window, `cj/window-resize-sticky' runs the +`windsize' command matching the arrow key that triggered it, then arms the +sticky-repeat map. `one-window-p' is forced nil so the resize path is taken +deterministically -- in `--batch' the sole frame is one-window-p, which would +otherwise route to the pull-away path." (dolist (case '((left . windsize-left) (right . windsize-right) (up . windsize-up) @@ -33,13 +36,43 @@ arrow key that triggered it, then arms the sticky-repeat map." (let ((ran nil) (overriding-terminal-local-map nil) (pre-command-hook nil)) - (cl-letf (((symbol-function (cdr case)) + (cl-letf (((symbol-function 'one-window-p) (lambda (&rest _) nil)) + ((symbol-function (cdr case)) (lambda (&rest _) (interactive) (setq ran t)))) (let ((last-command-event (car case))) (cj/window-resize-sticky))) (should ran) ; dispatched to the right command (should overriding-terminal-local-map)))) ; loop armed +(ert-deftest test-ui-navigation-window-arrow-direction () + "Normal/Error: each arrow maps to its split direction; anything else is nil." + (should (eq (cj/window-arrow-direction "<left>") 'left)) + (should (eq (cj/window-arrow-direction "<right>") 'right)) + (should (eq (cj/window-arrow-direction "<up>") 'above)) + (should (eq (cj/window-arrow-direction "<down>") 'below)) + (should (null (cj/window-arrow-direction "<prior>"))) + (should (null (cj/window-arrow-direction "x")))) + +(ert-deftest test-ui-navigation-window-resize-sticky-sole-window-pulls-away () + "Normal: with a single window, the arrow pulls a window away toward its +direction (via `cj/window--pull-away') rather than resizing, then arms the +loop. `cj/window--pull-away' is stubbed to capture the direction so no real +window split happens under `--batch'." + (dolist (case '((left . left) + (right . right) + (up . above) + (down . below))) + (let ((pulled nil) + (overriding-terminal-local-map nil) + (pre-command-hook nil)) + (cl-letf (((symbol-function 'one-window-p) (lambda (&rest _) t)) + ((symbol-function 'cj/window--pull-away) + (lambda (dir) (setq pulled dir)))) + (let ((last-command-event (car case))) + (cj/window-resize-sticky))) + (should (eq pulled (cdr case))) ; pulled toward the arrow + (should overriding-terminal-local-map)))) ; loop armed + (ert-deftest test-ui-navigation-window-resize-bound-under-c-semicolon-b () "Normal: `C-; b <arrow>' (each direction) reaches the sticky-resize command." (require 'custom-buffer-file) |
