aboutsummaryrefslogtreecommitdiff
path: root/test/functional/legacy/display_spec.lua
diff options
context:
space:
mode:
authorzeertzjq <zeertzjq@outlook.com>2022-04-10 04:50:49 +0800
committerGitHub <noreply@github.com>2022-04-10 04:50:49 +0800
commit2a2c4e191f5c2cb70bafaa213b5697308dc6f850 (patch)
treea766cd43496484591a86d1d74db86f94a6e47a27 /test/functional/legacy/display_spec.lua
parent61bd5426f4ef0d8f45d0972f7da870131ae278ba (diff)
downloadrneovim-2a2c4e191f5c2cb70bafaa213b5697308dc6f850.tar.gz
rneovim-2a2c4e191f5c2cb70bafaa213b5697308dc6f850.tar.bz2
rneovim-2a2c4e191f5c2cb70bafaa213b5697308dc6f850.zip
vim-patch:8.2.4718: @@@ in the last line sometimes drawn in the wrong place (#18055)
Problem: @@@ in the last line sometimes drawn in the wrong place. Solution: Make sure the column is valid. (closes vim/vim#10130) https://github.com/vim/vim/commit/cee9c844f27bceaba90362a3fa27a04d4d06c0fd
Diffstat (limited to 'test/functional/legacy/display_spec.lua')
-rw-r--r--test/functional/legacy/display_spec.lua56
1 files changed, 49 insertions, 7 deletions
diff --git a/test/functional/legacy/display_spec.lua b/test/functional/legacy/display_spec.lua
index 59ba170e33..4c7915403c 100644
--- a/test/functional/legacy/display_spec.lua
+++ b/test/functional/legacy/display_spec.lua
@@ -2,23 +2,21 @@ local helpers = require('test.functional.helpers')(after_each)
local Screen = require('test.functional.ui.screen')
local clear = helpers.clear
-local poke_eventloop = helpers.poke_eventloop
local exec = helpers.exec
local feed = helpers.feed
-local feed_command = helpers.feed_command
+local command = helpers.command
describe('display', function()
before_each(clear)
- it('scroll when modified at topline', function()
+ it('scroll when modified at topline vim-patch:8.2.1488', function()
local screen = Screen.new(20, 4)
screen:attach()
screen:set_default_attr_ids({
[1] = {bold = true},
})
- feed_command([[call setline(1, repeat('a', 21))]])
- poke_eventloop()
+ command([[call setline(1, repeat('a', 21))]])
feed('O')
screen:expect([[
^ |
@@ -28,7 +26,7 @@ describe('display', function()
]])
end)
- it('scrolling when modified at topline in Visual mode', function()
+ it('scrolling when modified at topline in Visual mode vim-patch:8.2.4626', function()
local screen = Screen.new(60, 8)
screen:attach()
screen:set_default_attr_ids({
@@ -57,5 +55,49 @@ describe('display', function()
{1:-- VISUAL LINE --} |
]])
end)
-end)
+ it('@@@ in the last line shows correctly in a narrow window vim-patch:8.2.4718', function()
+ local screen = Screen.new(60, 10)
+ screen:set_default_attr_ids({
+ [1] = {bold = true, foreground = Screen.colors.Blue}, -- NonText
+ [2] = {bold = true, reverse = true}, -- StatusLine
+ [3] = {reverse = true}, -- VertSplit, StatusLineNC
+ })
+ screen:attach()
+ exec([[
+ call setline(1, ['aaa', 'b'->repeat(100)])
+ set display=truncate
+ vsplit
+ 100wincmd <
+ ]])
+ screen:expect([[
+ ^a{3:│}aaa |
+ a{3:│}bbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbb|
+ a{3:│}bbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbb |
+ b{3:│}{1:~ }|
+ b{3:│}{1:~ }|
+ b{3:│}{1:~ }|
+ b{3:│}{1:~ }|
+ {1:@}{3:│}{1:~ }|
+ {2:< }{3:[No Name] [+] }|
+ |
+ ]])
+ command('set display=lastline')
+ screen:expect_unchanged()
+ command('100wincmd >')
+ screen:expect([[
+ ^aaa {3:│}a|
+ bbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbb{3:│}a|
+ bbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbb {3:│}a|
+ {1:~ }{3:│}b|
+ {1:~ }{3:│}b|
+ {1:~ }{3:│}b|
+ {1:~ }{3:│}b|
+ {1:~ }{3:│}{1:@}|
+ {2:[No Name] [+] }{3:<}|
+ |
+ ]])
+ command('set display=truncate')
+ screen:expect_unchanged()
+ end)
+end)