blob: ceee044ca35fc656f8571e39bb02ae74c24f87d8 [file] [log] [blame]
Bram Moolenaar66459b72016-08-06 19:01:55 +02001" Tests for startup.
Bram Moolenaarb9a46fe2016-07-29 18:13:42 +02002
Bram Moolenaar66459b72016-08-06 19:01:55 +02003source shared.vim
Bram Moolenaarc75e8122019-04-21 15:55:10 +02004source screendump.vim
Bram Moolenaar8c5a2782019-08-07 23:07:07 +02005source check.vim
Bram Moolenaar66459b72016-08-06 19:01:55 +02006
7" Check that loading startup.vim works.
Bram Moolenaarb9a46fe2016-07-29 18:13:42 +02008func Test_startup_script()
9 set compatible
10 source $VIMRUNTIME/defaults.vim
11
12 call assert_equal(0, &compatible)
13endfunc
Bram Moolenaar66459b72016-08-06 19:01:55 +020014
15" Verify the order in which plugins are loaded:
16" 1. plugins in non-after directories
17" 2. packages
18" 3. plugins in after directories
19func Test_after_comes_later()
Bram Moolenaar32860432016-08-06 19:24:23 +020020 if !has('packages')
21 return
22 endif
Bram Moolenaarc79745a2019-05-20 22:12:34 +020023 let before =<< trim [CODE]
24 set nocp viminfo+=nviminfo
25 set guioptions+=M
26 let $HOME = "/does/not/exist"
27 set loadplugins
28 set rtp=Xhere,Xafter,Xanother
29 set packpath=Xhere,Xafter
30 set nomore
31 let g:sequence = ""
32 [CODE]
33
34 let after =<< trim [CODE]
35 redir! > Xtestout
36 scriptnames
37 redir END
38 redir! > Xsequence
39 echo g:sequence
40 redir END
41 quit
42 [CODE]
43
Bram Moolenaar66459b72016-08-06 19:01:55 +020044 call mkdir('Xhere/plugin', 'p')
Bram Moolenaar07ecfa62017-06-27 14:43:55 +020045 call writefile(['let g:sequence .= "here "'], 'Xhere/plugin/here.vim')
46 call mkdir('Xanother/plugin', 'p')
47 call writefile(['let g:sequence .= "another "'], 'Xanother/plugin/another.vim')
Bram Moolenaar66459b72016-08-06 19:01:55 +020048 call mkdir('Xhere/pack/foo/start/foobar/plugin', 'p')
Bram Moolenaar07ecfa62017-06-27 14:43:55 +020049 call writefile(['let g:sequence .= "pack "'], 'Xhere/pack/foo/start/foobar/plugin/foo.vim')
Bram Moolenaar66459b72016-08-06 19:01:55 +020050
51 call mkdir('Xafter/plugin', 'p')
Bram Moolenaar07ecfa62017-06-27 14:43:55 +020052 call writefile(['let g:sequence .= "after "'], 'Xafter/plugin/later.vim')
Bram Moolenaar66459b72016-08-06 19:01:55 +020053
Bram Moolenaar472a0a82016-08-06 22:31:42 +020054 if RunVim(before, after, '')
Bram Moolenaar66459b72016-08-06 19:01:55 +020055
Bram Moolenaar83b3c3d2016-08-06 19:16:43 +020056 let lines = readfile('Xtestout')
Bram Moolenaar07ecfa62017-06-27 14:43:55 +020057 let expected = ['Xbefore.vim', 'here.vim', 'another.vim', 'foo.vim', 'later.vim', 'Xafter.vim']
Bram Moolenaar83b3c3d2016-08-06 19:16:43 +020058 let found = []
59 for line in lines
60 for one in expected
61 if line =~ one
62 call add(found, one)
63 endif
64 endfor
Bram Moolenaar66459b72016-08-06 19:01:55 +020065 endfor
Bram Moolenaar83b3c3d2016-08-06 19:16:43 +020066 call assert_equal(expected, found)
67 endif
Bram Moolenaar66459b72016-08-06 19:01:55 +020068
Bram Moolenaar07ecfa62017-06-27 14:43:55 +020069 call assert_equal('here another pack after', substitute(join(readfile('Xsequence', 1), ''), '\s\+$', '', ''))
70
Bram Moolenaar66459b72016-08-06 19:01:55 +020071 call delete('Xtestout')
Bram Moolenaar07ecfa62017-06-27 14:43:55 +020072 call delete('Xsequence')
Bram Moolenaar66459b72016-08-06 19:01:55 +020073 call delete('Xhere', 'rf')
Bram Moolenaar07ecfa62017-06-27 14:43:55 +020074 call delete('Xanother', 'rf')
Bram Moolenaar66459b72016-08-06 19:01:55 +020075 call delete('Xafter', 'rf')
76endfunc
Bram Moolenaar472a0a82016-08-06 22:31:42 +020077
Bram Moolenaarce876aa2017-06-04 17:47:42 +020078func Test_pack_in_rtp_when_plugins_run()
79 if !has('packages')
80 return
81 endif
Bram Moolenaarc79745a2019-05-20 22:12:34 +020082 let before =<< trim [CODE]
83 set nocp viminfo+=nviminfo
84 set guioptions+=M
85 let $HOME = "/does/not/exist"
86 set loadplugins
87 set rtp=Xhere
88 set packpath=Xhere
89 set nomore
90 [CODE]
91
Bram Moolenaarce876aa2017-06-04 17:47:42 +020092 let after = [
93 \ 'quit',
94 \ ]
95 call mkdir('Xhere/plugin', 'p')
96 call writefile(['redir! > Xtestout', 'silent set runtimepath?', 'silent! call foo#Trigger()', 'redir END'], 'Xhere/plugin/here.vim')
97 call mkdir('Xhere/pack/foo/start/foobar/autoload', 'p')
98 call writefile(['function! foo#Trigger()', 'echo "autoloaded foo"', 'endfunction'], 'Xhere/pack/foo/start/foobar/autoload/foo.vim')
99
100 if RunVim(before, after, '')
101
102 let lines = filter(readfile('Xtestout'), '!empty(v:val)')
103 call assert_match('Xhere[/\\]pack[/\\]foo[/\\]start[/\\]foobar', get(lines, 0))
104 call assert_match('autoloaded foo', get(lines, 1))
105 endif
106
107 call delete('Xtestout')
108 call delete('Xhere', 'rf')
109endfunc
110
Bram Moolenaar472a0a82016-08-06 22:31:42 +0200111func Test_help_arg()
Bram Moolenaar3321e9d2016-08-06 23:03:59 +0200112 if !has('unix') && has('gui')
113 " this doesn't work with gvim on MS-Windows
114 return
115 endif
Bram Moolenaar472a0a82016-08-06 22:31:42 +0200116 if RunVim([], [], '--help >Xtestout')
117 let lines = readfile('Xtestout')
118 call assert_true(len(lines) > 20)
Bram Moolenaarba98bef2016-08-07 15:51:39 +0200119 call assert_match('Vi IMproved', lines[0])
Bram Moolenaar472a0a82016-08-06 22:31:42 +0200120
121 " check if couple of lines are there
Bram Moolenaar50fa8dd2016-08-09 22:58:21 +0200122 let found = []
Bram Moolenaar472a0a82016-08-06 22:31:42 +0200123 for line in lines
124 if line =~ '-R.*Readonly mode'
Bram Moolenaar50fa8dd2016-08-09 22:58:21 +0200125 call add(found, 'Readonly mode')
Bram Moolenaar472a0a82016-08-06 22:31:42 +0200126 endif
Bram Moolenaar50fa8dd2016-08-09 22:58:21 +0200127 " Watch out for a second --version line in the Gnome version.
128 if line =~ '--version.*Print version information and exit'
129 call add(found, "--version")
Bram Moolenaar472a0a82016-08-06 22:31:42 +0200130 endif
131 endfor
Bram Moolenaar50fa8dd2016-08-09 22:58:21 +0200132 call assert_equal(['Readonly mode', '--version'], found)
Bram Moolenaar472a0a82016-08-06 22:31:42 +0200133 endif
134 call delete('Xtestout')
135endfunc
Bram Moolenaarba98bef2016-08-07 15:51:39 +0200136
137func Test_compatible_args()
Bram Moolenaarc79745a2019-05-20 22:12:34 +0200138 let after =<< trim [CODE]
139 call writefile([string(&compatible)], "Xtestout")
140 set viminfo+=nviminfo
141 quit
142 [CODE]
143
Bram Moolenaarba98bef2016-08-07 15:51:39 +0200144 if RunVim([], after, '-C')
145 let lines = readfile('Xtestout')
146 call assert_equal('1', lines[0])
147 endif
148
149 if RunVim([], after, '-N')
150 let lines = readfile('Xtestout')
151 call assert_equal('0', lines[0])
152 endif
153
154 call delete('Xtestout')
155endfunc
156
Bram Moolenaar8f4499b2018-09-16 16:28:11 +0200157" Test the -o[N] and -O[N] arguments to open N windows split
158" horizontally or vertically.
159func Test_o_arg()
Bram Moolenaarc79745a2019-05-20 22:12:34 +0200160 let after =<< trim [CODE]
Bram Moolenaare96a2492019-06-25 04:12:16 +0200161 set cpo&vim
Bram Moolenaarc79745a2019-05-20 22:12:34 +0200162 call writefile([winnr("$"),
163 \ winheight(1), winheight(2), &lines,
164 \ winwidth(1), winwidth(2), &columns,
165 \ bufname(winbufnr(1)), bufname(winbufnr(2))],
166 \ "Xtestout")
167 qall
168 [CODE]
169
Bram Moolenaar8f4499b2018-09-16 16:28:11 +0200170 if RunVim([], after, '-o2')
171 " Open 2 windows split horizontally. Expect:
172 " - 2 windows
173 " - both windows should have the same or almost the same height
174 " - sum of both windows height (+ 3 for both statusline and Ex command)
175 " should be equal to the number of lines
176 " - both windows should have the same width which should be equal to the
177 " number of columns
178 " - buffer of both windows should have no name
179 let [wn, wh1, wh2, ln, ww1, ww2, cn, bn1, bn2] = readfile('Xtestout')
180 call assert_equal('2', wn)
181 call assert_inrange(0, 1, wh1 - wh2)
182 call assert_equal(string(wh1 + wh2 + 3), ln)
183 call assert_equal(ww1, ww2)
184 call assert_equal(ww1, cn)
185 call assert_equal('', bn1)
186 call assert_equal('', bn2)
187 endif
188
189 if RunVim([], after, '-o foo bar')
190 " Same expectations as for -o2 but buffer names should be foo and bar
191 let [wn, wh1, wh2, ln, ww1, ww2, cn, bn1, bn2] = readfile('Xtestout')
192 call assert_equal('2', wn)
193 call assert_inrange(0, 1, wh1 - wh2)
194 call assert_equal(string(wh1 + wh2 + 3), ln)
195 call assert_equal(ww1, ww2)
196 call assert_equal(ww1, cn)
197 call assert_equal('foo', bn1)
198 call assert_equal('bar', bn2)
199 endif
200
201 if RunVim([], after, '-O2')
202 " Open 2 windows split vertically. Expect:
203 " - 2 windows
204 " - both windows should have the same or almost the same width
Bram Moolenaar036b09c2018-09-21 12:54:06 +0200205 " - sum of both windows width (+ 1 for the separator) should be equal to
206 " the number of columns
Bram Moolenaar8f4499b2018-09-16 16:28:11 +0200207 " - both windows should have the same height
208 " - window height (+ 2 for the statusline and Ex command) should be equal
209 " to the number of lines
Bram Moolenaar9e81db92018-09-18 22:37:31 +0200210 " - buffer of both windows should have no name
Bram Moolenaar8f4499b2018-09-16 16:28:11 +0200211 let [wn, wh1, wh2, ln, ww1, ww2, cn, bn1, bn2] = readfile('Xtestout')
212 call assert_equal('2', wn)
213 call assert_inrange(0, 1, ww1 - ww2)
214 call assert_equal(string(ww1 + ww2 + 1), cn)
215 call assert_equal(wh1, wh2)
216 call assert_equal(string(wh1 + 2), ln)
217 call assert_equal('', bn1)
218 call assert_equal('', bn2)
219 endif
220
221 if RunVim([], after, '-O foo bar')
222 " Same expectations as for -O2 but buffer names should be foo and bar
223 let [wn, wh1, wh2, ln, ww1, ww2, cn, bn1, bn2] = readfile('Xtestout')
224 call assert_equal('2', wn)
225 call assert_inrange(0, 1, ww1 - ww2)
226 call assert_equal(string(ww1 + ww2 + 1), cn)
227 call assert_equal(wh1, wh2)
228 call assert_equal(string(wh1 + 2), ln)
229 call assert_equal('foo', bn1)
230 call assert_equal('bar', bn2)
231 endif
232
233 call delete('Xtestout')
234endfunc
235
Bram Moolenaar9e81db92018-09-18 22:37:31 +0200236" Test the -p[N] argument to open N tabpages.
237func Test_p_arg()
Bram Moolenaarc79745a2019-05-20 22:12:34 +0200238 let after =<< trim [CODE]
239 call writefile(split(execute("tabs"), "\n"), "Xtestout")
240 qall
241 [CODE]
242
Bram Moolenaar9e81db92018-09-18 22:37:31 +0200243 if RunVim([], after, '-p2')
244 let lines = readfile('Xtestout')
245 call assert_equal(4, len(lines))
246 call assert_equal('Tab page 1', lines[0])
247 call assert_equal('> [No Name]', lines[1])
248 call assert_equal('Tab page 2', lines[2])
249 call assert_equal(' [No Name]', lines[3])
250 endif
251
252 if RunVim([], after, '-p foo bar')
253 let lines = readfile('Xtestout')
254 call assert_equal(4, len(lines))
255 call assert_equal('Tab page 1', lines[0])
256 call assert_equal('> foo', lines[1])
257 call assert_equal('Tab page 2', lines[2])
258 call assert_equal(' bar', lines[3])
259 endif
260
261 call delete('Xtestout')
262endfunc
263
Bram Moolenaar4b1c9a92018-09-19 21:06:31 +0200264" Test the -V[N] argument to set the 'verbose' option to [N]
Bram Moolenaar9e81db92018-09-18 22:37:31 +0200265func Test_V_arg()
Bram Moolenaar8c5a2782019-08-07 23:07:07 +0200266 " Can't catch the output of gvim.
267 CheckNotGui
268
Bram Moolenaar9e81db92018-09-18 22:37:31 +0200269 let out = system(GetVimCommand() . ' --clean -es -X -V0 -c "set verbose?" -cq')
270 call assert_equal(" verbose=0\n", out)
271
272 let out = system(GetVimCommand() . ' --clean -es -X -V2 -c "set verbose?" -cq')
Bram Moolenaar4b1c9a92018-09-19 21:06:31 +0200273 call assert_match("sourcing \"$VIMRUNTIME[\\/]defaults\.vim\"\r\nSearching for \"filetype\.vim\".*\n", out)
274 call assert_match(" verbose=2\n", out)
Bram Moolenaar9e81db92018-09-18 22:37:31 +0200275
276 let out = system(GetVimCommand() . ' --clean -es -X -V15 -c "set verbose?" -cq')
Bram Moolenaar4b1c9a92018-09-19 21:06:31 +0200277 call assert_match("sourcing \"$VIMRUNTIME[\\/]defaults\.vim\"\r\nline 1: \" The default vimrc file\..* verbose=15\n", out)
Bram Moolenaar9e81db92018-09-18 22:37:31 +0200278endfunc
279
Bram Moolenaar54948182018-12-28 18:32:56 +0100280" Test the '-q [errorfile]' argument.
281func Test_q_arg()
282 let source_file = has('win32') ? '..\memfile.c' : '../memfile.c'
Bram Moolenaarc79745a2019-05-20 22:12:34 +0200283 let after =<< trim [CODE]
284 call writefile([&errorfile, string(getpos("."))], "Xtestout")
285 copen
286 w >> Xtestout
287 qall
288 [CODE]
Bram Moolenaar54948182018-12-28 18:32:56 +0100289
290 " Test with default argument '-q'.
291 call assert_equal('errors.err', &errorfile)
Bram Moolenaarb58a4b92019-05-27 23:36:21 +0200292 call writefile(["../memfile.c:208:5: error: expected ';' before '}' token"], 'errors.err')
Bram Moolenaar54948182018-12-28 18:32:56 +0100293 if RunVim([], after, '-q')
294 let lines = readfile('Xtestout')
295 call assert_equal(['errors.err',
Bram Moolenaarb58a4b92019-05-27 23:36:21 +0200296 \ '[0, 208, 5, 0]',
297 \ source_file . "|208 col 5| error: expected ';' before '}' token"],
Bram Moolenaar54948182018-12-28 18:32:56 +0100298 \ lines)
299 endif
300 call delete('Xtestout')
301 call delete('errors.err')
302
303 " Test with explicit argument '-q Xerrors' (with space).
Bram Moolenaarb58a4b92019-05-27 23:36:21 +0200304 call writefile(["../memfile.c:208:5: error: expected ';' before '}' token"], 'Xerrors')
Bram Moolenaar54948182018-12-28 18:32:56 +0100305 if RunVim([], after, '-q Xerrors')
306 let lines = readfile('Xtestout')
307 call assert_equal(['Xerrors',
Bram Moolenaarb58a4b92019-05-27 23:36:21 +0200308 \ '[0, 208, 5, 0]',
309 \ source_file . "|208 col 5| error: expected ';' before '}' token"],
Bram Moolenaar54948182018-12-28 18:32:56 +0100310 \ lines)
311 endif
312 call delete('Xtestout')
313
314 " Test with explicit argument '-qXerrors' (without space).
315 if RunVim([], after, '-qXerrors')
316 let lines = readfile('Xtestout')
317 call assert_equal(['Xerrors',
Bram Moolenaarb58a4b92019-05-27 23:36:21 +0200318 \ '[0, 208, 5, 0]',
319 \ source_file . "|208 col 5| error: expected ';' before '}' token"],
Bram Moolenaar54948182018-12-28 18:32:56 +0100320 \ lines)
321 endif
322
323 call delete('Xtestout')
324 call delete('Xerrors')
325endfunc
326
Bram Moolenaar036b09c2018-09-21 12:54:06 +0200327" Test the -V[N]{filename} argument to set the 'verbose' option to N
328" and set 'verbosefile' to filename.
329func Test_V_file_arg()
Bram Moolenaar4841a7c2018-09-22 14:08:49 +0200330 if RunVim([], [], ' --clean -V2Xverbosefile -c "set verbose? verbosefile?" -cq')
Bram Moolenaar036b09c2018-09-21 12:54:06 +0200331 let out = join(readfile('Xverbosefile'), "\n")
332 call assert_match("sourcing \"$VIMRUNTIME[\\/]defaults\.vim\"\n", out)
333 call assert_match("\n verbose=2\n", out)
334 call assert_match("\n verbosefile=Xverbosefile", out)
335 endif
336
337 call delete('Xverbosefile')
338endfunc
339
340" Test the -m, -M and -R arguments:
341" -m resets 'write'
342" -M resets 'modifiable' and 'write'
343" -R sets 'readonly'
344func Test_m_M_R()
Bram Moolenaarc79745a2019-05-20 22:12:34 +0200345 let after =<< trim [CODE]
346 call writefile([&write, &modifiable, &readonly, &updatecount], "Xtestout")
347 qall
348 [CODE]
349
Bram Moolenaar036b09c2018-09-21 12:54:06 +0200350 if RunVim([], after, '')
351 let lines = readfile('Xtestout')
352 call assert_equal(['1', '1', '0', '200'], lines)
353 endif
354 if RunVim([], after, '-m')
355 let lines = readfile('Xtestout')
356 call assert_equal(['0', '1', '0', '200'], lines)
357 endif
358 if RunVim([], after, '-M')
359 let lines = readfile('Xtestout')
360 call assert_equal(['0', '0', '0', '200'], lines)
361 endif
362 if RunVim([], after, '-R')
363 let lines = readfile('Xtestout')
364 call assert_equal(['1', '1', '1', '10000'], lines)
365 endif
366
367 call delete('Xtestout')
368endfunc
369
Bram Moolenaar9e81db92018-09-18 22:37:31 +0200370" Test the -A, -F and -H arguments (Arabic, Farsi and Hebrew modes).
371func Test_A_F_H_arg()
Bram Moolenaarc79745a2019-05-20 22:12:34 +0200372 let after =<< trim [CODE]
373 call writefile([&rightleft, &arabic, &fkmap, &hkmap], "Xtestout")
374 qall
375 [CODE]
376
Bram Moolenaar4b1c9a92018-09-19 21:06:31 +0200377 " Use silent Ex mode to avoid the hit-Enter prompt for the warning that
378 " 'encoding' is not utf-8.
379 if has('arabic') && &encoding == 'utf-8' && RunVim([], after, '-e -s -A')
Bram Moolenaar9e81db92018-09-18 22:37:31 +0200380 let lines = readfile('Xtestout')
381 call assert_equal(['1', '1', '0', '0'], lines)
382 endif
383
384 if has('farsi') && RunVim([], after, '-F')
385 let lines = readfile('Xtestout')
386 call assert_equal(['1', '0', '1', '0'], lines)
387 endif
388
389 if has('rightleft') && RunVim([], after, '-H')
390 let lines = readfile('Xtestout')
391 call assert_equal(['1', '0', '0', '1'], lines)
392 endif
393
394 call delete('Xtestout')
395endfunc
396
Bram Moolenaarba9ea912019-05-07 22:10:50 +0200397func Test_invalid_args()
Bram Moolenaar8c5a2782019-08-07 23:07:07 +0200398 " must be able to get the output of Vim.
399 CheckUnix
400 CheckNotGui
Bram Moolenaarba9ea912019-05-07 22:10:50 +0200401
402 for opt in ['-Y', '--does-not-exist']
403 let out = split(system(GetVimCommand() .. ' ' .. opt), "\n")
404 call assert_equal(1, v:shell_error)
405 call assert_match('^VIM - Vi IMproved .* (.*)$', out[0])
406 call assert_equal('Unknown option argument: "' .. opt .. '"', out[1])
407 call assert_equal('More info with: "vim -h"', out[2])
408 endfor
409
410 for opt in ['-c', '-i', '-s', '-t', '-T', '-u', '-U', '-w', '-W', '--cmd', '--startuptime']
411 let out = split(system(GetVimCommand() .. ' ' .. opt), "\n")
412 call assert_equal(1, v:shell_error)
413 call assert_match('^VIM - Vi IMproved .* (.*)$', out[0])
414 call assert_equal('Argument missing after: "' .. opt .. '"', out[1])
415 call assert_equal('More info with: "vim -h"', out[2])
416 endfor
417
418 if has('clientserver')
Bram Moolenaarba9ea912019-05-07 22:10:50 +0200419 for opt in ['--remote', '--remote-send', '--remote-silent', '--remote-expr',
420 \ '--remote-tab', '--remote-tab-wait',
421 \ '--remote-tab-wait-silent', '--remote-tab-silent',
422 \ '--remote-wait', '--remote-wait-silent',
Bram Moolenaar27821262019-05-08 16:41:09 +0200423 \ '--servername',
Bram Moolenaarba9ea912019-05-07 22:10:50 +0200424 \ ]
425 let out = split(system(GetVimCommand() .. ' ' .. opt), "\n")
426 call assert_equal(1, v:shell_error)
427 call assert_match('^VIM - Vi IMproved .* (.*)$', out[0])
428 call assert_equal('Argument missing after: "' .. opt .. '"', out[1])
429 call assert_equal('More info with: "vim -h"', out[2])
430 endfor
431 endif
432
Bram Moolenaar240f7ab2019-05-08 17:58:15 +0200433 if has('gui_gtk')
Bram Moolenaar27821262019-05-08 16:41:09 +0200434 let out = split(system(GetVimCommand() .. ' --display'), "\n")
435 call assert_equal(1, v:shell_error)
436 call assert_match('^VIM - Vi IMproved .* (.*)$', out[0])
437 call assert_equal('Argument missing after: "--display"', out[1])
438 call assert_equal('More info with: "vim -h"', out[2])
439 endif
Bram Moolenaarba9ea912019-05-07 22:10:50 +0200440
Bram Moolenaar5416b752019-05-08 18:36:43 +0200441 if has('xterm_clipboard')
Bram Moolenaar240f7ab2019-05-08 17:58:15 +0200442 let out = split(system(GetVimCommand() .. ' -display'), "\n")
443 call assert_equal(1, v:shell_error)
444 call assert_match('^VIM - Vi IMproved .* (.*)$', out[0])
445 call assert_equal('Argument missing after: "-display"', out[1])
446 call assert_equal('More info with: "vim -h"', out[2])
447 endif
448
Bram Moolenaarba9ea912019-05-07 22:10:50 +0200449 let out = split(system(GetVimCommand() .. ' -ix'), "\n")
450 call assert_equal(1, v:shell_error)
451 call assert_match('^VIM - Vi IMproved .* (.*)$', out[0])
452 call assert_equal('Garbage after option argument: "-ix"', out[1])
453 call assert_equal('More info with: "vim -h"', out[2])
454
455 let out = split(system(GetVimCommand() .. ' - xxx'), "\n")
456 call assert_equal(1, v:shell_error)
457 call assert_match('^VIM - Vi IMproved .* (.*)$', out[0])
458 call assert_equal('Too many edit arguments: "xxx"', out[1])
459 call assert_equal('More info with: "vim -h"', out[2])
460
461 " Detect invalid repeated arguments '-t foo -t foo", '-q foo -q foo'.
462 for opt in ['-t', '-q']
463 let out = split(system(GetVimCommand() .. repeat(' ' .. opt .. ' foo', 2)), "\n")
464 call assert_equal(1, v:shell_error)
465 call assert_match('^VIM - Vi IMproved .* (.*)$', out[0])
466 call assert_equal('Too many edit arguments: "' .. opt .. '"', out[1])
467 call assert_equal('More info with: "vim -h"', out[2])
468 endfor
469
470 for opt in [' -cq', ' --cmd q', ' +', ' -S foo']
471 let out = split(system(GetVimCommand() .. repeat(opt, 11)), "\n")
472 call assert_equal(1, v:shell_error)
473 " FIXME: The error message given by Vim is not ideal in case of repeated
474 " -S foo since it does not mention -S.
475 call assert_match('^VIM - Vi IMproved .* (.*)$', out[0])
476 call assert_equal('Too many "+command", "-c command" or "--cmd command" arguments', out[1])
477 call assert_equal('More info with: "vim -h"', out[2])
478 endfor
479
Bram Moolenaar27821262019-05-08 16:41:09 +0200480 if has('gui_gtk')
481 for opt in ['--socketid x', '--socketid 0xg']
482 let out = split(system(GetVimCommand() .. ' ' .. opt), "\n")
483 call assert_equal(1, v:shell_error)
484 call assert_match('^VIM - Vi IMproved .* (.*)$', out[0])
485 call assert_equal('Invalid argument for: "--socketid"', out[1])
486 call assert_equal('More info with: "vim -h"', out[2])
487 endfor
488 endif
Bram Moolenaarba9ea912019-05-07 22:10:50 +0200489endfunc
490
Bram Moolenaarba98bef2016-08-07 15:51:39 +0200491func Test_file_args()
Bram Moolenaarc79745a2019-05-20 22:12:34 +0200492 let after =<< trim [CODE]
493 call writefile(argv(), "Xtestout")
494 qall
495 [CODE]
496
Bram Moolenaarba98bef2016-08-07 15:51:39 +0200497 if RunVim([], after, '')
498 let lines = readfile('Xtestout')
499 call assert_equal(0, len(lines))
500 endif
501
502 if RunVim([], after, 'one')
503 let lines = readfile('Xtestout')
504 call assert_equal(1, len(lines))
505 call assert_equal('one', lines[0])
506 endif
507
508 if RunVim([], after, 'one two three')
509 let lines = readfile('Xtestout')
510 call assert_equal(3, len(lines))
511 call assert_equal('one', lines[0])
512 call assert_equal('two', lines[1])
513 call assert_equal('three', lines[2])
514 endif
515
516 if RunVim([], after, 'one -c echo two')
517 let lines = readfile('Xtestout')
518 call assert_equal(2, len(lines))
519 call assert_equal('one', lines[0])
520 call assert_equal('two', lines[1])
521 endif
522
523 if RunVim([], after, 'one -- -c echo two')
524 let lines = readfile('Xtestout')
525 call assert_equal(4, len(lines))
526 call assert_equal('one', lines[0])
527 call assert_equal('-c', lines[1])
528 call assert_equal('echo', lines[2])
529 call assert_equal('two', lines[3])
530 endif
531
532 call delete('Xtestout')
533endfunc
534
535func Test_startuptime()
536 if !has('startuptime')
537 return
538 endif
539 let after = ['qall']
540 if RunVim([], after, '--startuptime Xtestout one')
541 let lines = readfile('Xtestout')
542 let expected = ['--- VIM STARTING ---', 'parsing arguments',
543 \ 'shell init', 'inits 3', 'start termcap', 'opening buffers']
544 let found = []
545 for line in lines
546 for exp in expected
547 if line =~ exp
548 call add(found, exp)
549 endif
550 endfor
551 endfor
552 call assert_equal(expected, found)
553 endif
554 call delete('Xtestout')
555endfunc
Bram Moolenaar3a938382016-08-07 16:36:40 +0200556
557func Test_read_stdin()
Bram Moolenaarc79745a2019-05-20 22:12:34 +0200558 let after =<< trim [CODE]
559 write Xtestout
560 quit!
561 [CODE]
562
Bram Moolenaar3a938382016-08-07 16:36:40 +0200563 if RunVimPiped([], after, '-', 'echo something | ')
564 let lines = readfile('Xtestout')
Bram Moolenaare4a76ad2016-08-07 16:50:10 +0200565 " MS-Windows adds a space after the word
566 call assert_equal(['something'], split(lines[0]))
Bram Moolenaar3a938382016-08-07 16:36:40 +0200567 endif
568 call delete('Xtestout')
569endfunc
Bram Moolenaar08cab962017-03-04 14:37:18 +0100570
Bram Moolenaar4bfa8af2018-02-03 15:14:46 +0100571func Test_set_shell()
Bram Moolenaarc79745a2019-05-20 22:12:34 +0200572 let after =<< trim [CODE]
573 call writefile([&shell], "Xtestout")
574 quit!
575 [CODE]
576
Bram Moolenaar4bfa8af2018-02-03 15:14:46 +0100577 let $SHELL = '/bin/with space/sh'
578 if RunVimPiped([], after, '', '')
579 let lines = readfile('Xtestout')
580 " MS-Windows adds a space after the word
581 call assert_equal('/bin/with\ space/sh', lines[0])
582 endif
583 call delete('Xtestout')
584endfunc
585
Bram Moolenaar08cab962017-03-04 14:37:18 +0100586func Test_progpath()
587 " Tests normally run with "./vim" or "../vim", these must have been expanded
588 " to a full path.
589 if has('unix')
590 call assert_equal('/', v:progpath[0])
591 elseif has('win32')
592 call assert_equal(':', v:progpath[1])
593 call assert_match('[/\\]', v:progpath[2])
594 endif
595
596 " Only expect "vim" to appear in v:progname.
597 call assert_match('vim\c', v:progname)
598endfunc
Bram Moolenaard5d37532017-03-27 23:02:07 +0200599
600func Test_silent_ex_mode()
Bram Moolenaar8c5a2782019-08-07 23:07:07 +0200601 " must be able to get the output of Vim.
602 CheckUnix
603 CheckNotGui
Bram Moolenaard5d37532017-03-27 23:02:07 +0200604
605 " This caused an ml_get error.
606 let out = system(GetVimCommand() . '-u NONE -es -c''set verbose=1|h|exe "%norm\<c-y>\<c-d>"'' -c cq')
607 call assert_notmatch('E315:', out)
608endfunc
Bram Moolenaar85045a72017-04-02 16:54:09 +0200609
610func Test_default_term()
Bram Moolenaar8c5a2782019-08-07 23:07:07 +0200611 " must be able to get the output of Vim.
612 CheckUnix
613 CheckNotGui
Bram Moolenaar85045a72017-04-02 16:54:09 +0200614
615 let save_term = $TERM
Bram Moolenaar08f88b12017-04-02 17:21:16 +0200616 let $TERM = 'unknownxxx'
Bram Moolenaar85045a72017-04-02 16:54:09 +0200617 let out = system(GetVimCommand() . ' -c''set term'' -c cq')
618 call assert_match("defaulting to 'ansi'", out)
619 let $TERM = save_term
620endfunc
Bram Moolenaar09ca9322017-09-26 17:40:45 +0200621
622func Test_zzz_startinsert()
623 " Test :startinsert
624 call writefile(['123456'], 'Xtestout')
Bram Moolenaarc79745a2019-05-20 22:12:34 +0200625 let after =<< trim [CODE]
626 :startinsert
627 call feedkeys("foobar\<c-o>:wq\<cr>","t")
628 [CODE]
629
Bram Moolenaar09ca9322017-09-26 17:40:45 +0200630 if RunVim([], after, 'Xtestout')
631 let lines = readfile('Xtestout')
632 call assert_equal(['foobar123456'], lines)
633 endif
634 " Test :startinsert!
635 call writefile(['123456'], 'Xtestout')
Bram Moolenaarc79745a2019-05-20 22:12:34 +0200636 let after =<< trim [CODE]
637 :startinsert!
638 call feedkeys("foobar\<c-o>:wq\<cr>","t")
639 [CODE]
640
Bram Moolenaar09ca9322017-09-26 17:40:45 +0200641 if RunVim([], after, 'Xtestout')
642 let lines = readfile('Xtestout')
643 call assert_equal(['123456foobar'], lines)
644 endif
645 call delete('Xtestout')
646endfunc
Bram Moolenaar97c2c052019-02-22 13:42:07 +0100647
648func Test_issue_3969()
Bram Moolenaar8c5a2782019-08-07 23:07:07 +0200649 " Can't catch the output of gvim.
650 CheckNotGui
651
Bram Moolenaar97c2c052019-02-22 13:42:07 +0100652 " Check that message is not truncated.
653 let out = system(GetVimCommand() . ' -es -X -V1 -c "echon ''hello''" -cq')
654 call assert_equal('hello', out)
655endfunc
Bram Moolenaarc75e8122019-04-21 15:55:10 +0200656
657func Test_start_with_tabs()
658 if !CanRunVimInTerminal()
Bram Moolenaar5d30ff12019-06-06 16:12:12 +0200659 throw 'Skipped: cannot make screendumps'
Bram Moolenaarc75e8122019-04-21 15:55:10 +0200660 endif
661
662 let buf = RunVimInTerminal('-p a b c', {})
663 call VerifyScreenDump(buf, 'Test_start_with_tabs', {})
664
665 " clean up
666 call StopVimInTerminal(buf)
667endfunc