mirror of
https://github.com/neovim/neovim.git
synced 2024-12-29 14:41:06 -07:00
e61228a214
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.
49 lines
1.1 KiB
Lua
49 lines
1.1 KiB
Lua
local n = require('test.functional.testnvim')()
|
|
local Screen = require('test.functional.ui.screen')
|
|
|
|
local clear = n.clear
|
|
local command = n.command
|
|
local feed = n.feed
|
|
|
|
describe('update_menu notification', function()
|
|
local screen
|
|
|
|
before_each(function()
|
|
clear()
|
|
screen = Screen.new()
|
|
end)
|
|
|
|
local function expect_sent(expected)
|
|
screen:expect {
|
|
condition = function()
|
|
if screen.update_menu ~= expected then
|
|
if expected then
|
|
error('update_menu was expected but not sent')
|
|
else
|
|
error('update_menu was sent unexpectedly')
|
|
end
|
|
end
|
|
end,
|
|
unchanged = not expected,
|
|
}
|
|
end
|
|
|
|
it('should be sent when adding a menu', function()
|
|
command('menu Test.Test :')
|
|
expect_sent(true)
|
|
end)
|
|
|
|
it('should be sent when deleting a menu', function()
|
|
command('menu Test.Test :')
|
|
screen.update_menu = false
|
|
|
|
command('unmenu Test.Test')
|
|
expect_sent(true)
|
|
end)
|
|
|
|
it('should not be sent unnecessarily', function()
|
|
feed('i12345<ESC>:redraw<CR>')
|
|
expect_sent(false)
|
|
end)
|
|
end)
|