aboutsummaryrefslogtreecommitdiff
path: root/test
diff options
context:
space:
mode:
Diffstat (limited to 'test')
-rw-r--r--test/old/testdir/test_ins_complete.vim61
1 files changed, 61 insertions, 0 deletions
diff --git a/test/old/testdir/test_ins_complete.vim b/test/old/testdir/test_ins_complete.vim
index d9b2abffab..aeceeea9f1 100644
--- a/test/old/testdir/test_ins_complete.vim
+++ b/test/old/testdir/test_ins_complete.vim
@@ -2252,5 +2252,66 @@ func Test_tagfunc_wipes_out_buffer()
bwipe!
endfunc
+func Test_ins_complete_popup_position()
+ CheckScreendump
+
+ let lines =<< trim END
+ vim9script
+ set nowrap
+ setline(1, ['one', 'two', 'this is line ', 'four'])
+ prop_type_add('test', {highlight: 'Error'})
+ prop_add(3, 0, {
+ text_align: 'above',
+ text: 'The quick brown fox jumps over the lazy dog',
+ type: 'test'
+ })
+ END
+ call writefile(lines, 'XinsPopup', 'D')
+ let buf = RunVimInTerminal('-S XinsPopup', #{rows: 10})
+
+ call term_sendkeys(buf, "3GA\<C-N>")
+ call VerifyScreenDump(buf, 'Test_ins_complete_popup_position_1', {})
+
+ call StopVimInTerminal(buf)
+endfunc
+
+func GetCompleteInfo()
+ let g:compl_info = complete_info()
+ return ''
+endfunc
+
+func Test_complete_info_index()
+ new
+ call setline(1, ["aaa", "bbb", "ccc", "ddd", "eee", "fff"])
+ inoremap <buffer><F5> <C-R>=GetCompleteInfo()<CR>
+
+ " Ensure 'index' in complete_info() is coherent with the 'items' array.
+
+ set completeopt=menu,preview
+ " Search forward.
+ call feedkeys("Go\<C-X>\<C-N>\<F5>\<Esc>_dd", 'tx')
+ call assert_equal("aaa", g:compl_info['items'][g:compl_info['selected']]['word'])
+ call feedkeys("Go\<C-X>\<C-N>\<C-N>\<F5>\<Esc>_dd", 'tx')
+ call assert_equal("bbb", g:compl_info['items'][g:compl_info['selected']]['word'])
+
+ " Search backward.
+ call feedkeys("Go\<C-X>\<C-P>\<F5>\<Esc>_dd", 'tx')
+ call assert_equal("fff", g:compl_info['items'][g:compl_info['selected']]['word'])
+ call feedkeys("Go\<C-X>\<C-P>\<C-P>\<F5>\<Esc>_dd", 'tx')
+ call assert_equal("eee", g:compl_info['items'][g:compl_info['selected']]['word'])
+
+ " Add 'noselect', check that 'selected' is -1 when nothing is selected.
+ set completeopt+=noselect
+ " Search forward.
+ call feedkeys("Go\<C-X>\<C-N>\<F5>\<Esc>_dd", 'tx')
+ call assert_equal(-1, g:compl_info['selected'])
+
+ " Search backward.
+ call feedkeys("Go\<C-X>\<C-P>\<F5>\<Esc>_dd", 'tx')
+ call assert_equal(-1, g:compl_info['selected'])
+
+ set completeopt&
+ bwipe!
+endfunc
" vim: shiftwidth=2 sts=2 expandtab