summaryrefslogtreecommitdiffstats
path: root/src/testdir/test_restricted.vim
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-07 08:50:31 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-07 08:50:31 +0000
commitaed8ce9da277f5ecffe968b324f242c41c3b752a (patch)
treed2e538394cb7a8a7c42a4aac6ccf1a8e3256999b /src/testdir/test_restricted.vim
parentInitial commit. (diff)
downloadvim-aed8ce9da277f5ecffe968b324f242c41c3b752a.tar.xz
vim-aed8ce9da277f5ecffe968b324f242c41c3b752a.zip
Adding upstream version 2:9.0.1378.upstream/2%9.0.1378upstream
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'src/testdir/test_restricted.vim')
-rw-r--r--src/testdir/test_restricted.vim120
1 files changed, 120 insertions, 0 deletions
diff --git a/src/testdir/test_restricted.vim b/src/testdir/test_restricted.vim
new file mode 100644
index 0000000..d01406e
--- /dev/null
+++ b/src/testdir/test_restricted.vim
@@ -0,0 +1,120 @@
+" Test for "rvim" or "vim -Z"
+
+source shared.vim
+
+"if has('win32') && has('gui')
+" " Win32 GUI shows a dialog instead of displaying the error in the last line.
+" 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('unix') && 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('exe "normal \<C-Z>"', 'E145:')
+ set insertmode
+ call assert_fails('call feedkeys("\<C-Z>", "xt")', 'E145:')
+ set insertmode&
+ call assert_fails('suspend', 'E145:')
+ call assert_fails('call system("ls")', 'E145:')
+ call assert_fails('call systemlist("ls")', 'E145:')
+ if has('unix')
+ call assert_fails('cd `pwd`', 'E145:')
+ endif
+
+ call writefile(v:errors, 'Xresult')
+ qa!
+ END
+ call writefile(lines, 'Xrestricted', 'D')
+ if RunVim([], [], '-Z --clean -S Xrestricted')
+ call assert_equal([], readfile('Xresult'))
+ endif
+ call delete('Xresult')
+ if has('unix') && RunVimPiped([], [], '--clean -S Xrestricted', 'SHELL=/bin/false ')
+ call assert_equal([], readfile('Xresult'))
+ endif
+ call delete('Xresult')
+ if has('unix') && RunVimPiped([], [], '--clean -S Xrestricted', 'SHELL=/sbin/nologin')
+ call assert_equal([], readfile('Xresult'))
+ endif
+
+ call delete('Xresult')
+endfunc
+
+" vim: shiftwidth=2 sts=2 expandtab