aboutsummaryrefslogtreecommitdiff
path: root/src/nvim/testdir
diff options
context:
space:
mode:
authorJosh Rahm <joshuarahm@gmail.com>2022-08-07 16:01:34 -0600
committerJosh Rahm <joshuarahm@gmail.com>2022-08-07 16:01:34 -0600
commita5f27a311fb28797a72b8aa16ec7122c5a1b15e4 (patch)
tree3732f7339e29431f31310aef6ffc802cf4f6255d /src/nvim/testdir
parent6c909fedc924d9f4257aa204b0168c6177cc5d28 (diff)
parent629169462a82f0fbb7a8911a4554894537d6776c (diff)
downloadrneovim-a5f27a311fb28797a72b8aa16ec7122c5a1b15e4.tar.gz
rneovim-a5f27a311fb28797a72b8aa16ec7122c5a1b15e4.tar.bz2
rneovim-a5f27a311fb28797a72b8aa16ec7122c5a1b15e4.zip
Merge branch 'master' of https://github.com/neovim/neovim into rahm
Diffstat (limited to 'src/nvim/testdir')
-rw-r--r--src/nvim/testdir/setup.vim4
-rw-r--r--src/nvim/testdir/test_alot.vim1
-rw-r--r--src/nvim/testdir/test_menu.vim420
-rw-r--r--src/nvim/testdir/test_normal.vim3
-rw-r--r--src/nvim/testdir/test_options.vim2
-rw-r--r--src/nvim/testdir/test_popup.vim22
-rw-r--r--src/nvim/testdir/test_tabpage.vim46
7 files changed, 463 insertions, 35 deletions
diff --git a/src/nvim/testdir/setup.vim b/src/nvim/testdir/setup.vim
index 9d6fc5e526..6bc3607b69 100644
--- a/src/nvim/testdir/setup.vim
+++ b/src/nvim/testdir/setup.vim
@@ -39,9 +39,11 @@ if exists('s:did_load')
endif
let s:did_load = 1
-" Clear Nvim default mappings.
+" Clear Nvim default mappings and menus.
mapclear
mapclear!
+aunmenu *
+tlunmenu *
" Prevent Nvim log from writing to stderr.
let $NVIM_LOG_FILE = exists($NVIM_LOG_FILE) ? $NVIM_LOG_FILE : 'Xnvim.log'
diff --git a/src/nvim/testdir/test_alot.vim b/src/nvim/testdir/test_alot.vim
index 966b8ef571..a83ef50abc 100644
--- a/src/nvim/testdir/test_alot.vim
+++ b/src/nvim/testdir/test_alot.vim
@@ -16,7 +16,6 @@ source test_ga.vim
source test_glob2regpat.vim
source test_global.vim
source test_lispwords.vim
-source test_menu.vim
source test_move.vim
source test_put.vim
source test_reltime.vim
diff --git a/src/nvim/testdir/test_menu.vim b/src/nvim/testdir/test_menu.vim
index 4af75be514..75992d3313 100644
--- a/src/nvim/testdir/test_menu.vim
+++ b/src/nvim/testdir/test_menu.vim
@@ -19,6 +19,48 @@ func Test_load_menu()
call assert_equal('', v:errmsg)
endfunc
+func Test_buffer_menu_special_buffers()
+ " Load in runtime menus
+ try
+ source $VIMRUNTIME/menu.vim
+ catch
+ call assert_report('error while loading menus: ' . v:exception)
+ endtry
+
+ let v:errmsg = ''
+ doautocmd LoadBufferMenu VimEnter
+ call assert_equal('', v:errmsg)
+
+ let orig_buffer_menus = execute("nmenu Buffers")
+
+ " Test that regular new buffer results in a new buffer menu item.
+ new
+ let new_buffer_menus = execute('nmenu Buffers')
+ call assert_equal(len(split(orig_buffer_menus, "\n")) + 2, len(split(new_buffer_menus, "\n")))
+ bwipe!
+ call assert_equal(orig_buffer_menus, execute("nmenu Buffers"))
+
+ " Make a new command-line window, test that it does not create a new buffer
+ " menu.
+ call feedkeys("q::let cmdline_buffer_menus=execute('nmenu Buffers')\<CR>:q\<CR>", 'ntx')
+ call assert_equal(len(split(orig_buffer_menus, "\n")) + 2, len(split(cmdline_buffer_menus, "\n")))
+ call assert_equal(orig_buffer_menus, execute("nmenu Buffers"))
+
+ if has('terminal')
+ " Open a terminal window and test that it does not create a buffer menu
+ " item.
+ terminal
+ let term_buffer_menus = execute('nmenu Buffers')
+ call assert_equal(len(split(orig_buffer_menus, "\n")) + 2, len(split(term_buffer_menus, "\n")))
+ bwipe!
+ call assert_equal(orig_buffer_menus, execute("nmenu Buffers"))
+ endif
+
+ " Remove menus to clean up
+ source $VIMRUNTIME/delmenu.vim
+ call assert_equal('', v:errmsg)
+endfunc
+
func Test_translate_menu()
if !has('multi_lang')
return
@@ -89,9 +131,39 @@ func Test_menu_commands()
unlet g:did_menu
endfun
+" Test various menu related errors
+func Test_menu_errors()
+ menu Test.Foo :version<CR>
+
+ " Error cases
+ call assert_fails('menu .Test.Foo :ls<CR>', 'E475:')
+ call assert_fails('menu Test. :ls<CR>', 'E330:')
+ call assert_fails('menu Foo. :ls<CR>', 'E331:')
+ call assert_fails('unmenu Test.Foo abc', 'E488:')
+ call assert_fails('menu <Tab>:ls :ls<CR>', 'E792:')
+ call assert_fails('menu Test.<Tab>:ls :ls<CR>', 'E792:')
+ call assert_fails('menu Test.Foo.Bar :ls<CR>', 'E327:')
+ call assert_fails('menu Test.-Sep-.Baz :ls<CR>', 'E332:')
+ call assert_fails('menu Foo.Bar.--.Baz :ls<CR>', 'E332:')
+ call assert_fails('menu disable Test.Foo.Bar', 'E327:')
+ call assert_fails('menu disable T.Foo', 'E329:')
+ call assert_fails('unmenu Test.Foo.Bar', 'E327:')
+ call assert_fails('cunmenu Test.Foo', 'E328:')
+ call assert_fails('unmenu Test.Bar', 'E329:')
+ call assert_fails('menu Test.Foo.Bar', 'E327:')
+ call assert_fails('cmenu Test.Foo', 'E328:')
+ call assert_fails('emenu x Test.Foo', 'E475:')
+ call assert_fails('emenu Test.Foo.Bar', 'E334:')
+ call assert_fails('menutranslate Test', 'E474:')
+
+ silent! unmenu Foo
+ unmenu Test
+endfunc
+
" Test for menu item completion in command line
func Test_menu_expand()
" Create the menu itmes for test
+ menu Dummy.Nothing lll
for i in range(1, 4)
let m = 'menu Xmenu.A' .. i .. '.A' .. i
for j in range(1, 4)
@@ -117,10 +189,356 @@ func Test_menu_expand()
" Test for <Up> to go up a menu
call feedkeys(":emenu Xmenu.A\<Tab>\<Down>\<Up>\<Up>\<Up>" ..
\ "\<C-A>\<C-B>\"\<CR>", 'xt')
- call assert_equal('"emenu Buffers. Xmenu.', @:)
+ call assert_equal('"emenu Dummy. Xmenu.', @:)
+
+ " Test for expanding only submenus
+ call feedkeys(":popup Xmenu.\<C-A>\<C-B>\"\<CR>", 'xt')
+ call assert_equal('"popup Xmenu.A1 A2 A3 A4', @:)
+
+ " Test for expanding menus after enable/disable
+ call feedkeys(":menu enable Xmenu.\<C-A>\<C-B>\"\<CR>", 'xt')
+ call assert_equal('"menu enable Xmenu.A1. A2. A3. A4.', @:)
+ call feedkeys(":menu disable Xmenu.\<C-A>\<C-B>\"\<CR>", 'xt')
+ call assert_equal('"menu disable Xmenu.A1. A2. A3. A4.', @:)
+
+ " Test for expanding non-existing menu path
+ call feedkeys(":menu xyz.\<C-A>\<C-B>\"\<CR>", 'xt')
+ call assert_equal('"menu xyz.', @:)
+ call feedkeys(":menu Xmenu.A1.A1B1.xyz.\<C-A>\<C-B>\"\<CR>", 'xt')
+ call assert_equal('"menu Xmenu.A1.A1B1.xyz.', @:)
set wildmenu&
unmenu Xmenu
+ unmenu Dummy
+
+ " Test for expanding popup menus with some hidden items
+ menu Xmenu.foo.A1 a1
+ menu Xmenu.]bar bar
+ menu Xmenu.]baz.B1 b1
+ menu Xmenu.-sep- :
+ call feedkeys(":popup Xmenu.\<C-A>\<C-B>\"\<CR>", 'xt')
+ call assert_equal('"popup Xmenu.foo', @:)
+ unmenu Xmenu
+endfunc
+
+" Test for the menu_info() function
+func Test_menu_info()
+ " Define menus with various attributes
+ 10nnoremenu 10.10 T&est.F&oo :echo 'foo'<CR>
+ 10nmenu <silent> 10.20 T&est.B&ar<Tab>:bar :echo 'bar'<CR>
+ 10nmenu <script> 10.30.5 T&est.Ba&z.Qu&x :echo 'qux'<CR>
+
+ let d = #{name: "B&ar\t:bar", display: 'Bar', modes: 'n', shortcut: 'a',
+ \ accel: ':bar', priority: 20, enabled: v:true, silent: v:true,
+ \ noremenu: v:false, script: v:false, rhs: ":echo 'bar'<CR>"}
+ call assert_equal(d, menu_info('Test.Bar'))
+
+ let d = #{name: 'Ba&z', display: 'Baz', modes: 'n', shortcut: 'z',
+ \ priority: 30, submenus: ['Qux']}
+ call assert_equal(d, menu_info('Test.Baz'))
+
+ let d = #{name: 'T&est', display: 'Test', modes: 'n', shortcut: 'e',
+ \ priority: 10, submenus: ['Foo', 'Bar', 'Baz']}
+ call assert_equal(d, menu_info('Test'))
+ call assert_equal({}, menu_info('Test.Dummy'))
+ call assert_equal({}, menu_info('Dummy'))
+
+ nmenu disable Test.Foo
+ call assert_equal(v:false, menu_info('Test.Foo').enabled)
+ nmenu enable Test.Foo
+ call assert_equal(v:true, menu_info('Test.Foo').enabled)
+
+ call assert_equal(menu_info('Test.Foo'), menu_info('Test.Foo', ''))
+ nmenu Test.abc <Nop>
+ call assert_equal('<Nop>', menu_info('Test.abc').rhs)
+ call assert_fails('call menu_info([])', 'E730:')
+ nunmenu Test
+
+ " Test for defining menus in different modes
+ menu Test.menu :menu<CR>
+ menu! Test.menu! :menu!<CR>
+ amenu Test.amenu :amenu<CR>
+ nmenu Test.nmenu :nmenu<CR>
+ omenu Test.omenu :omenu<CR>
+ vmenu Test.vmenu :vmenu<CR>
+ xmenu Test.xmenu :xmenu<CR>
+ smenu Test.smenu :smenu<CR>
+ imenu <silent> <script> Test.imenu :imenu<CR>
+ cmenu Test.cmenu :cmenu<CR>
+ tlmenu Test.tlmenu :tlmenu<CR>
+ tmenu Test.nmenu Normal mode menu
+ tmenu Test.omenu Op-pending mode menu
+ noremenu Test.noremenu :noremenu<CR>
+ noremenu! Test.noremenu! :noremenu!<CR>
+ anoremenu Test.anoremenu :anoremenu<CR>
+ nnoremenu Test.nnoremenu :nnoremenu<CR>
+ onoremenu Test.onoremenu :onoremenu<CR>
+ vnoremenu Test.vnoremenu :vnoremenu<CR>
+ xnoremenu Test.xnoremenu :xnoremenu<CR>
+ snoremenu Test.snoremenu :snoremenu<CR>
+ inoremenu <silent> Test.inoremenu :inoremenu<CR>
+ cnoremenu Test.cnoremenu :cnoremenu<CR>
+ tlnoremenu Test.tlnoremenu :tlnoremenu<CR>
+ call assert_equal(#{name: 'menu', priority: 500, shortcut: '',
+ \ display: 'menu', modes: ' ', enabled: v:true, silent: v:false,
+ \ rhs: ":menu<CR>", noremenu: v:false, script: v:false},
+ \ menu_info('Test.menu'))
+ call assert_equal(#{name: 'menu!', priority: 500, shortcut: '',
+ \ display: 'menu!', modes: '!', enabled: v:true, silent: v:false,
+ \ rhs: ":menu!<CR>", noremenu: v:false, script: v:false},
+ \ menu_info('Test.menu!', '!'))
+ call assert_equal(#{name: 'amenu', priority: 500, shortcut: '',
+ \ display: 'amenu', modes: 'a', enabled: v:true, silent: v:false,
+ \ rhs: ":amenu<CR>", noremenu: v:false, script: v:false},
+ \ menu_info('Test.amenu', 'a'))
+ call assert_equal(#{name: 'nmenu', priority: 500, shortcut: '',
+ \ display: 'nmenu', modes: 'n', enabled: v:true, silent: v:false,
+ \ rhs: ':nmenu<CR>', noremenu: v:false, script: v:false},
+ \ menu_info('Test.nmenu', 'n'))
+ call assert_equal(#{name: 'omenu', priority: 500, shortcut: '',
+ \ display: 'omenu', modes: 'o', enabled: v:true, silent: v:false,
+ \ rhs: ':omenu<CR>', noremenu: v:false, script: v:false},
+ \ menu_info('Test.omenu', 'o'))
+ call assert_equal(#{name: 'vmenu', priority: 500, shortcut: '',
+ \ display: 'vmenu', modes: 'v', enabled: v:true, silent: v:false,
+ \ rhs: ':vmenu<CR>', noremenu: v:false, script: v:false},
+ \ menu_info('Test.vmenu', 'v'))
+ call assert_equal(#{name: 'xmenu', priority: 500, shortcut: '',
+ \ display: 'xmenu', modes: 'x', enabled: v:true, silent: v:false,
+ \ rhs: ':xmenu<CR>', noremenu: v:false, script: v:false},
+ \ menu_info('Test.xmenu', 'x'))
+ call assert_equal(#{name: 'smenu', priority: 500, shortcut: '',
+ \ display: 'smenu', modes: 's', enabled: v:true, silent: v:false,
+ \ rhs: ':smenu<CR>', noremenu: v:false, script: v:false},
+ \ menu_info('Test.smenu', 's'))
+ call assert_equal(#{name: 'imenu', priority: 500, shortcut: '',
+ \ display: 'imenu', modes: 'i', enabled: v:true, silent: v:true,
+ \ rhs: ':imenu<CR>', noremenu: v:false, script: v:true},
+ \ menu_info('Test.imenu', 'i'))
+ call assert_equal(#{ name: 'cmenu', priority: 500, shortcut: '',
+ \ display: 'cmenu', modes: 'c', enabled: v:true, silent: v:false,
+ \ rhs: ':cmenu<CR>', noremenu: v:false, script: v:false},
+ \ menu_info('Test.cmenu', 'c'))
+ call assert_equal(#{name: 'tlmenu', priority: 500, shortcut: '',
+ \ display: 'tlmenu', modes: 'tl', enabled: v:true, silent: v:false,
+ \ rhs: ':tlmenu<CR>', noremenu: v:false, script: v:false},
+ \ menu_info('Test.tlmenu', 'tl'))
+ call assert_equal(#{name: 'noremenu', priority: 500, shortcut: '',
+ \ display: 'noremenu', modes: ' ', enabled: v:true, silent: v:false,
+ \ rhs: ":noremenu<CR>", noremenu: v:true, script: v:false},
+ \ menu_info('Test.noremenu'))
+ call assert_equal(#{name: 'noremenu!', priority: 500, shortcut: '',
+ \ display: 'noremenu!', modes: '!', enabled: v:true, silent: v:false,
+ \ rhs: ":noremenu!<CR>", noremenu: v:true, script: v:false},
+ \ menu_info('Test.noremenu!', '!'))
+ call assert_equal(#{name: 'anoremenu', priority: 500, shortcut: '',
+ \ display: 'anoremenu', modes: 'a', enabled: v:true, silent: v:false,
+ \ rhs: ":anoremenu<CR>", noremenu: v:true, script: v:false},
+ \ menu_info('Test.anoremenu', 'a'))
+ call assert_equal(#{name: 'nnoremenu', priority: 500, shortcut: '',
+ \ display: 'nnoremenu', modes: 'n', enabled: v:true, silent: v:false,
+ \ rhs: ':nnoremenu<CR>', noremenu: v:true, script: v:false},
+ \ menu_info('Test.nnoremenu', 'n'))
+ call assert_equal(#{name: 'onoremenu', priority: 500, shortcut: '',
+ \ display: 'onoremenu', modes: 'o', enabled: v:true, silent: v:false,
+ \ rhs: ':onoremenu<CR>', noremenu: v:true, script: v:false},
+ \ menu_info('Test.onoremenu', 'o'))
+ call assert_equal(#{name: 'vnoremenu', priority: 500, shortcut: '',
+ \ display: 'vnoremenu', modes: 'v', enabled: v:true, silent: v:false,
+ \ rhs: ':vnoremenu<CR>', noremenu: v:true, script: v:false},
+ \ menu_info('Test.vnoremenu', 'v'))
+ call assert_equal(#{name: 'xnoremenu', priority: 500, shortcut: '',
+ \ display: 'xnoremenu', modes: 'x', enabled: v:true, silent: v:false,
+ \ rhs: ':xnoremenu<CR>', noremenu: v:true, script: v:false},
+ \ menu_info('Test.xnoremenu', 'x'))
+ call assert_equal(#{name: 'snoremenu', priority: 500, shortcut: '',
+ \ display: 'snoremenu', modes: 's', enabled: v:true, silent: v:false,
+ \ rhs: ':snoremenu<CR>', noremenu: v:true, script: v:false},
+ \ menu_info('Test.snoremenu', 's'))
+ call assert_equal(#{name: 'inoremenu', priority: 500, shortcut: '',
+ \ display: 'inoremenu', modes: 'i', enabled: v:true, silent: v:true,
+ \ rhs: ':inoremenu<CR>', noremenu: v:true, script: v:false},
+ \ menu_info('Test.inoremenu', 'i'))
+ call assert_equal(#{ name: 'cnoremenu', priority: 500, shortcut: '',
+ \ display: 'cnoremenu', modes: 'c', enabled: v:true, silent: v:false,
+ \ rhs: ':cnoremenu<CR>', noremenu: v:true, script: v:false},
+ \ menu_info('Test.cnoremenu', 'c'))
+ call assert_equal(#{name: 'tlnoremenu', priority: 500, shortcut: '',
+ \ display: 'tlnoremenu', modes: 'tl', enabled: v:true, silent: v:false,
+ \ rhs: ':tlnoremenu<CR>', noremenu: v:true, script: v:false},
+ \ menu_info('Test.tlnoremenu', 'tl'))
+
+ " Test for getting all the top-level menu names
+ call assert_notequal(menu_info('').submenus, [])
+
+ aunmenu Test
+ tlunmenu Test
+ call assert_equal({}, menu_info('Test'))
+ call assert_equal({}, menu_info('Test', '!'))
+ call assert_equal({}, menu_info('Test', 'a'))
+ call assert_equal({}, menu_info('Test', 'n'))
+ call assert_equal({}, menu_info('Test', 'o'))
+ call assert_equal({}, menu_info('Test', 'v'))
+ call assert_equal({}, menu_info('Test', 'x'))
+ call assert_equal({}, menu_info('Test', 's'))
+ call assert_equal({}, menu_info('Test', 'i'))
+ call assert_equal({}, menu_info('Test', 'c'))
+ call assert_equal({}, menu_info('Test', 't'))
+ call assert_equal({}, menu_info('Test', 'tl'))
+
+ amenu Test.amenu :amenu<CR>
+ call assert_equal(':amenu<CR>', menu_info('Test.amenu', '').rhs)
+ call assert_equal('<C-\><C-O>:amenu<CR>', menu_info('Test.amenu', '!').rhs)
+ call assert_equal(':amenu<CR>', menu_info('Test.amenu', 'n').rhs)
+ call assert_equal('<C-C>:amenu<CR><C-\><C-G>',
+ \ menu_info('Test.amenu', 'o').rhs)
+ call assert_equal('<C-C>:amenu<CR><C-\><C-G>',
+ \ menu_info('Test.amenu', 'v').rhs)
+ call assert_equal('<C-C>:amenu<CR><C-\><C-G>',
+ \ menu_info('Test.amenu', 'x').rhs)
+ call assert_equal('<C-C>:amenu<CR><C-\><C-G>',
+ \ menu_info('Test.amenu', 's').rhs)
+ call assert_equal('<C-\><C-O>:amenu<CR>', menu_info('Test.amenu', 'i').rhs)
+ call assert_equal('<C-C>:amenu<CR><C-\><C-G>',
+ \ menu_info('Test.amenu', 'c').rhs)
+ aunmenu Test.amenu
+
+ " Test for hidden menus
+ menu ]Test.menu :menu<CR>
+ call assert_equal(#{name: ']Test', display: ']Test', priority: 500,
+ \ shortcut: '', modes: ' ', submenus: ['menu']},
+ \ menu_info(']Test'))
+ unmenu ]Test
+endfunc
+
+" Test for <special> keyword in a menu with 'cpo' containing '<'
+func Test_menu_special()
+ throw 'Skipped: Nvim does not support cpoptions flag "<"'
+ new
+ set cpo+=<
+ nmenu Test.Sign am<Tab>n<Esc>
+ call feedkeys(":emenu n Test.Sign\<CR>", 'x')
+ call assert_equal("m<Tab>n<Esc>", getline(1))
+ nunmenu Test.Sign
+ nmenu <special> Test.Sign am<Tab>n<Esc>
+ call setline(1, '')
+ call feedkeys(":emenu n Test.Sign\<CR>", 'x')
+ call assert_equal("m\tn", getline(1))
+ set cpo-=<
+ close!
+ nunmenu Test.Sign
+endfunc
+
+" Test for "icon=filname" in a toolbar
+func Test_menu_icon()
+ CheckFeature toolbar
+ nmenu icon=myicon.xpm Toolbar.Foo :echo "Foo"<CR>
+ call assert_equal('myicon.xpm', "Toolbar.Foo"->menu_info().icon)
+ nunmenu Toolbar.Foo
+
+ " Test for using the builtin icon
+ amenu ToolBar.BuiltIn22 :echo "BuiltIn22"<CR>
+ call assert_equal(#{name: 'BuiltIn22', display: 'BuiltIn22',
+ \ enabled: v:true, shortcut: '', modes: 'a', script: v:false,
+ \ iconidx: 22, priority: 500, silent: v:false,
+ \ rhs: ':echo "BuiltIn22"<CR>', noremenu: v:false},
+ \ menu_info("ToolBar.BuiltIn22"))
+ aunmenu ToolBar.BuiltIn22
+endfunc
+
+" Test for ":emenu" command in different modes
+func Test_emenu_cmd()
+ new
+ xmenu Test.foo rx
+ call setline(1, ['aaaa', 'bbbb'])
+ normal ggVj
+ %emenu Test.foo
+ call assert_equal(['xxxx', 'xxxx'], getline(1, 2))
+ call setline(1, ['aaaa', 'bbbb'])
+ exe "normal ggVj\<Esc>"
+ %emenu Test.foo
+ call assert_equal(['xxxx', 'xxxx'], getline(1, 2))
+ call setline(1, ['aaaa', 'bbbb'])
+ exe "normal ggV\<Esc>"
+ 2emenu Test.foo
+ call assert_equal(['aaaa', 'xxxx'], getline(1, 2))
+ xunmenu Test.foo
+ close!
+endfunc
+
+" Test for PopUp menus
+func Test_popup_menu()
+ 20menu PopUp.foo :echo 'foo'<CR>
+ 20menu PopUp.bar :echo 'bar'<CR>
+ call assert_equal(#{name: 'PopUp', display: 'PopUp', priority: 20,
+ \ shortcut: '', modes: ' ', submenus: ['foo', 'bar']},
+ \ menu_info('PopUp'))
+ menu disable PopUp.bar
+ call assert_equal(v:true, "PopUp.foo"->menu_info().enabled)
+ call assert_equal(v:false, "PopUp.bar"->menu_info().enabled)
+ menu enable PopUp.bar
+ call assert_equal(v:true, "PopUp.bar"->menu_info().enabled)
+ unmenu PopUp
+endfunc
+
+" Test for listing the menus using the :menu command
+func Test_show_menus()
+ " In the GUI, tear-off menu items are present in the output below
+ " So skip this test
+ CheckNotGui
+ aunmenu *
+ call assert_equal(['--- Menus ---'], split(execute('menu'), "\n"))
+ nmenu <script> 200.10 Test.nmenu1 :nmenu1<CR>
+ nmenu 200.20 Test.nmenu2 :nmenu2<CR>
+ nnoremenu 200.30 Test.nmenu3 :nmenu3<CR>
+ nmenu 200.40 Test.nmenu4 :nmenu4<CR>
+ nmenu 200.50 disable Test.nmenu4
+ let exp =<< trim [TEXT]
+ --- Menus ---
+ 200 Test
+ 10 nmenu1
+ n& :nmenu1<CR>
+ 20 nmenu2
+ n :nmenu2<CR>
+ 30 nmenu3
+ n* :nmenu3<CR>
+ 40 nmenu4
+ n - :nmenu4<CR>
+ [TEXT]
+ call assert_equal(exp, split(execute('nmenu'), "\n"))
+ nunmenu Test
+endfunc
+
+" Test for menu tips
+func Test_tmenu()
+ tunmenu *
+ call assert_equal(['--- Menus ---'], split(execute('tmenu'), "\n"))
+ tmenu Test.nmenu1 nmenu1
+ tmenu Test.nmenu2.sub1 nmenu2.sub1
+ let exp =<< trim [TEXT]
+ --- Menus ---
+ 500 Test
+ 500 nmenu1
+ t - nmenu1
+ 500 nmenu2
+ 500 sub1
+ t - nmenu2.sub1
+ [TEXT]
+ call assert_equal(exp, split(execute('tmenu'), "\n"))
+ tunmenu Test
+endfunc
+
+func Test_only_modifier()
+ exe "tmenu a.b \x80\xfc0"
+ let exp =<< trim [TEXT]
+ --- Menus ---
+ 500 a
+ 500 b
+ t - <T-2-^@>
+ [TEXT]
+ call assert_equal(exp, split(execute('tmenu'), "\n"))
+
+ tunmenu a.b
endfunc
" vim: shiftwidth=2 sts=2 expandtab
diff --git a/src/nvim/testdir/test_normal.vim b/src/nvim/testdir/test_normal.vim
index f18ddb274c..7cb70aa2af 100644
--- a/src/nvim/testdir/test_normal.vim
+++ b/src/nvim/testdir/test_normal.vim
@@ -1975,7 +1975,8 @@ func Test_normal31_r_cmd()
" using CTRL-Y and CTRL-E.
" Different code paths are used for utf-8 and latin1 encodings
set showmatch
- for enc in ['latin1', 'utf-8']
+ " for enc in ['latin1', 'utf-8']
+ for enc in ['utf-8']
enew!
let &encoding = enc
call setline(1, [' {a}', 'xxxxxxxxxx', ' [b]'])
diff --git a/src/nvim/testdir/test_options.vim b/src/nvim/testdir/test_options.vim
index c5b1266689..b10f0f5030 100644
--- a/src/nvim/testdir/test_options.vim
+++ b/src/nvim/testdir/test_options.vim
@@ -310,6 +310,7 @@ func Test_set_errors()
call assert_fails('set sidescroll=-1', 'E487:')
call assert_fails('set tabstop=-1', 'E487:')
call assert_fails('set tabstop=10000', 'E474:')
+ call assert_fails('let &tabstop = 10000', 'E474:')
call assert_fails('set tabstop=5500000000', 'E474:')
call assert_fails('set textwidth=-1', 'E487:')
call assert_fails('set timeoutlen=-1', 'E487:')
@@ -325,6 +326,7 @@ func Test_set_errors()
call assert_fails('set comments=a', 'E525:')
call assert_fails('set foldmarker=x', 'E536:')
call assert_fails('set commentstring=x', 'E537:')
+ call assert_fails('let &commentstring = "x"', 'E537:')
call assert_fails('set complete=x', 'E539:')
call assert_fails('set rulerformat=%-', 'E539:')
call assert_fails('set rulerformat=%(', 'E542:')
diff --git a/src/nvim/testdir/test_popup.vim b/src/nvim/testdir/test_popup.vim
index 0486ed83ad..3d1e3fa6db 100644
--- a/src/nvim/testdir/test_popup.vim
+++ b/src/nvim/testdir/test_popup.vim
@@ -864,15 +864,21 @@ func Test_popup_position()
endfunc
func Test_popup_command()
- if !CanRunVimInTerminal() || !has('menu')
- return
- endif
+ CheckScreendump
+ CheckFeature menu
- call writefile([
- \ 'one two three four five',
- \ 'and one two Xthree four five',
- \ 'one more two three four five',
- \ ], 'Xtest')
+ menu Test.Foo Foo
+ call assert_fails('popup Test.Foo', 'E336:')
+ call assert_fails('popup Test.Foo.X', 'E327:')
+ call assert_fails('popup Foo', 'E337:')
+ unmenu Test.Foo
+
+ let lines =<< trim END
+ one two three four five
+ and one two Xthree four five
+ one more two three four five
+ END
+ call writefile(lines, 'Xtest')
let buf = RunVimInTerminal('Xtest', {})
call term_sendkeys(buf, ":source $VIMRUNTIME/menu.vim\<CR>")
call term_sendkeys(buf, "/X\<CR>:popup PopUp\<CR>")
diff --git a/src/nvim/testdir/test_tabpage.vim b/src/nvim/testdir/test_tabpage.vim
index d891684ecb..07f35ddb4f 100644
--- a/src/nvim/testdir/test_tabpage.vim
+++ b/src/nvim/testdir/test_tabpage.vim
@@ -133,18 +133,18 @@ function Test_tabpage()
call assert_fails("99tabmove", 'E16:')
call assert_fails("+99tabmove", 'E16:')
call assert_fails("-99tabmove", 'E16:')
- call assert_fails("tabmove foo", 'E474:')
- call assert_fails("tabmove 99", 'E474:')
- call assert_fails("tabmove +99", 'E474:')
- call assert_fails("tabmove -99", 'E474:')
- call assert_fails("tabmove -3+", 'E474:')
- call assert_fails("tabmove $3", 'E474:')
+ call assert_fails("tabmove foo", 'E475:')
+ call assert_fails("tabmove 99", 'E475:')
+ call assert_fails("tabmove +99", 'E475:')
+ call assert_fails("tabmove -99", 'E475:')
+ call assert_fails("tabmove -3+", 'E475:')
+ call assert_fails("tabmove $3", 'E475:')
call assert_fails("%tabonly", 'E16:')
1tabonly!
tabmove 1
call assert_equal(1, tabpagenr())
tabnew
- call assert_fails("-2tabmove", 'E474:')
+ call assert_fails("-2tabmove", 'E16:')
tabonly!
endfunc
@@ -320,14 +320,14 @@ function Test_tabpage_with_tabnext()
call Check_tab_count(4, 'tabnext -', 3)
call Check_tab_count(4, 'tabnext -2', 2)
call Check_tab_count(3, 'tabnext $', 5)
- call assert_fails('tabnext 0', 'E474:')
- call assert_fails('tabnext .', 'E474:')
- call assert_fails('tabnext -+', 'E474:')
- call assert_fails('tabnext +2-', 'E474:')
- call assert_fails('tabnext $3', 'E474:')
- call assert_fails('tabnext 99', 'E474:')
- call assert_fails('tabnext +99', 'E474:')
- call assert_fails('tabnext -99', 'E474:')
+ call assert_fails('tabnext 0', 'E475:')
+ call assert_fails('tabnext .', 'E475:')
+ call assert_fails('tabnext -+', 'E475:')
+ call assert_fails('tabnext +2-', 'E475:')
+ call assert_fails('tabnext $3', 'E475:')
+ call assert_fails('tabnext 99', 'E475:')
+ call assert_fails('tabnext +99', 'E475:')
+ call assert_fails('tabnext -99', 'E475:')
1tabonly!
endfunction
@@ -352,7 +352,7 @@ function Test_tabpage_with_tabprevious()
let err_code = 'E16:'
else
let entire_cmd = cmd . ' ' . c
- let err_code = 'E474:'
+ let err_code = 'E475:'
endif
call assert_fails(entire_cmd, err_code)
endfor
@@ -451,7 +451,7 @@ function Test_tabpage_with_tabclose()
let err_code = 'E16:'
else
let entire_cmd = 'tabclose ' . c
- let err_code = 'E474:'
+ let err_code = 'E475:'
endif
call assert_fails(entire_cmd, err_code)
call assert_equal(6, tabpagenr('$'))
@@ -460,8 +460,8 @@ function Test_tabpage_with_tabclose()
call assert_fails('3tabclose', 'E37:')
call assert_fails('tabclose 3', 'E37:')
- call assert_fails('tabclose -+', 'E474:')
- call assert_fails('tabclose +2-', 'E474:')
+ call assert_fails('tabclose -+', 'E475:')
+ call assert_fails('tabclose +2-', 'E475:')
call assert_equal(6, tabpagenr('$'))
1tabonly!
@@ -506,7 +506,7 @@ function Test_tabpage_with_tabonly()
let err_code = 'E16:'
else
let entire_cmd = 'tabonly ' . c
- let err_code = 'E474:'
+ let err_code = 'E475:'
endif
call assert_fails(entire_cmd, err_code)
call assert_equal(6, tabpagenr('$'))
@@ -517,13 +517,13 @@ function Test_tabpage_with_tabonly()
for c in tc
call s:reconstruct_tabpage_for_test(6)
let entire_cmd = 'tabonly' . c[2] . ' ' . c[1]
- let err_code = 'E474:'
+ let err_code = 'E475:'
call assert_fails(entire_cmd, err_code)
call assert_equal(6, tabpagenr('$'))
endfor
- call assert_fails('tabonly -+', 'E474:')
- call assert_fails('tabonly +2-', 'E474:')
+ call assert_fails('tabonly -+', 'E475:')
+ call assert_fails('tabonly +2-', 'E475:')
call assert_equal(6, tabpagenr('$'))
1tabonly!