mirror of
https://github.com/vim/vim.git
synced 2025-10-01 04:54:07 -04:00
patch 8.2.0450: not enough testing for restricted mode and function calls
Problem: Not enough testing for restricted mode and function calls. Solution: Add more tests. (Yegappan Lakshmanan, closes #5847)
This commit is contained in:
@@ -152,6 +152,22 @@ endfunc
|
|||||||
|
|
||||||
func Test_method_not_supported()
|
func Test_method_not_supported()
|
||||||
call assert_fails('eval 123->changenr()', 'E276:')
|
call assert_fails('eval 123->changenr()', 'E276:')
|
||||||
|
call assert_fails('echo "abc"->invalidfunc()', 'E117:')
|
||||||
|
" Test for too many or too few arguments to a method
|
||||||
|
call assert_fails('let n="abc"->len(2)', 'E118:')
|
||||||
|
call assert_fails('let n=10->setwinvar()', 'E119:')
|
||||||
endfunc
|
endfunc
|
||||||
|
|
||||||
" vim: shiftwidth=2 sts=2 expandtab
|
" Test for passing optional arguments to methods
|
||||||
|
func Test_method_args()
|
||||||
|
let v:errors = []
|
||||||
|
let n = 10->assert_inrange(1, 5, "Test_assert_inrange")
|
||||||
|
if v:errors[0] !~ 'Test_assert_inrange'
|
||||||
|
call assert_report(v:errors[0])
|
||||||
|
else
|
||||||
|
" Test passed
|
||||||
|
let v:errors = []
|
||||||
|
endif
|
||||||
|
endfunc
|
||||||
|
|
||||||
|
" vim: ts=8 sw=2 sts=2 expandtab tw=80 fdm=marker
|
||||||
|
@@ -7,97 +7,103 @@ source shared.vim
|
|||||||
" finish
|
" finish
|
||||||
"endif
|
"endif
|
||||||
|
|
||||||
func Test_restricted()
|
func Test_restricted_mode()
|
||||||
call Run_restricted_test('!ls', 'E145:')
|
let lines =<< trim END
|
||||||
endfunc
|
if has('lua')
|
||||||
|
call assert_fails('lua print("Hello, Vim!")', 'E981:')
|
||||||
func Run_restricted_test(ex_cmd, error)
|
call assert_fails('luado return "hello"', 'E981:')
|
||||||
let cmd = GetVimCommand('Xrestricted')
|
call assert_fails('luafile somefile', 'E981:')
|
||||||
if cmd == ''
|
call assert_fails('call luaeval("expression")', 'E145:')
|
||||||
return
|
|
||||||
endif
|
endif
|
||||||
|
|
||||||
" Use a VimEnter autocommand to avoid that the error message is displayed in
|
if has('mzscheme')
|
||||||
" a dialog with an OK button.
|
call assert_fails('mzscheme statement', 'E981:')
|
||||||
call writefile([
|
call assert_fails('mzfile somefile', 'E981:')
|
||||||
\ "func Init()",
|
call assert_fails('call mzeval("expression")', 'E145:')
|
||||||
\ " silent! " . a:ex_cmd,
|
endif
|
||||||
\ " call writefile([v:errmsg], 'Xrestrout')",
|
|
||||||
\ " qa!",
|
if has('perl')
|
||||||
\ "endfunc",
|
" TODO: how to make Safe mode fail?
|
||||||
\ "au VimEnter * call Init()",
|
" call assert_fails('perl system("ls")', 'E981:')
|
||||||
\ ], 'Xrestricted')
|
" call assert_fails('perldo system("hello")', 'E981:')
|
||||||
call system(cmd . ' -Z')
|
" call assert_fails('perlfile somefile', 'E981:')
|
||||||
call assert_match(a:error, join(readfile('Xrestrout')))
|
" call assert_fails('call perleval("system(\"ls\")")', 'E145:')
|
||||||
|
endif
|
||||||
|
|
||||||
|
if has('python')
|
||||||
|
call assert_fails('python print "hello"', 'E981:')
|
||||||
|
call assert_fails('pydo return "hello"', 'E981:')
|
||||||
|
call assert_fails('pyfile somefile', 'E981:')
|
||||||
|
call assert_fails('call pyeval("expression")', 'E145:')
|
||||||
|
endif
|
||||||
|
|
||||||
|
if has('python3')
|
||||||
|
call assert_fails('py3 print "hello"', 'E981:')
|
||||||
|
call assert_fails('py3do return "hello"', 'E981:')
|
||||||
|
call assert_fails('py3file somefile', 'E981:')
|
||||||
|
call assert_fails('call py3eval("expression")', 'E145:')
|
||||||
|
endif
|
||||||
|
|
||||||
|
if has('ruby')
|
||||||
|
call assert_fails('ruby print "Hello"', 'E981:')
|
||||||
|
call assert_fails('rubydo print "Hello"', 'E981:')
|
||||||
|
call assert_fails('rubyfile somefile', 'E981:')
|
||||||
|
endif
|
||||||
|
|
||||||
|
if has('tcl')
|
||||||
|
call assert_fails('tcl puts "Hello"', 'E981:')
|
||||||
|
call assert_fails('tcldo puts "Hello"', 'E981:')
|
||||||
|
call assert_fails('tclfile somefile', 'E981:')
|
||||||
|
endif
|
||||||
|
|
||||||
|
if has('clientserver')
|
||||||
|
call assert_fails('let s=remote_peek(10)', 'E145:')
|
||||||
|
call assert_fails('let s=remote_read(10)', 'E145:')
|
||||||
|
call assert_fails('let s=remote_send("vim", "abc")', 'E145:')
|
||||||
|
call assert_fails('let s=server2client(10, "abc")', 'E145:')
|
||||||
|
endif
|
||||||
|
|
||||||
|
if has('terminal')
|
||||||
|
call assert_fails('terminal', 'E145:')
|
||||||
|
call assert_fails('call term_start("vim")', 'E145:')
|
||||||
|
call assert_fails('call term_dumpwrite(1, "Xfile")', 'E145:')
|
||||||
|
endif
|
||||||
|
|
||||||
|
if has('channel')
|
||||||
|
call assert_fails("call ch_logfile('Xlog')", 'E145:')
|
||||||
|
call assert_fails("call ch_open('localhost:8765')", 'E145:')
|
||||||
|
endif
|
||||||
|
|
||||||
|
if has('job')
|
||||||
|
call assert_fails("call job_start('vim')", 'E145:')
|
||||||
|
endif
|
||||||
|
|
||||||
|
if has('libcall')
|
||||||
|
call assert_fails("echo libcall('libc.so', 'getenv', 'HOME')", 'E145:')
|
||||||
|
endif
|
||||||
|
call assert_fails("call rename('a', 'b')", 'E145:')
|
||||||
|
call assert_fails("call delete('Xfile')", 'E145:')
|
||||||
|
call assert_fails("call mkdir('Xdir')", 'E145:')
|
||||||
|
call assert_fails('!ls', 'E145:')
|
||||||
|
call assert_fails('shell', 'E145:')
|
||||||
|
call assert_fails('stop', 'E145:')
|
||||||
|
call assert_fails('suspend', 'E145:')
|
||||||
|
call assert_fails('call system("vim")', 'E145:')
|
||||||
|
call assert_fails('call systemlist("vim")', 'E145:')
|
||||||
|
if has('unix')
|
||||||
|
call assert_fails('cd `pwd`', 'E145:')
|
||||||
|
endif
|
||||||
|
|
||||||
|
call writefile(v:errors, 'Xresult')
|
||||||
|
qa!
|
||||||
|
END
|
||||||
|
call writefile(lines, 'Xrestricted')
|
||||||
|
if RunVim([], [], '-Z --clean -S Xrestricted')
|
||||||
|
call assert_equal([], readfile('Xresult'))
|
||||||
|
endif
|
||||||
|
|
||||||
call delete('Xrestricted')
|
call delete('Xrestricted')
|
||||||
call delete('Xrestrout')
|
call delete('Xresult')
|
||||||
endfunc
|
endfunc
|
||||||
|
|
||||||
func Test_restricted_lua()
|
" vim: shiftwidth=2 sts=2 expandtab
|
||||||
if !has('lua')
|
|
||||||
throw 'Skipped: Lua is not supported'
|
|
||||||
endif
|
|
||||||
call Run_restricted_test('lua print("Hello, Vim!")', 'E981:')
|
|
||||||
call Run_restricted_test('luado return "hello"', 'E981:')
|
|
||||||
call Run_restricted_test('luafile somefile', 'E981:')
|
|
||||||
call Run_restricted_test('call luaeval("expression")', 'E145:')
|
|
||||||
endfunc
|
|
||||||
|
|
||||||
func Test_restricted_mzscheme()
|
|
||||||
if !has('mzscheme')
|
|
||||||
throw 'Skipped: MzScheme is not supported'
|
|
||||||
endif
|
|
||||||
call Run_restricted_test('mzscheme statement', 'E981:')
|
|
||||||
call Run_restricted_test('mzfile somefile', 'E981:')
|
|
||||||
call Run_restricted_test('call mzeval("expression")', 'E145:')
|
|
||||||
endfunc
|
|
||||||
|
|
||||||
func Test_restricted_perl()
|
|
||||||
if !has('perl')
|
|
||||||
throw 'Skipped: Perl is not supported'
|
|
||||||
endif
|
|
||||||
" TODO: how to make Safe mode fail?
|
|
||||||
" call Run_restricted_test('perl system("ls")', 'E981:')
|
|
||||||
" call Run_restricted_test('perldo system("hello")', 'E981:')
|
|
||||||
" call Run_restricted_test('perlfile somefile', 'E981:')
|
|
||||||
" call Run_restricted_test('call perleval("system(\"ls\")")', 'E145:')
|
|
||||||
endfunc
|
|
||||||
|
|
||||||
func Test_restricted_python()
|
|
||||||
if !has('python')
|
|
||||||
throw 'Skipped: Python is not supported'
|
|
||||||
endif
|
|
||||||
call Run_restricted_test('python print "hello"', 'E981:')
|
|
||||||
call Run_restricted_test('pydo return "hello"', 'E981:')
|
|
||||||
call Run_restricted_test('pyfile somefile', 'E981:')
|
|
||||||
call Run_restricted_test('call pyeval("expression")', 'E145:')
|
|
||||||
endfunc
|
|
||||||
|
|
||||||
func Test_restricted_python3()
|
|
||||||
if !has('python3')
|
|
||||||
throw 'Skipped: Python3 is not supported'
|
|
||||||
endif
|
|
||||||
call Run_restricted_test('py3 print "hello"', 'E981:')
|
|
||||||
call Run_restricted_test('py3do return "hello"', 'E981:')
|
|
||||||
call Run_restricted_test('py3file somefile', 'E981:')
|
|
||||||
call Run_restricted_test('call py3eval("expression")', 'E145:')
|
|
||||||
endfunc
|
|
||||||
|
|
||||||
func Test_restricted_ruby()
|
|
||||||
if !has('ruby')
|
|
||||||
throw 'Skipped: Ruby is not supported'
|
|
||||||
endif
|
|
||||||
call Run_restricted_test('ruby print "Hello"', 'E981:')
|
|
||||||
call Run_restricted_test('rubydo print "Hello"', 'E981:')
|
|
||||||
call Run_restricted_test('rubyfile somefile', 'E981:')
|
|
||||||
endfunc
|
|
||||||
|
|
||||||
func Test_restricted_tcl()
|
|
||||||
if !has('tcl')
|
|
||||||
throw 'Skipped: Tcl is not supported'
|
|
||||||
endif
|
|
||||||
call Run_restricted_test('tcl puts "Hello"', 'E981:')
|
|
||||||
call Run_restricted_test('tcldo puts "Hello"', 'E981:')
|
|
||||||
call Run_restricted_test('tclfile somefile', 'E981:')
|
|
||||||
endfunc
|
|
||||||
|
@@ -1004,4 +1004,62 @@ def Test_redef_failure()
|
|||||||
delfunc! Func2
|
delfunc! Func2
|
||||||
enddef
|
enddef
|
||||||
|
|
||||||
|
" Test for internal functions returning different types
|
||||||
|
func Test_InternalFuncRetType()
|
||||||
|
let lines =<< trim END
|
||||||
|
def RetFloat(): float
|
||||||
|
return ceil(1.456)
|
||||||
|
enddef
|
||||||
|
|
||||||
|
def RetListAny(): list<any>
|
||||||
|
return items({'k' : 'v'})
|
||||||
|
enddef
|
||||||
|
|
||||||
|
def RetListString(): list<string>
|
||||||
|
return split('a:b:c', ':')
|
||||||
|
enddef
|
||||||
|
|
||||||
|
def RetListDictAny(): list<dict<any>>
|
||||||
|
return getbufinfo()
|
||||||
|
enddef
|
||||||
|
|
||||||
|
def RetDictNumber(): dict<number>
|
||||||
|
return wordcount()
|
||||||
|
enddef
|
||||||
|
|
||||||
|
def RetDictString(): dict<string>
|
||||||
|
return environ()
|
||||||
|
enddef
|
||||||
|
END
|
||||||
|
call writefile(lines, 'Xscript')
|
||||||
|
source Xscript
|
||||||
|
|
||||||
|
call assert_equal(2.0, RetFloat())
|
||||||
|
call assert_equal([['k', 'v']], RetListAny())
|
||||||
|
call assert_equal(['a', 'b', 'c'], RetListString())
|
||||||
|
call assert_notequal([], RetListDictAny())
|
||||||
|
call assert_notequal({}, RetDictNumber())
|
||||||
|
call assert_notequal({}, RetDictString())
|
||||||
|
call delete('Xscript')
|
||||||
|
endfunc
|
||||||
|
|
||||||
|
" Test for passing too many or too few arguments to internal functions
|
||||||
|
func Test_internalfunc_arg_error()
|
||||||
|
let l =<< trim END
|
||||||
|
def! FArgErr(): float
|
||||||
|
return ceil(1.1, 2)
|
||||||
|
enddef
|
||||||
|
END
|
||||||
|
call writefile(l, 'Xinvalidarg')
|
||||||
|
call assert_fails('so Xinvalidarg', 'E118:')
|
||||||
|
let l =<< trim END
|
||||||
|
def! FArgErr(): float
|
||||||
|
return ceil()
|
||||||
|
enddef
|
||||||
|
END
|
||||||
|
call writefile(l, 'Xinvalidarg')
|
||||||
|
call assert_fails('so Xinvalidarg', 'E119:')
|
||||||
|
call delete('Xinvalidarg')
|
||||||
|
endfunc
|
||||||
|
|
||||||
" vim: ts=8 sw=2 sts=2 expandtab tw=80 fdm=marker
|
" vim: ts=8 sw=2 sts=2 expandtab tw=80 fdm=marker
|
||||||
|
@@ -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 */
|
||||||
|
/**/
|
||||||
|
450,
|
||||||
/**/
|
/**/
|
||||||
449,
|
449,
|
||||||
/**/
|
/**/
|
||||||
|
Reference in New Issue
Block a user