forked from aniani/vim
patch 8.2.0316: ex_getln.c code has insufficient test coverage
Problem: ex_getln.c code has insufficient test coverage. Solution: Add more tests. Fix a problem. (Yegappan Lakshmanan, closes #5693)
This commit is contained in:
@@ -389,7 +389,7 @@ calc_hist_idx(int histype, int num)
|
|||||||
i += hislen;
|
i += hislen;
|
||||||
wrapped = TRUE;
|
wrapped = TRUE;
|
||||||
}
|
}
|
||||||
if (hist[i].hisnum == num && hist[i].hisstr != NULL)
|
if (i >= 0 && hist[i].hisnum == num && hist[i].hisstr != NULL)
|
||||||
return i;
|
return i;
|
||||||
}
|
}
|
||||||
else if (-num <= hislen)
|
else if (-num <= hislen)
|
||||||
|
@@ -51,6 +51,12 @@ func Test_complete_wildmenu()
|
|||||||
call feedkeys(":e Xdir1/\<Tab>\<Down>\<Up>\<Right>\<CR>", 'tx')
|
call feedkeys(":e Xdir1/\<Tab>\<Down>\<Up>\<Right>\<CR>", 'tx')
|
||||||
call assert_equal('testfile1', getline(1))
|
call assert_equal('testfile1', getline(1))
|
||||||
|
|
||||||
|
" Completion using a relative path
|
||||||
|
cd Xdir1/Xdir2
|
||||||
|
call feedkeys(":e ../\<Tab>\<Right>\<Down>\<C-A>\<C-B>\"\<CR>", 'tx')
|
||||||
|
call assert_equal('"e Xtestfile3 Xtestfile4', @:)
|
||||||
|
cd -
|
||||||
|
|
||||||
" cleanup
|
" cleanup
|
||||||
%bwipe
|
%bwipe
|
||||||
call delete('Xdir1/Xdir2/Xtestfile4')
|
call delete('Xdir1/Xdir2/Xtestfile4')
|
||||||
@@ -456,6 +462,10 @@ func Test_cmdline_paste()
|
|||||||
" ignore error E32
|
" ignore error E32
|
||||||
endtry
|
endtry
|
||||||
call assert_equal("Xtestfile", bufname("%"))
|
call assert_equal("Xtestfile", bufname("%"))
|
||||||
|
|
||||||
|
" Use an invalid expression for <C-\>e
|
||||||
|
call assert_beeps('call feedkeys(":\<C-\>einvalid\<CR>", "tx")')
|
||||||
|
|
||||||
bwipe!
|
bwipe!
|
||||||
endfunc
|
endfunc
|
||||||
|
|
||||||
@@ -690,6 +700,8 @@ func Test_getcmdtype()
|
|||||||
cnoremap <expr> <F6> Check_cmdline('=')
|
cnoremap <expr> <F6> Check_cmdline('=')
|
||||||
call feedkeys("a\<C-R>=MyCmd a\<F6>\<Esc>\<Esc>", "xt")
|
call feedkeys("a\<C-R>=MyCmd a\<F6>\<Esc>\<Esc>", "xt")
|
||||||
cunmap <F6>
|
cunmap <F6>
|
||||||
|
|
||||||
|
call assert_equal('', getcmdline())
|
||||||
endfunc
|
endfunc
|
||||||
|
|
||||||
func Test_getcmdwintype()
|
func Test_getcmdwintype()
|
||||||
@@ -930,6 +942,22 @@ func Test_cmdwin_cedit()
|
|||||||
delfunc CmdWinType
|
delfunc CmdWinType
|
||||||
endfunc
|
endfunc
|
||||||
|
|
||||||
|
" Test for CmdwinEnter autocmd
|
||||||
|
func Test_cmdwin_autocmd()
|
||||||
|
augroup CmdWin
|
||||||
|
au!
|
||||||
|
autocmd CmdwinEnter * startinsert
|
||||||
|
augroup END
|
||||||
|
|
||||||
|
call assert_fails('call feedkeys("q:xyz\<CR>", "xt")', 'E492:')
|
||||||
|
call assert_equal('xyz', @:)
|
||||||
|
|
||||||
|
augroup CmdWin
|
||||||
|
au!
|
||||||
|
augroup END
|
||||||
|
augroup! CmdWin
|
||||||
|
endfunc
|
||||||
|
|
||||||
func Test_cmdlineclear_tabenter()
|
func Test_cmdlineclear_tabenter()
|
||||||
CheckScreendump
|
CheckScreendump
|
||||||
|
|
||||||
@@ -967,6 +995,10 @@ func Test_cmdwin_jump_to_win()
|
|||||||
call assert_equal(1, winnr('$'))
|
call assert_equal(1, winnr('$'))
|
||||||
call feedkeys("q/:exit\<CR>", "xt")
|
call feedkeys("q/:exit\<CR>", "xt")
|
||||||
call assert_equal(1, winnr('$'))
|
call assert_equal(1, winnr('$'))
|
||||||
|
|
||||||
|
" opening command window twice should fail
|
||||||
|
call assert_beeps('call feedkeys("q:q:\<CR>\<CR>", "xt")')
|
||||||
|
call assert_equal(1, winnr('$'))
|
||||||
endfunc
|
endfunc
|
||||||
|
|
||||||
" Test for backtick expression in the command line
|
" Test for backtick expression in the command line
|
||||||
@@ -1006,4 +1038,19 @@ func Test_cmd_bang()
|
|||||||
call delete('Xresult')
|
call delete('Xresult')
|
||||||
endfunc
|
endfunc
|
||||||
|
|
||||||
|
" Test for using ~ for home directory in cmdline completion matches
|
||||||
|
func Test_cmdline_expand_home()
|
||||||
|
call mkdir('Xdir')
|
||||||
|
call writefile([], 'Xdir/Xfile1')
|
||||||
|
call writefile([], 'Xdir/Xfile2')
|
||||||
|
cd Xdir
|
||||||
|
let save_HOME = $HOME
|
||||||
|
let $HOME = getcwd()
|
||||||
|
call feedkeys(":e ~/\<C-A>\<C-B>\"\<CR>", 'xt')
|
||||||
|
call assert_equal('"e ~/Xfile1 ~/Xfile2', @:)
|
||||||
|
let $HOME = save_HOME
|
||||||
|
cd ..
|
||||||
|
call delete('Xdir', 'rf')
|
||||||
|
endfunc
|
||||||
|
|
||||||
" vim: shiftwidth=2 sts=2 expandtab
|
" vim: shiftwidth=2 sts=2 expandtab
|
||||||
|
@@ -1141,6 +1141,30 @@ func Test_col()
|
|||||||
bw!
|
bw!
|
||||||
endfunc
|
endfunc
|
||||||
|
|
||||||
|
" Test for input()
|
||||||
|
func Test_input_func()
|
||||||
|
" Test for prompt with multiple lines
|
||||||
|
redir => v
|
||||||
|
call feedkeys(":let c = input(\"A\\nB\\nC\\n? \")\<CR>B\<CR>", 'xt')
|
||||||
|
redir END
|
||||||
|
call assert_equal("B", c)
|
||||||
|
call assert_equal(['A', 'B', 'C'], split(v, "\n"))
|
||||||
|
|
||||||
|
" Test for default value
|
||||||
|
call feedkeys(":let c = input('color? ', 'red')\<CR>\<CR>", 'xt')
|
||||||
|
call assert_equal('red', c)
|
||||||
|
|
||||||
|
" Test for completion at the input prompt
|
||||||
|
func! Tcomplete(arglead, cmdline, pos)
|
||||||
|
return "item1\nitem2\nitem3"
|
||||||
|
endfunc
|
||||||
|
call feedkeys(":let c = input('Q? ', '' , 'custom,Tcomplete')\<CR>"
|
||||||
|
\ .. "\<C-A>\<CR>", 'xt')
|
||||||
|
delfunc Tcomplete
|
||||||
|
call assert_equal('item1 item2 item3', c)
|
||||||
|
endfunc
|
||||||
|
|
||||||
|
" Test for inputlist()
|
||||||
func Test_inputlist()
|
func Test_inputlist()
|
||||||
call feedkeys(":let c = inputlist(['Select color:', '1. red', '2. green', '3. blue'])\<cr>1\<cr>", 'tx')
|
call feedkeys(":let c = inputlist(['Select color:', '1. red', '2. green', '3. blue'])\<cr>1\<cr>", 'tx')
|
||||||
call assert_equal(1, c)
|
call assert_equal(1, c)
|
||||||
@@ -2034,3 +2058,5 @@ func Test_echoraw()
|
|||||||
call StopVimInTerminal(buf)
|
call StopVimInTerminal(buf)
|
||||||
call delete('XTest_echoraw')
|
call delete('XTest_echoraw')
|
||||||
endfunc
|
endfunc
|
||||||
|
|
||||||
|
" vim: shiftwidth=2 sts=2 expandtab
|
||||||
|
@@ -85,6 +85,8 @@ function Test_History()
|
|||||||
call assert_fails('call histget([])', 'E730:')
|
call assert_fails('call histget([])', 'E730:')
|
||||||
call assert_equal(-1, histnr('abc'))
|
call assert_equal(-1, histnr('abc'))
|
||||||
call assert_fails('call histnr([])', 'E730:')
|
call assert_fails('call histnr([])', 'E730:')
|
||||||
|
call assert_fails('history xyz', 'E488:')
|
||||||
|
call assert_fails('history ,abc', 'E488:')
|
||||||
endfunction
|
endfunction
|
||||||
|
|
||||||
function Test_Search_history_window()
|
function Test_Search_history_window()
|
||||||
@@ -108,3 +110,52 @@ function Test_history_completion()
|
|||||||
call feedkeys(":history \<C-A>\<C-B>\"\<CR>", 'tx')
|
call feedkeys(":history \<C-A>\<C-B>\"\<CR>", 'tx')
|
||||||
call assert_equal('"history / : = > ? @ all cmd debug expr input search', @:)
|
call assert_equal('"history / : = > ? @ all cmd debug expr input search', @:)
|
||||||
endfunc
|
endfunc
|
||||||
|
|
||||||
|
" Test for increasing the 'history' option value
|
||||||
|
func Test_history_size()
|
||||||
|
let save_histsz = &history
|
||||||
|
call histdel(':')
|
||||||
|
set history=5
|
||||||
|
for i in range(1, 5)
|
||||||
|
call histadd(':', 'cmd' .. i)
|
||||||
|
endfor
|
||||||
|
call assert_equal(5, histnr(':'))
|
||||||
|
call assert_equal('cmd5', histget(':', -1))
|
||||||
|
|
||||||
|
set history=10
|
||||||
|
for i in range(6, 10)
|
||||||
|
call histadd(':', 'cmd' .. i)
|
||||||
|
endfor
|
||||||
|
call assert_equal(10, histnr(':'))
|
||||||
|
call assert_equal('cmd1', histget(':', 1))
|
||||||
|
call assert_equal('cmd10', histget(':', -1))
|
||||||
|
|
||||||
|
set history=5
|
||||||
|
call histadd(':', 'abc')
|
||||||
|
call assert_equal('', histget(':', 6))
|
||||||
|
call assert_equal('', histget(':', 12))
|
||||||
|
call assert_equal('cmd7', histget(':', 7))
|
||||||
|
call assert_equal('abc', histget(':', -1))
|
||||||
|
|
||||||
|
let &history=save_histsz
|
||||||
|
endfunc
|
||||||
|
|
||||||
|
" Test for recalling old search patterns in /
|
||||||
|
func Test_history_search()
|
||||||
|
call histdel('/')
|
||||||
|
let g:pat = []
|
||||||
|
func SavePat()
|
||||||
|
call add(g:pat, getcmdline())
|
||||||
|
return ''
|
||||||
|
endfunc
|
||||||
|
cnoremap <F2> <C-\>eSavePat()<CR>
|
||||||
|
call histadd('/', 'pat1')
|
||||||
|
call histadd('/', 'pat2')
|
||||||
|
let @/ = ''
|
||||||
|
call feedkeys("/\<Up>\<F2>\<Up>\<F2>\<Down>\<Down>\<F2>\<Esc>", 'xt')
|
||||||
|
call assert_equal(['pat2', 'pat1', ''], g:pat)
|
||||||
|
cunmap <F2>
|
||||||
|
delfunc SavePat
|
||||||
|
endfunc
|
||||||
|
|
||||||
|
" vim: shiftwidth=2 sts=2 expandtab
|
||||||
|
@@ -88,3 +88,39 @@ func Test_menu_commands()
|
|||||||
|
|
||||||
unlet g:did_menu
|
unlet g:did_menu
|
||||||
endfun
|
endfun
|
||||||
|
|
||||||
|
" Test for menu item completion in command line
|
||||||
|
func Test_menu_expand()
|
||||||
|
" Create the menu itmes for test
|
||||||
|
for i in range(1, 4)
|
||||||
|
let m = 'menu Xmenu.A' .. i .. '.A' .. i
|
||||||
|
for j in range(1, 4)
|
||||||
|
exe m .. 'B' .. j .. ' :echo "A' .. i .. 'B' .. j .. '"' .. "<CR>"
|
||||||
|
endfor
|
||||||
|
endfor
|
||||||
|
set wildmenu
|
||||||
|
|
||||||
|
" Test for <CR> selecting a submenu
|
||||||
|
call feedkeys(":emenu Xmenu.A\<Tab>\<CR>\<Right>x\<BS>\<C-B>\"\<CR>", 'xt')
|
||||||
|
call assert_equal('"emenu Xmenu.A1.A1B2', @:)
|
||||||
|
|
||||||
|
" Test for <Down> selecting a submenu
|
||||||
|
call feedkeys(":emenu Xmenu.A\<Tab>\<Right>\<Right>\<Down>" ..
|
||||||
|
\ "\<C-A>\<C-B>\"\<CR>", 'xt')
|
||||||
|
call assert_equal('"emenu Xmenu.A3.A3B1 A3B2 A3B3 A3B4', @:)
|
||||||
|
|
||||||
|
" Test for <Up> to go up a submenu
|
||||||
|
call feedkeys(":emenu Xmenu.A\<Tab>\<Down>\<Up>\<Right>\<Right>" ..
|
||||||
|
\ "\<Left>\<Down>\<C-A>\<C-B>\"\<CR>", 'xt')
|
||||||
|
call assert_equal('"emenu Xmenu.A2.A2B1 A2B2 A2B3 A2B4', @:)
|
||||||
|
|
||||||
|
" 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.', @:)
|
||||||
|
|
||||||
|
set wildmenu&
|
||||||
|
unmenu Xmenu
|
||||||
|
endfunc
|
||||||
|
|
||||||
|
" vim: shiftwidth=2 sts=2 expandtab
|
||||||
|
@@ -738,6 +738,8 @@ static char *(features[]) =
|
|||||||
|
|
||||||
static int included_patches[] =
|
static int included_patches[] =
|
||||||
{ /* Add new patch number below this line */
|
{ /* Add new patch number below this line */
|
||||||
|
/**/
|
||||||
|
316,
|
||||||
/**/
|
/**/
|
||||||
315,
|
315,
|
||||||
/**/
|
/**/
|
||||||
|
Reference in New Issue
Block a user