Patch 8.2.0450
Problem:    Not enough testing for restricted mode and function calls.
Solution:   Add more tests. (Yegappan Lakshmanan, closes #5847)
Files:      src/testdir/test_method.vim, src/testdir/test_restricted.vim,
            src/testdir/test_vim9_script.vim


*** ../vim-8.2.0449/src/testdir/test_method.vim 2020-03-20 18:20:47.080975621 
+0100
--- src/testdir/test_method.vim 2020-03-26 14:09:58.719386928 +0100
***************
*** 152,157 ****
  
  func Test_method_not_supported()
    call assert_fails('eval 123->changenr()', 'E276:')
  endfunc
  
! " vim: shiftwidth=2 sts=2 expandtab
--- 152,173 ----
  
  func Test_method_not_supported()
    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
  
! " 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
*** ../vim-8.2.0449/src/testdir/test_restricted.vim     2019-02-11 
21:43:42.000000000 +0100
--- src/testdir/test_restricted.vim     2020-03-26 14:09:58.719386928 +0100
***************
*** 7,103 ****
  "  finish
  "endif
  
! func Test_restricted()
!   call Run_restricted_test('!ls', 'E145:')
! endfunc
! 
! func Run_restricted_test(ex_cmd, error)
!   let cmd = GetVimCommand('Xrestricted')
!   if cmd == ''
!     return
    endif
  
-   " Use a VimEnter autocommand to avoid that the error message is displayed in
-   " a dialog with an OK button.
-   call writefile([
-       \ "func Init()",
-       \ "  silent! " . a:ex_cmd,
-       \ "  call writefile([v:errmsg], 'Xrestrout')",
-       \ "  qa!",
-       \ "endfunc",
-       \ "au VimEnter * call Init()",
-       \ ], 'Xrestricted')
-   call system(cmd . ' -Z')
-   call assert_match(a:error, join(readfile('Xrestrout')))
- 
    call delete('Xrestricted')
!   call delete('Xrestrout')
! endfunc
! 
! func Test_restricted_lua()
!   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
--- 7,109 ----
  "  finish
  "endif
  
! func Test_restricted_mode()
!   let lines =<< trim END
!     if has('lua')
!       call assert_fails('lua print("Hello, Vim!")', 'E981:')
!       call assert_fails('luado return "hello"', 'E981:')
!       call assert_fails('luafile somefile', 'E981:')
!       call assert_fails('call luaeval("expression")', 'E145:')
!     endif
! 
!     if has('mzscheme')
!       call assert_fails('mzscheme statement', 'E981:')
!       call assert_fails('mzfile somefile', 'E981:')
!       call assert_fails('call mzeval("expression")', 'E145:')
!     endif
! 
!     if has('perl')
!       " TODO: how to make Safe mode fail?
!       " call assert_fails('perl system("ls")', 'E981:')
!       " call assert_fails('perldo system("hello")', 'E981:')
!       " call assert_fails('perlfile somefile', 'E981:')
!       " 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('Xresult')
  endfunc
  
! " vim: shiftwidth=2 sts=2 expandtab
*** ../vim-8.2.0449/src/testdir/test_vim9_script.vim    2020-03-26 
13:15:38.582501280 +0100
--- src/testdir/test_vim9_script.vim    2020-03-26 14:09:58.719386928 +0100
***************
*** 1004,1007 ****
--- 1004,1065 ----
    delfunc! Func2
  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-8.2.0449/src/version.c       2020-03-26 13:15:38.582501280 +0100
--- src/version.c       2020-03-26 14:11:06.995155160 +0100
***************
*** 740,741 ****
--- 740,743 ----
  {   /* Add new patch number below this line */
+ /**/
+     450,
  /**/

-- 
I'm sure that I asked CBuilder to do a "full" install.  Looks like I got
a "fool" install, instead.              Charles E Campbell, Jr, PhD


 /// Bram Moolenaar -- [email protected] -- http://www.Moolenaar.net   \\\
///        sponsor Vim, vote for features -- http://www.Vim.org/sponsor/ \\\
\\\  an exciting new programming language -- http://www.Zimbu.org        ///
 \\\            help me help AIDS victims -- http://ICCF-Holland.org    ///

-- 
-- 
You received this message from the "vim_dev" maillist.
Do not top-post! Type your reply below the text you are replying to.
For more information, visit http://www.vim.org/maillist.php

--- 
You received this message because you are subscribed to the Google Groups 
"vim_dev" group.
To unsubscribe from this group and stop receiving emails from it, send an email 
to [email protected].
To view this discussion on the web visit 
https://groups.google.com/d/msgid/vim_dev/202003261312.02QDCYCW010965%40masaka.moolenaar.net.

Raspunde prin e-mail lui