mirror of
https://github.com/neovim/neovim.git
synced 2025-12-16 03:15:39 +00:00
fix(tests): needing two calls to setup a screen is cringe
Before calling "attach" a screen object is just a dummy container for (row, col) values whose purpose is to be sent as part of the "attach" function call anyway. Just create the screen in an attached state directly. Keep the complete (row, col, options) config together. It is still completely valid to later detach and re-attach as needed, including to another session.
This commit is contained in:
@@ -55,7 +55,6 @@ describe('insert-mode', function()
|
||||
|
||||
it('double quote is removed after hit-enter prompt #22609', function()
|
||||
local screen = Screen.new(50, 6)
|
||||
screen:attach()
|
||||
feed('i<C-R>')
|
||||
screen:expect([[
|
||||
{18:^"} |
|
||||
@@ -180,7 +179,6 @@ describe('insert-mode', function()
|
||||
|
||||
it('multi-char mapping updates screen properly #25626', function()
|
||||
local screen = Screen.new(60, 6)
|
||||
screen:attach()
|
||||
command('vnew')
|
||||
insert('foo\nfoo\nfoo')
|
||||
command('wincmd w')
|
||||
@@ -228,8 +226,7 @@ describe('insert-mode', function()
|
||||
end
|
||||
|
||||
it('works with tabs and spaces', function()
|
||||
local screen = Screen.new(30, 2)
|
||||
screen:attach()
|
||||
local _ = Screen.new(30, 2)
|
||||
command('setl ts=4 sw=4')
|
||||
set_lines(0, 1, '\t' .. s(4) .. '\t' .. s(9) .. '\t a')
|
||||
feed('$i')
|
||||
@@ -246,8 +243,7 @@ describe('insert-mode', function()
|
||||
end)
|
||||
|
||||
it('works with varsofttabstop', function()
|
||||
local screen = Screen.new(30, 2)
|
||||
screen:attach()
|
||||
local _ = Screen.new(30, 2)
|
||||
command('setl vsts=6,2,5,3')
|
||||
set_lines(0, 1, 'a\t' .. s(4) .. '\t a')
|
||||
feed('$i')
|
||||
@@ -263,8 +259,7 @@ describe('insert-mode', function()
|
||||
end)
|
||||
|
||||
it('works with tab as ^I', function()
|
||||
local screen = Screen.new(30, 2)
|
||||
screen:attach()
|
||||
local _ = Screen.new(30, 2)
|
||||
command('set list listchars=space:.')
|
||||
command('setl ts=4 sw=4')
|
||||
set_lines(0, 1, '\t' .. s(4) .. '\t' .. s(9) .. '\t a')
|
||||
@@ -280,8 +275,7 @@ describe('insert-mode', function()
|
||||
end)
|
||||
|
||||
it('works in replace mode', function()
|
||||
local screen = Screen.new(50, 2)
|
||||
screen:attach()
|
||||
local _ = Screen.new(50, 2)
|
||||
command('setl ts=8 sw=8 sts=8')
|
||||
set_lines(0, 1, '\t' .. s(4) .. '\t' .. s(9) .. '\t a')
|
||||
feed('$R')
|
||||
@@ -296,8 +290,7 @@ describe('insert-mode', function()
|
||||
end)
|
||||
|
||||
it('works with breakindent', function()
|
||||
local screen = Screen.new(17, 4)
|
||||
screen:attach()
|
||||
local _ = Screen.new(17, 4)
|
||||
command('setl ts=4 sw=4 bri briopt=min:5')
|
||||
set_lines(0, 1, '\t' .. s(4) .. '\t' .. s(9) .. '\t a')
|
||||
feed('$i')
|
||||
@@ -314,8 +307,7 @@ describe('insert-mode', function()
|
||||
end)
|
||||
|
||||
it('works with inline virtual text', function()
|
||||
local screen = Screen.new(50, 2)
|
||||
screen:attach()
|
||||
local _ = Screen.new(50, 2)
|
||||
command('setl ts=4 sw=4')
|
||||
set_lines(0, 1, '\t' .. s(4) .. '\t' .. s(9) .. '\t a')
|
||||
local ns = api.nvim_create_namespace('')
|
||||
@@ -335,8 +327,7 @@ describe('insert-mode', function()
|
||||
end)
|
||||
|
||||
it("works with 'revins'", function()
|
||||
local screen = Screen.new(30, 3)
|
||||
screen:attach()
|
||||
local _ = Screen.new(30, 3)
|
||||
command('setl ts=4 sw=4 revins')
|
||||
set_lines(0, 1, ('a'):rep(16), s(3) .. '\t' .. s(4) .. '\t a')
|
||||
feed('j$i')
|
||||
@@ -354,7 +345,6 @@ describe('insert-mode', function()
|
||||
|
||||
it('backspace after replacing multibyte chars', function()
|
||||
local screen = Screen.new(30, 3)
|
||||
screen:attach()
|
||||
api.nvim_buf_set_lines(0, 0, -1, true, { 'test ȧ̟̜̝̅̚m̆̉̐̐̇̈ å' })
|
||||
feed('^Rabcdefghi')
|
||||
screen:expect([[
|
||||
|
||||
Reference in New Issue
Block a user