aboutsummaryrefslogtreecommitdiff
path: root/test/functional
diff options
context:
space:
mode:
authorAufar Gilbran <aufargilbran@gmail.com>2020-10-02 03:20:58 +0800
committerAufar Gilbran <aufargilbran@gmail.com>2020-10-07 23:41:38 +0800
commite852bad3a7f9ae8a85117785f3ad18954b1a74fa (patch)
treeea16a546020ddfcd18276d1024eb9f025167ba11 /test/functional
parenta260d5def363ca30f0473365ea514f2dedd0d0ba (diff)
downloadrneovim-e852bad3a7f9ae8a85117785f3ad18954b1a74fa.tar.gz
rneovim-e852bad3a7f9ae8a85117785f3ad18954b1a74fa.tar.bz2
rneovim-e852bad3a7f9ae8a85117785f3ad18954b1a74fa.zip
vim-patch:8.2.1345: Redraw error when using visual block and scroll
Problem: Redraw error when using visual block and scroll. Solution: Add check for w_topline. ( closes vim/vim#6597) https://github.com/vim/vim/commit/f8992d47cd50494c64bb733329067c9de3c75200
Diffstat (limited to 'test/functional')
-rw-r--r--test/functional/legacy/visual_mode_spec.lua42
1 files changed, 42 insertions, 0 deletions
diff --git a/test/functional/legacy/visual_mode_spec.lua b/test/functional/legacy/visual_mode_spec.lua
new file mode 100644
index 0000000000..c8e83ed649
--- /dev/null
+++ b/test/functional/legacy/visual_mode_spec.lua
@@ -0,0 +1,42 @@
+-- Test visual line mode selection redraw after scrolling
+
+local helpers = require('test.functional.helpers')(after_each)
+
+local Screen = require('test.functional.ui.screen')
+local call = helpers.call
+local clear = helpers.clear
+local feed = helpers.feed
+local feed_command = helpers.feed_command
+local funcs = helpers.funcs
+local meths = helpers.meths
+local eq = helpers.eq
+
+describe('visual line mode', function()
+ local screen
+
+ it('redraws properly after scrolling with matchparen loaded and scrolloff=1', function()
+ clear{args={'-u', 'NORC'}}
+ screen = Screen.new(30, 7)
+ screen:attach()
+ screen:set_default_attr_ids({
+ [1] = {bold = true},
+ [2] = {background = Screen.colors.LightGrey},
+ })
+
+ eq(1, meths.get_var('loaded_matchparen'))
+ feed_command('set scrolloff=1')
+ funcs.setline(1, {'a', 'b', 'c', 'd', 'e', '', '{', '}', '{', 'f', 'g', '}'})
+ call('cursor', 5, 1)
+
+ feed('V<c-d><c-d>')
+ screen:expect([[
+ {2:{} |
+ {2:}} |
+ {2:{} |
+ {2:f} |
+ ^g |
+ } |
+ {1:-- VISUAL LINE --} |
+ ]])
+ end)
+end)