1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145
|
local t = require('test.testutil')
local n = require('test.functional.testnvim')()
local Screen = require('test.functional.ui.screen')
local clear = n.clear
local command = n.command
local eq = t.eq
local neq = t.neq
local feed = n.feed
local eval = n.eval
local exec = n.exec
local fn = n.fn
local api = n.api
local curwin = n.api.nvim_get_current_win
local assert_alive = n.assert_alive
describe('tabpage', function()
before_each(clear)
it('advances to the next page via <C-W>gt', function()
-- add some tabpages
command('tabnew')
command('tabnew')
command('tabnew')
eq(4, eval('tabpagenr()'))
feed('<C-W>gt')
eq(1, eval('tabpagenr()'))
end)
it('retreats to the previous page via <C-W>gT', function()
-- add some tabpages
command('tabnew')
command('tabnew')
command('tabnew')
eq(4, eval('tabpagenr()'))
feed('<C-W>gT')
eq(3, eval('tabpagenr()'))
end)
it('does not crash or loop 999 times if BufWipeout autocommand switches window #17868', function()
exec([[
tabedit
let s:window_id = win_getid()
botright new
setlocal bufhidden=wipe
let g:win_closed = 0
autocmd WinClosed * let g:win_closed += 1
autocmd BufWipeout <buffer> call win_gotoid(s:window_id)
tabprevious
+tabclose
]])
neq(999, eval('g:win_closed'))
end)
it('no segfault with strange WinClosed autocommand #20290', function()
pcall(
exec,
[[
set nohidden
edit Xa
split Xb
tab split
new
autocmd WinClosed * tabprev | bwipe!
close
]]
)
assert_alive()
end)
it('nvim_win_close and nvim_win_hide update tabline #20285', function()
eq(1, #api.nvim_list_tabpages())
eq({ 1, 1 }, fn.win_screenpos(0))
local win1 = curwin()
command('tabnew')
eq(2, #api.nvim_list_tabpages())
eq({ 2, 1 }, fn.win_screenpos(0))
local win2 = curwin()
api.nvim_win_close(win1, true)
eq(win2, curwin())
eq(1, #api.nvim_list_tabpages())
eq({ 1, 1 }, fn.win_screenpos(0))
command('tabnew')
eq(2, #api.nvim_list_tabpages())
eq({ 2, 1 }, fn.win_screenpos(0))
local win3 = curwin()
api.nvim_win_hide(win2)
eq(win3, curwin())
eq(1, #api.nvim_list_tabpages())
eq({ 1, 1 }, fn.win_screenpos(0))
end)
it('switching tabpage after setting laststatus=3 #19591', function()
local screen = Screen.new(40, 8)
screen:add_extra_attr_ids {
[100] = { bold = true, foreground = Screen.colors.Fuchsia },
}
command('tabnew')
command('tabprev')
command('set laststatus=3')
command('tabnext')
feed('<C-G>')
screen:expect([[
{24: [No Name] }{5: [No Name] }{2: }{24:X}|
^ |
{1:~ }|*4
{3:[No Name] }|
"[No Name]" --No lines in buffer-- |
]])
command('vnew')
screen:expect([[
{24: [No Name] }{5: }{100:2}{5: [No Name] }{2: }{24:X}|
^ │ |
{1:~ }│{1:~ }|*4
{3:[No Name] }|
"[No Name]" --No lines in buffer-- |
]])
end)
it(':tabmove handles modifiers and addr', function()
command('tabnew | tabnew | tabnew')
eq(4, fn.nvim_tabpage_get_number(0))
command(' silent :keepalt :: ::: silent! - tabmove')
eq(3, fn.nvim_tabpage_get_number(0))
command(' silent :keepalt :: ::: silent! -2 tabmove')
eq(1, fn.nvim_tabpage_get_number(0))
end)
it(':tabs does not overflow IObuff with long path with comma #20850', function()
api.nvim_buf_set_name(0, ('x'):rep(1024) .. ',' .. ('x'):rep(1024))
command('tabs')
assert_alive()
end)
end)
|