vim-patch:8.2.0401: not enough test coverage for evalvars.c

Problem:    Not enough test coverage for evalvars.c.
Solution:   Add more tests. (Yegappan Lakshmanan, closes vim/vim#5804)

8dfcce3a78

Assert E475 instead of E474 in :redir test because a later patch changed
the error number.

Comment out the test for :echo with a deeply nested container as Nvim
implements :echo very differently.
This commit is contained in:
zeertzjq
2022-10-26 13:05:33 +08:00
parent b4c250d37b
commit d40739843c
11 changed files with 272 additions and 12 deletions

View File

@@ -1077,6 +1077,40 @@ func Test_cmdline_complete_various()
" completion for the expression register " completion for the expression register
call feedkeys(":\"\<C-R>=float2\t\"\<C-B>\"\<CR>", 'xt') call feedkeys(":\"\<C-R>=float2\t\"\<C-B>\"\<CR>", 'xt')
call assert_equal('"float2nr("', @=) call assert_equal('"float2nr("', @=)
" completion for :language command with an invalid argument
call feedkeys(":language dummy \t\<C-B>\"\<CR>", 'xt')
call assert_equal("\"language dummy \t", @:)
" completion for commands after a :global command
call feedkeys(":g/a\\xb/call float2\t\<C-B>\"\<CR>", 'xt')
call assert_equal('"g/a\xb/call float2nr(', @:)
" completion with ambiguous user defined commands
com TCmd1 echo 'TCmd1'
com TCmd2 echo 'TCmd2'
call feedkeys(":TCmd \t\<C-B>\"\<CR>", 'xt')
call assert_equal('"TCmd ', @:)
delcom TCmd1
delcom TCmd2
" completion after a range followed by a pipe (|) character
call feedkeys(":1,10 | chist\t\<C-B>\"\<CR>", 'xt')
call assert_equal('"1,10 | chistory', @:)
" completion for window local variables
let w:wvar1 = 10
let w:wvar2 = 10
call feedkeys(":echo w:wvar\<C-A>\<C-B>\"\<CR>", 'xt')
call assert_equal('"echo w:wvar1 w:wvar2', @:)
unlet w:wvar1 w:wvar2
" completion for tab local variables
let t:tvar1 = 10
let t:tvar2 = 10
call feedkeys(":echo t:tvar\<C-A>\<C-B>\"\<CR>", 'xt')
call assert_equal('"echo t:tvar1 t:tvar2', @:)
unlet t:tvar1 t:tvar2
endfunc endfunc
func Test_cmdline_write_alternatefile() func Test_cmdline_write_alternatefile()
@@ -1682,16 +1716,16 @@ func Test_wildmode()
" Test for wildmode=longest with 'fileignorecase' set " Test for wildmode=longest with 'fileignorecase' set
set wildmode=longest set wildmode=longest
set fileignorecase set fileignorecase
argadd AA AAA AAAA argadd AAA AAAA AAAAA
call feedkeys(":buffer \t\<C-B>\"\<CR>", 'xt') call feedkeys(":buffer a\t\<C-B>\"\<CR>", 'xt')
call assert_equal('"buffer AA', @:) call assert_equal('"buffer AAA', @:)
set fileignorecase& set fileignorecase&
" Test for listing files with wildmode=list " Test for listing files with wildmode=list
set wildmode=list set wildmode=list
let g:Sline = '' let g:Sline = ''
call feedkeys(":b A\t\t\<F2>\<C-B>\"\<CR>", 'xt') call feedkeys(":b A\t\t\<F2>\<C-B>\"\<CR>", 'xt')
call assert_equal('AA AAA AAAA', g:Sline) call assert_equal('AAA AAAA AAAAA', g:Sline)
call assert_equal('"b A', @:) call assert_equal('"b A', @:)
%argdelete %argdelete

View File

@@ -231,6 +231,14 @@ func Test_const_with_special_variables()
call assert_fails('const &filetype = "vim"', 'E996:') call assert_fails('const &filetype = "vim"', 'E996:')
call assert_fails('const &l:filetype = "vim"', 'E996:') call assert_fails('const &l:filetype = "vim"', 'E996:')
call assert_fails('const &g:encoding = "utf-8"', 'E996:') call assert_fails('const &g:encoding = "utf-8"', 'E996:')
call assert_fails('const [a, $CONST_FOO] = [369, "abc"]', 'E996:')
call assert_equal(369, a)
call assert_equal(v:null, getenv("CONST_FOO"))
call assert_fails('const [b; $CONST_FOO] = [246, 2, "abc"]', 'E996:')
call assert_equal(246, b)
call assert_equal(v:null, getenv("CONST_FOO"))
endfunc endfunc
func Test_const_with_eval_name() func Test_const_with_eval_name()
@@ -274,3 +282,5 @@ func Test_lock_depth_is_2()
const d2 = #{a: 0, b: lvar, c: 4} const d2 = #{a: 0, b: lvar, c: 4}
let d2.b[1] = 'd' let d2.b[1] = 'd'
endfunc endfunc
" vim: shiftwidth=2 sts=2 expandtab

View File

@@ -1198,6 +1198,33 @@ func Test_diff_maintains_change_mark()
delfunc DiffMaintainsChangeMark delfunc DiffMaintainsChangeMark
endfunc endfunc
" Test for 'patchexpr'
func Test_patchexpr()
let g:patch_args = []
func TPatch()
call add(g:patch_args, readfile(v:fname_in))
call add(g:patch_args, readfile(v:fname_diff))
call writefile(['output file'], v:fname_out)
endfunc
set patchexpr=TPatch()
call writefile(['input file'], 'Xinput')
call writefile(['diff file'], 'Xdiff')
%bwipe!
edit Xinput
diffpatch Xdiff
call assert_equal('output file', getline(1))
call assert_equal('Xinput.new', bufname())
call assert_equal(2, winnr('$'))
call assert_true(&diff)
call delete('Xinput')
call delete('Xdiff')
set patchexpr&
delfunc TPatch
%bwipe!
endfunc
func Test_diff_rnu() func Test_diff_rnu()
CheckScreendump CheckScreendump

View File

@@ -479,12 +479,21 @@ endfunc
func Test_redir_cmd() func Test_redir_cmd()
call assert_fails('redir @@', 'E475:') call assert_fails('redir @@', 'E475:')
call assert_fails('redir abc', 'E475:') call assert_fails('redir abc', 'E475:')
call assert_fails('redir => 1abc', 'E474:')
call assert_fails('redir => a b', 'E488:')
call assert_fails('redir => abc[1]', 'E475:')
let b=0zFF
call assert_fails('redir =>> b', 'E734:')
unlet b
if has('unix') if has('unix')
" Redirecting to a directory name
call mkdir('Xdir') call mkdir('Xdir')
call assert_fails('redir > Xdir', 'E17:') call assert_fails('redir > Xdir', 'E17:')
call delete('Xdir', 'd') call delete('Xdir', 'd')
endif endif
if !has('bsd') if !has('bsd')
" Redirecting to a read-only file
call writefile([], 'Xfile') call writefile([], 'Xfile')
call setfperm('Xfile', 'r--r--r--') call setfperm('Xfile', 'r--r--r--')
call assert_fails('redir! > Xfile', 'E190:') call assert_fails('redir! > Xfile', 'E190:')

View File

@@ -804,6 +804,10 @@ func Test_getbufvar()
call assert_equal(0, getbufvar(bnr, '&autoindent')) call assert_equal(0, getbufvar(bnr, '&autoindent'))
call assert_equal(0, getbufvar(bnr, '&autoindent', 1)) call assert_equal(0, getbufvar(bnr, '&autoindent', 1))
" Set and get a buffer-local variable
call setbufvar(bnr, 'bufvar_test', ['one', 'two'])
call assert_equal(['one', 'two'], getbufvar(bnr, 'bufvar_test'))
" Open new window with forced option values " Open new window with forced option values
set fileformats=unix,dos set fileformats=unix,dos
new ++ff=dos ++bin ++enc=iso-8859-2 new ++ff=dos ++bin ++enc=iso-8859-2
@@ -1633,6 +1637,10 @@ func Test_func_sandbox()
call assert_fails('call Fsandbox()', 'E48:') call assert_fails('call Fsandbox()', 'E48:')
delfunc Fsandbox delfunc Fsandbox
" From a sandbox try to set a predefined variable (which cannot be modified
" from a sandbox)
call assert_fails('sandbox let v:lnum = 10', 'E794:')
endfunc endfunc
func EditAnotherFile() func EditAnotherFile()
@@ -2143,14 +2151,6 @@ func Test_range()
" sort() " sort()
call assert_equal([0, 1, 2, 3, 4, 5], sort(range(5, 0, -1))) call assert_equal([0, 1, 2, 3, 4, 5], sort(range(5, 0, -1)))
" 'spellsuggest'
func MySuggest()
return range(3)
endfunc
set spell spellsuggest=expr:MySuggest()
call assert_equal([], spellsuggest('baord', 3))
set nospell spellsuggest&
" string() " string()
call assert_equal('[0, 1, 2, 3, 4]', string(range(5))) call assert_equal('[0, 1, 2, 3, 4]', string(range(5)))

View File

@@ -25,9 +25,62 @@ func Test_let()
let s = "\na #1\nb #2" let s = "\na #1\nb #2"
call assert_equal(s, out) call assert_equal(s, out)
" Test for displaying a string variable
let s = 'vim'
let out = execute('let s')
let s = "\ns vim"
call assert_equal(s, out)
" Test for displaying a list variable
let l = [1, 2]
let out = execute('let l')
let s = "\nl [1, 2]"
call assert_equal(s, out)
" Test for displaying a dict variable
let d = {'k' : 'v'}
let out = execute('let d')
let s = "\nd {'k': 'v'}"
call assert_equal(s, out)
" Test for displaying a function reference variable
let F = function('min')
let out = execute('let F')
let s = "\nF *min()"
call assert_equal(s, out)
let x = 0 let x = 0
if 0 | let x = 1 | endif if 0 | let x = 1 | endif
call assert_equal(0, x) call assert_equal(0, x)
" Display a list item using an out of range index
let l = [10]
call assert_fails('let l[1]', 'E684:')
" List special variable dictionaries
let g:Test_Global_Var = 5
call assert_match("\nTest_Global_Var #5", execute('let g:'))
unlet g:Test_Global_Var
let b:Test_Buf_Var = 8
call assert_match("\nb:Test_Buf_Var #8", execute('let b:'))
unlet b:Test_Buf_Var
let w:Test_Win_Var = 'foo'
call assert_equal("\nw:Test_Win_Var foo", execute('let w:'))
unlet w:Test_Win_Var
let t:Test_Tab_Var = 'bar'
call assert_equal("\nt:Test_Tab_Var bar", execute('let t:'))
unlet t:Test_Tab_Var
let s:Test_Script_Var = [7]
call assert_match("\ns:Test_Script_Var \\[7]", execute('let s:'))
unlet s:Test_Script_Var
let l:Test_Local_Var = {'k' : 5}
call assert_match("\nl:Test_Local_Var {'k': 5}", execute('let l:'))
call assert_match("v:errors []", execute('let v:'))
endfunc endfunc
func s:set_arg1(a) abort func s:set_arg1(a) abort
@@ -201,16 +254,45 @@ func Test_let_option_error()
let &fillchars = _w let &fillchars = _w
endfunc endfunc
" Errors with the :let statement
func Test_let_errors() func Test_let_errors()
let s = 'abcd' let s = 'abcd'
call assert_fails('let s[1] = 5', 'E689:') call assert_fails('let s[1] = 5', 'E689:')
let l = [1, 2, 3] let l = [1, 2, 3]
call assert_fails('let l[:] = 5', 'E709:') call assert_fails('let l[:] = 5', 'E709:')
call assert_fails('let x:lnum=5', 'E488:')
call assert_fails('let v:=5', 'E461:')
call assert_fails('let [a]', 'E474:')
call assert_fails('let [a, b] = [', 'E697:')
call assert_fails('let [a, b] = [10, 20', 'E696:')
call assert_fails('let [a, b] = 10', 'E714:')
call assert_fails('let [a, , b] = [10, 20]', 'E475:')
call assert_fails('let [a, b&] = [10, 20]', 'E475:')
call assert_fails('let $ = 10', 'E475:')
call assert_fails('let $FOO[1] = "abc"', 'E18:')
call assert_fails('let &buftype[1] = "nofile"', 'E18:')
let s = "var"
let var = 1
call assert_fails('let {s}.1 = 2', 'E18:')
" This test works only when the language is English
if v:lang == "C" || v:lang =~ '^[Ee]n'
call assert_fails('let [a ; b;] = [10, 20]',
\ 'Double ; in list of variables')
endif
endfunc endfunc
func Test_let_heredoc_fails() func Test_let_heredoc_fails()
call assert_fails('let v =<< marker', 'E991:') call assert_fails('let v =<< marker', 'E991:')
try
exe "let v =<< TEXT | abc | TEXT"
call assert_report('No exception thrown')
catch /E488:/
catch
call assert_report("Caught exception: " .. v:exception)
endtry
let text =<< trim END let text =<< trim END
func WrongSyntax() func WrongSyntax()
@@ -243,6 +325,10 @@ func Test_let_heredoc_fails()
call writefile(text, 'XheredocBadMarker') call writefile(text, 'XheredocBadMarker')
call assert_fails('source XheredocBadMarker', 'E221:') call assert_fails('source XheredocBadMarker', 'E221:')
call delete('XheredocBadMarker') call delete('XheredocBadMarker')
call writefile(['let v =<< TEXT', 'abc'], 'XheredocMissingMarker')
call assert_fails('source XheredocMissingMarker', 'E990:')
call delete('XheredocMissingMarker')
endfunc endfunc
func Test_let_heredoc_trim_no_indent_marker() func Test_let_heredoc_trim_no_indent_marker()
@@ -361,3 +447,5 @@ E
END END
call assert_equal([' x', ' \y', ' z'], [a, b, c]) call assert_equal([' x', ' \y', ' z'], [a, b, c])
endfunc endfunc
" vim: shiftwidth=2 sts=2 expandtab

View File

@@ -574,6 +574,18 @@ func Test_let_lock_list()
unlet l unlet l
endfunc endfunc
" Locking part of the list
func Test_let_lock_list_items()
let l = [1, 2, 3, 4]
lockvar l[2:]
call assert_equal(0, islocked('l[0]'))
call assert_equal(1, islocked('l[2]'))
call assert_equal(1, islocked('l[3]'))
call assert_fails('let l[2] = 10', 'E741:')
call assert_fails('let l[3] = 20', 'E741:')
unlet l
endfunc
" lockvar/islocked() triggering script autoloading " lockvar/islocked() triggering script autoloading
func Test_lockvar_script_autoload() func Test_lockvar_script_autoload()
let old_rtp = &rtp let old_rtp = &rtp
@@ -870,6 +882,46 @@ func Test_scope_dict()
call s:check_scope_dict('v', v:true) call s:check_scope_dict('v', v:true)
endfunc endfunc
" Test for deep nesting of lists (> 100)
func Test_deep_nested_list()
let deep_list = []
let l = deep_list
for i in range(102)
let newlist = []
call add(l, newlist)
let l = newlist
endfor
call add(l, 102)
call assert_fails('let m = deepcopy(deep_list)', 'E698:')
call assert_fails('lockvar 110 deep_list', 'E743:')
call assert_fails('unlockvar 110 deep_list', 'E743:')
" Nvim implements :echo very differently
" call assert_fails('let x = execute("echo deep_list")', 'E724:')
call test_garbagecollect_now()
unlet deep_list
endfunc
" Test for deep nesting of dicts (> 100)
func Test_deep_nested_dict()
let deep_dict = {}
let d = deep_dict
for i in range(102)
let newdict = {}
let d.k = newdict
let d = newdict
endfor
let d.k = 'v'
call assert_fails('let m = deepcopy(deep_dict)', 'E698:')
call assert_fails('lockvar 110 deep_dict', 'E743:')
call assert_fails('unlockvar 110 deep_dict', 'E743:')
" Nvim implements :echo very differently
" call assert_fails('let x = execute("echo deep_dict")', 'E724:')
call test_garbagecollect_now()
unlet deep_dict
endfunc
" Test for a null list " Test for a null list
func Test_null_list() func Test_null_list()
let l = v:_null_list let l = v:_null_list
@@ -906,3 +958,5 @@ func Test_null_list()
call assert_equal(1, islocked('l')) call assert_equal(1, islocked('l'))
unlockvar l unlockvar l
endfunc endfunc
" vim: shiftwidth=2 sts=2 expandtab

View File

@@ -474,6 +474,35 @@ func Test_spellsuggest_option_expr()
bwipe! bwipe!
endfunc endfunc
" Test for 'spellsuggest' expr errrors
func Test_spellsuggest_expr_errors()
" 'spellsuggest'
func MySuggest()
return range(3)
endfunc
set spell spellsuggest=expr:MySuggest()
call assert_equal([], spellsuggest('baord', 3))
" Test for 'spellsuggest' expression returning a non-list value
func! MySuggest2()
return 'good'
endfunc
set spellsuggest=expr:MySuggest2()
call assert_equal([], spellsuggest('baord'))
" Test for 'spellsuggest' expression returning a list with dict values
func! MySuggest3()
return [[{}, {}]]
endfunc
set spellsuggest=expr:MySuggest3()
call assert_fails("call spellsuggest('baord')", 'E728:')
set nospell spellsuggest&
delfunc MySuggest
delfunc MySuggest2
delfunc MySuggest3
endfunc
func Test_spellsuggest_timeout() func Test_spellsuggest_timeout()
set spellsuggest=timeout:30 set spellsuggest=timeout:30
set spellsuggest=timeout:-123 set spellsuggest=timeout:-123

View File

@@ -20,6 +20,7 @@ endfunc
func Test_unlet_fails() func Test_unlet_fails()
call assert_fails('unlet v:["count"]', 'E46:') call assert_fails('unlet v:["count"]', 'E46:')
call assert_fails('unlet $', 'E475:')
endfunc endfunc
func Test_unlet_env() func Test_unlet_env()
@@ -55,3 +56,5 @@ func Test_unlet_complete()
call feedkeys(":unlet $FOO\t\n", 'tx') call feedkeys(":unlet $FOO\t\n", 'tx')
call assert_true(!exists('$FOOBAR') || empty($FOOBAR)) call assert_true(!exists('$FOOBAR') || empty($FOOBAR))
endfunc endfunc
" vim: shiftwidth=2 sts=2 expandtab

View File

@@ -87,6 +87,9 @@ func Test_user_func()
call assert_fails("call extend(g:, {'max': function('min')})", 'E704') call assert_fails("call extend(g:, {'max': function('min')})", 'E704')
call assert_equal(3, max([1, 2, 3])) call assert_equal(3, max([1, 2, 3]))
" Try to overwrite an user defined function with a function reference
call assert_fails("let Expr1 = function('min')", 'E705:')
" Regression: the first line below used to throw ?E110: Missing ')'? " Regression: the first line below used to throw ?E110: Missing ')'?
" Second is here just to prove that this line is correct when not skipping " Second is here just to prove that this line is correct when not skipping
" rhs of &&. " rhs of &&.

View File

@@ -1542,6 +1542,9 @@ func Test_delfunction_force()
endfunc endfunc
delfunc! Xtest delfunc! Xtest
delfunc! Xtest delfunc! Xtest
" Try deleting the current function
call assert_fails('delfunc Test_delfunction_force', 'E131:')
endfunc endfunc
" Test using bang after user command {{{1 " Test using bang after user command {{{1