aboutsummaryrefslogtreecommitdiff
path: root/test/functional/legacy/cmdline_spec.lua
diff options
context:
space:
mode:
authorzeertzjq <zeertzjq@outlook.com>2022-09-20 21:26:24 +0800
committerGitHub <noreply@github.com>2022-09-20 21:26:24 +0800
commit86c5d761c4752c44acb0eb4ce7e7b41be3408969 (patch)
tree32211d325eb5e35ab4dcef48e75520982a30a1bf /test/functional/legacy/cmdline_spec.lua
parentae30e388dee08e59c08dffc20c2f5122b8c31249 (diff)
parent2e4532bea50e5f6fb68ebf750c461c5704fc58c2 (diff)
downloadrneovim-86c5d761c4752c44acb0eb4ce7e7b41be3408969.tar.gz
rneovim-86c5d761c4752c44acb0eb4ce7e7b41be3408969.tar.bz2
rneovim-86c5d761c4752c44acb0eb4ce7e7b41be3408969.zip
Merge pull request #20262 from zeertzjq/vim-9.0.0507
vim-patch:9.0.{0507,0512}: cmdline cleared when using :redrawstatus
Diffstat (limited to 'test/functional/legacy/cmdline_spec.lua')
-rw-r--r--test/functional/legacy/cmdline_spec.lua68
1 files changed, 68 insertions, 0 deletions
diff --git a/test/functional/legacy/cmdline_spec.lua b/test/functional/legacy/cmdline_spec.lua
index 99d2d0f30e..8325f7eeb0 100644
--- a/test/functional/legacy/cmdline_spec.lua
+++ b/test/functional/legacy/cmdline_spec.lua
@@ -140,6 +140,74 @@ describe('cmdline', function()
:^ |
]])
end)
+
+ -- oldtest: Test_redraw_in_autocmd()
+ it('cmdline cursor position is correct after :redraw with cmdheight=2', function()
+ local screen = Screen.new(30, 6)
+ screen:set_default_attr_ids({
+ [0] = {bold = true, foreground = Screen.colors.Blue}, -- NonText
+ })
+ screen:attach()
+ exec([[
+ set cmdheight=2
+ autocmd CmdlineChanged * redraw
+ ]])
+ feed(':for i in range(3)<CR>')
+ screen:expect([[
+ |
+ {0:~ }|
+ {0:~ }|
+ {0:~ }|
+ :for i in range(3) |
+ : ^ |
+ ]])
+ feed(':let i =')
+ -- Note: this may still be considered broken, ref #18140
+ screen:expect([[
+ |
+ {0:~ }|
+ {0:~ }|
+ {0:~ }|
+ : :let i =^ |
+ |
+ ]])
+ end)
+
+ -- oldtest: Test_redrawstatus_in_autocmd()
+ it(':redrawstatus in cmdline mode', function()
+ local screen = Screen.new(60, 6)
+ screen:set_default_attr_ids({
+ [0] = {bold = true, foreground = Screen.colors.Blue}, -- NonText
+ [1] = {bold = true, reverse = true}, -- MsgSeparator, StatusLine
+ })
+ screen:attach()
+ exec([[
+ set laststatus=2
+ set statusline=%=:%{getcmdline()}
+ autocmd CmdlineChanged * if getcmdline() == 'foobar' | redrawstatus | endif
+ ]])
+ -- :redrawstatus is postponed if messages have scrolled
+ feed([[:echo "one\ntwo\nthree\nfour"<CR>]])
+ feed(':foobar')
+ screen:expect([[
+ {1: }|
+ one |
+ two |
+ three |
+ four |
+ :foobar^ |
+ ]])
+ -- it is not postponed if messages have not scrolled
+ feed('<Esc>:foobar')
+ screen:expect([[
+ |
+ {0:~ }|
+ {0:~ }|
+ {0:~ }|
+ {1: :foobar}|
+ :foobar^ |
+ ]])
+ end)
end)
describe('cmdwin', function()