blob: 6b678fb20ba137e2b30ed44d36ab2f0b7429f37d [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 Moolenaar66459b72016-08-06 19:01:55 +02005
6" Check that loading startup.vim works.
Bram Moolenaarb9a46fe2016-07-29 18:13:42 +02007func Test_startup_script()
8 set compatible
9 source $VIMRUNTIME/defaults.vim
10
11 call assert_equal(0, &compatible)
12endfunc
Bram Moolenaar66459b72016-08-06 19:01:55 +020013
14" Verify the order in which plugins are loaded:
15" 1. plugins in non-after directories
16" 2. packages
17" 3. plugins in after directories
18func Test_after_comes_later()
Bram Moolenaar32860432016-08-06 19:24:23 +020019 if !has('packages')
20 return
21 endif
Bram Moolenaarc79745a2019-05-20 22:12:34 +020022 let before =<< trim [CODE]
23 set nocp viminfo+=nviminfo
24 set guioptions+=M
25 let $HOME = "/does/not/exist"
26 set loadplugins
27 set rtp=Xhere,Xafter,Xanother
28 set packpath=Xhere,Xafter
29 set nomore
30 let g:sequence = ""
31 [CODE]
32
33 let after =<< trim [CODE]
34 redir! > Xtestout
35 scriptnames
36 redir END
37 redir! > Xsequence
38 echo g:sequence
39 redir END
40 quit
41 [CODE]
42
Bram Moolenaar66459b72016-08-06 19:01:55 +020043 call mkdir('Xhere/plugin', 'p')
Bram Moolenaar07ecfa62017-06-27 14:43:55 +020044 call writefile(['let g:sequence .= "here "'], 'Xhere/plugin/here.vim')
45 call mkdir('Xanother/plugin', 'p')
46 call writefile(['let g:sequence .= "another "'], 'Xanother/plugin/another.vim')
Bram Moolenaar66459b72016-08-06 19:01:55 +020047 call mkdir('Xhere/pack/foo/start/foobar/plugin', 'p')
Bram Moolenaar07ecfa62017-06-27 14:43:55 +020048 call writefile(['let g:sequence .= "pack "'], 'Xhere/pack/foo/start/foobar/plugin/foo.vim')
Bram Moolenaar66459b72016-08-06 19:01:55 +020049
50 call mkdir('Xafter/plugin', 'p')
Bram Moolenaar07ecfa62017-06-27 14:43:55 +020051 call writefile(['let g:sequence .= "after "'], 'Xafter/plugin/later.vim')
Bram Moolenaar66459b72016-08-06 19:01:55 +020052
Bram Moolenaar472a0a82016-08-06 22:31:42 +020053 if RunVim(before, after, '')
Bram Moolenaar66459b72016-08-06 19:01:55 +020054
Bram Moolenaar83b3c3d2016-08-06 19:16:43 +020055 let lines = readfile('Xtestout')
Bram Moolenaar07ecfa62017-06-27 14:43:55 +020056 let expected = ['Xbefore.vim', 'here.vim', 'another.vim', 'foo.vim', 'later.vim', 'Xafter.vim']
Bram Moolenaar83b3c3d2016-08-06 19:16:43 +020057 let found = []
58 for line in lines
59 for one in expected
60 if line =~ one
61 call add(found, one)
62 endif
63 endfor
Bram Moolenaar66459b72016-08-06 19:01:55 +020064 endfor
Bram Moolenaar83b3c3d2016-08-06 19:16:43 +020065 call assert_equal(expected, found)
66 endif
Bram Moolenaar66459b72016-08-06 19:01:55 +020067
Bram Moolenaar07ecfa62017-06-27 14:43:55 +020068 call assert_equal('here another pack after', substitute(join(readfile('Xsequence', 1), ''), '\s\+$', '', ''))
69
Bram Moolenaar66459b72016-08-06 19:01:55 +020070 call delete('Xtestout')
Bram Moolenaar07ecfa62017-06-27 14:43:55 +020071 call delete('Xsequence')
Bram Moolenaar66459b72016-08-06 19:01:55 +020072 call delete('Xhere', 'rf')
Bram Moolenaar07ecfa62017-06-27 14:43:55 +020073 call delete('Xanother', 'rf')
Bram Moolenaar66459b72016-08-06 19:01:55 +020074 call delete('Xafter', 'rf')
75endfunc
Bram Moolenaar472a0a82016-08-06 22:31:42 +020076
Bram Moolenaarce876aa2017-06-04 17:47:42 +020077func Test_pack_in_rtp_when_plugins_run()
78 if !has('packages')
79 return
80 endif
Bram Moolenaarc79745a2019-05-20 22:12:34 +020081 let before =<< trim [CODE]
82 set nocp viminfo+=nviminfo
83 set guioptions+=M
84 let $HOME = "/does/not/exist"
85 set loadplugins
86 set rtp=Xhere
87 set packpath=Xhere
88 set nomore
89 [CODE]
90
Bram Moolenaarce876aa2017-06-04 17:47:42 +020091 let after = [
92 \ 'quit',
93 \ ]
94 call mkdir('Xhere/plugin', 'p')
95 call writefile(['redir! > Xtestout', 'silent set runtimepath?', 'silent! call foo#Trigger()', 'redir END'], 'Xhere/plugin/here.vim')
96 call mkdir('Xhere/pack/foo/start/foobar/autoload', 'p')
97 call writefile(['function! foo#Trigger()', 'echo "autoloaded foo"', 'endfunction'], 'Xhere/pack/foo/start/foobar/autoload/foo.vim')
98
99 if RunVim(before, after, '')
100
101 let lines = filter(readfile('Xtestout'), '!empty(v:val)')
102 call assert_match('Xhere[/\\]pack[/\\]foo[/\\]start[/\\]foobar', get(lines, 0))
103 call assert_match('autoloaded foo', get(lines, 1))
104 endif
105
106 call delete('Xtestout')
107 call delete('Xhere', 'rf')
108endfunc
109
Bram Moolenaar472a0a82016-08-06 22:31:42 +0200110func Test_help_arg()
Bram Moolenaar3321e9d2016-08-06 23:03:59 +0200111 if !has('unix') && has('gui')
112 " this doesn't work with gvim on MS-Windows
113 return
114 endif
Bram Moolenaar472a0a82016-08-06 22:31:42 +0200115 if RunVim([], [], '--help >Xtestout')
116 let lines = readfile('Xtestout')
117 call assert_true(len(lines) > 20)
Bram Moolenaarba98bef2016-08-07 15:51:39 +0200118 call assert_match('Vi IMproved', lines[0])
Bram Moolenaar472a0a82016-08-06 22:31:42 +0200119
120 " check if couple of lines are there
Bram Moolenaar50fa8dd2016-08-09 22:58:21 +0200121 let found = []
Bram Moolenaar472a0a82016-08-06 22:31:42 +0200122 for line in lines
123 if line =~ '-R.*Readonly mode'
Bram Moolenaar50fa8dd2016-08-09 22:58:21 +0200124 call add(found, 'Readonly mode')
Bram Moolenaar472a0a82016-08-06 22:31:42 +0200125 endif
Bram Moolenaar50fa8dd2016-08-09 22:58:21 +0200126 " Watch out for a second --version line in the Gnome version.
127 if line =~ '--version.*Print version information and exit'
128 call add(found, "--version")
Bram Moolenaar472a0a82016-08-06 22:31:42 +0200129 endif
130 endfor
Bram Moolenaar50fa8dd2016-08-09 22:58:21 +0200131 call assert_equal(['Readonly mode', '--version'], found)
Bram Moolenaar472a0a82016-08-06 22:31:42 +0200132 endif
133 call delete('Xtestout')
134endfunc
Bram Moolenaarba98bef2016-08-07 15:51:39 +0200135
136func Test_compatible_args()
Bram Moolenaarc79745a2019-05-20 22:12:34 +0200137 let after =<< trim [CODE]
138 call writefile([string(&compatible)], "Xtestout")
139 set viminfo+=nviminfo
140 quit
141 [CODE]
142
Bram Moolenaarba98bef2016-08-07 15:51:39 +0200143 if RunVim([], after, '-C')
144 let lines = readfile('Xtestout')
145 call assert_equal('1', lines[0])
146 endif
147
148 if RunVim([], after, '-N')
149 let lines = readfile('Xtestout')
150 call assert_equal('0', lines[0])
151 endif
152
153 call delete('Xtestout')
154endfunc
155
Bram Moolenaar8f4499b2018-09-16 16:28:11 +0200156" Test the -o[N] and -O[N] arguments to open N windows split
157" horizontally or vertically.
158func Test_o_arg()
Bram Moolenaarc79745a2019-05-20 22:12:34 +0200159 let after =<< trim [CODE]
Bram Moolenaare96a2492019-06-25 04:12:16 +0200160 set cpo&vim
Bram Moolenaarc79745a2019-05-20 22:12:34 +0200161 call writefile([winnr("$"),
162 \ winheight(1), winheight(2), &lines,
163 \ winwidth(1), winwidth(2), &columns,
164 \ bufname(winbufnr(1)), bufname(winbufnr(2))],
165 \ "Xtestout")
166 qall
167 [CODE]
168
Bram Moolenaar8f4499b2018-09-16 16:28:11 +0200169 if RunVim([], after, '-o2')
170 " Open 2 windows split horizontally. Expect:
171 " - 2 windows
172 " - both windows should have the same or almost the same height
173 " - sum of both windows height (+ 3 for both statusline and Ex command)
174 " should be equal to the number of lines
175 " - both windows should have the same width which should be equal to the
176 " number of columns
177 " - buffer of both windows should have no name
178 let [wn, wh1, wh2, ln, ww1, ww2, cn, bn1, bn2] = readfile('Xtestout')
179 call assert_equal('2', wn)
180 call assert_inrange(0, 1, wh1 - wh2)
181 call assert_equal(string(wh1 + wh2 + 3), ln)
182 call assert_equal(ww1, ww2)
183 call assert_equal(ww1, cn)
184 call assert_equal('', bn1)
185 call assert_equal('', bn2)
186 endif
187
188 if RunVim([], after, '-o foo bar')
189 " Same expectations as for -o2 but buffer names should be foo and bar
190 let [wn, wh1, wh2, ln, ww1, ww2, cn, bn1, bn2] = readfile('Xtestout')
191 call assert_equal('2', wn)
192 call assert_inrange(0, 1, wh1 - wh2)
193 call assert_equal(string(wh1 + wh2 + 3), ln)
194 call assert_equal(ww1, ww2)
195 call assert_equal(ww1, cn)
196 call assert_equal('foo', bn1)
197 call assert_equal('bar', bn2)
198 endif
199
200 if RunVim([], after, '-O2')
201 " Open 2 windows split vertically. Expect:
202 " - 2 windows
203 " - both windows should have the same or almost the same width
Bram Moolenaar036b09c2018-09-21 12:54:06 +0200204 " - sum of both windows width (+ 1 for the separator) should be equal to
205 " the number of columns
Bram Moolenaar8f4499b2018-09-16 16:28:11 +0200206 " - both windows should have the same height
207 " - window height (+ 2 for the statusline and Ex command) should be equal
208 " to the number of lines
Bram Moolenaar9e81db92018-09-18 22:37:31 +0200209 " - buffer of both windows should have no name
Bram Moolenaar8f4499b2018-09-16 16:28:11 +0200210 let [wn, wh1, wh2, ln, ww1, ww2, cn, bn1, bn2] = readfile('Xtestout')
211 call assert_equal('2', wn)
212 call assert_inrange(0, 1, ww1 - ww2)
213 call assert_equal(string(ww1 + ww2 + 1), cn)
214 call assert_equal(wh1, wh2)
215 call assert_equal(string(wh1 + 2), ln)
216 call assert_equal('', bn1)
217 call assert_equal('', bn2)
218 endif
219
220 if RunVim([], after, '-O foo bar')
221 " Same expectations as for -O2 but buffer names should be foo and bar
222 let [wn, wh1, wh2, ln, ww1, ww2, cn, bn1, bn2] = readfile('Xtestout')
223 call assert_equal('2', wn)
224 call assert_inrange(0, 1, ww1 - ww2)
225 call assert_equal(string(ww1 + ww2 + 1), cn)
226 call assert_equal(wh1, wh2)
227 call assert_equal(string(wh1 + 2), ln)
228 call assert_equal('foo', bn1)
229 call assert_equal('bar', bn2)
230 endif
231
232 call delete('Xtestout')
233endfunc
234
Bram Moolenaar9e81db92018-09-18 22:37:31 +0200235" Test the -p[N] argument to open N tabpages.
236func Test_p_arg()
Bram Moolenaarc79745a2019-05-20 22:12:34 +0200237 let after =<< trim [CODE]
238 call writefile(split(execute("tabs"), "\n"), "Xtestout")
239 qall
240 [CODE]
241
Bram Moolenaar9e81db92018-09-18 22:37:31 +0200242 if RunVim([], after, '-p2')
243 let lines = readfile('Xtestout')
244 call assert_equal(4, len(lines))
245 call assert_equal('Tab page 1', lines[0])
246 call assert_equal('> [No Name]', lines[1])
247 call assert_equal('Tab page 2', lines[2])
248 call assert_equal(' [No Name]', lines[3])
249 endif
250
251 if RunVim([], after, '-p foo bar')
252 let lines = readfile('Xtestout')
253 call assert_equal(4, len(lines))
254 call assert_equal('Tab page 1', lines[0])
255 call assert_equal('> foo', lines[1])
256 call assert_equal('Tab page 2', lines[2])
257 call assert_equal(' bar', lines[3])
258 endif
259
260 call delete('Xtestout')
261endfunc
262
Bram Moolenaar4b1c9a92018-09-19 21:06:31 +0200263" Test the -V[N] argument to set the 'verbose' option to [N]
Bram Moolenaar9e81db92018-09-18 22:37:31 +0200264func Test_V_arg()
Bram Moolenaar4b1c9a92018-09-19 21:06:31 +0200265 if has('gui_running')
266 " Can't catch the output of gvim.
267 return
268 endif
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()
398 if !has('unix') || has('gui_running')
399 " can't get output of Vim.
400 return
401 endif
402
403 for opt in ['-Y', '--does-not-exist']
404 let out = split(system(GetVimCommand() .. ' ' .. opt), "\n")
405 call assert_equal(1, v:shell_error)
406 call assert_match('^VIM - Vi IMproved .* (.*)$', out[0])
407 call assert_equal('Unknown option argument: "' .. opt .. '"', out[1])
408 call assert_equal('More info with: "vim -h"', out[2])
409 endfor
410
411 for opt in ['-c', '-i', '-s', '-t', '-T', '-u', '-U', '-w', '-W', '--cmd', '--startuptime']
412 let out = split(system(GetVimCommand() .. ' ' .. opt), "\n")
413 call assert_equal(1, v:shell_error)
414 call assert_match('^VIM - Vi IMproved .* (.*)$', out[0])
415 call assert_equal('Argument missing after: "' .. opt .. '"', out[1])
416 call assert_equal('More info with: "vim -h"', out[2])
417 endfor
418
419 if has('clientserver')
Bram Moolenaarba9ea912019-05-07 22:10:50 +0200420 for opt in ['--remote', '--remote-send', '--remote-silent', '--remote-expr',
421 \ '--remote-tab', '--remote-tab-wait',
422 \ '--remote-tab-wait-silent', '--remote-tab-silent',
423 \ '--remote-wait', '--remote-wait-silent',
Bram Moolenaar27821262019-05-08 16:41:09 +0200424 \ '--servername',
Bram Moolenaarba9ea912019-05-07 22:10:50 +0200425 \ ]
426 let out = split(system(GetVimCommand() .. ' ' .. opt), "\n")
427 call assert_equal(1, v:shell_error)
428 call assert_match('^VIM - Vi IMproved .* (.*)$', out[0])
429 call assert_equal('Argument missing after: "' .. opt .. '"', out[1])
430 call assert_equal('More info with: "vim -h"', out[2])
431 endfor
432 endif
433
Bram Moolenaar240f7ab2019-05-08 17:58:15 +0200434 if has('gui_gtk')
Bram Moolenaar27821262019-05-08 16:41:09 +0200435 let out = split(system(GetVimCommand() .. ' --display'), "\n")
436 call assert_equal(1, v:shell_error)
437 call assert_match('^VIM - Vi IMproved .* (.*)$', out[0])
438 call assert_equal('Argument missing after: "--display"', out[1])
439 call assert_equal('More info with: "vim -h"', out[2])
440 endif
Bram Moolenaarba9ea912019-05-07 22:10:50 +0200441
Bram Moolenaar5416b752019-05-08 18:36:43 +0200442 if has('xterm_clipboard')
Bram Moolenaar240f7ab2019-05-08 17:58:15 +0200443 let out = split(system(GetVimCommand() .. ' -display'), "\n")
444 call assert_equal(1, v:shell_error)
445 call assert_match('^VIM - Vi IMproved .* (.*)$', out[0])
446 call assert_equal('Argument missing after: "-display"', out[1])
447 call assert_equal('More info with: "vim -h"', out[2])
448 endif
449
Bram Moolenaarba9ea912019-05-07 22:10:50 +0200450 let out = split(system(GetVimCommand() .. ' -ix'), "\n")
451 call assert_equal(1, v:shell_error)
452 call assert_match('^VIM - Vi IMproved .* (.*)$', out[0])
453 call assert_equal('Garbage after option argument: "-ix"', out[1])
454 call assert_equal('More info with: "vim -h"', out[2])
455
456 let out = split(system(GetVimCommand() .. ' - xxx'), "\n")
457 call assert_equal(1, v:shell_error)
458 call assert_match('^VIM - Vi IMproved .* (.*)$', out[0])
459 call assert_equal('Too many edit arguments: "xxx"', out[1])
460 call assert_equal('More info with: "vim -h"', out[2])
461
462 " Detect invalid repeated arguments '-t foo -t foo", '-q foo -q foo'.
463 for opt in ['-t', '-q']
464 let out = split(system(GetVimCommand() .. repeat(' ' .. opt .. ' foo', 2)), "\n")
465 call assert_equal(1, v:shell_error)
466 call assert_match('^VIM - Vi IMproved .* (.*)$', out[0])
467 call assert_equal('Too many edit arguments: "' .. opt .. '"', out[1])
468 call assert_equal('More info with: "vim -h"', out[2])
469 endfor
470
471 for opt in [' -cq', ' --cmd q', ' +', ' -S foo']
472 let out = split(system(GetVimCommand() .. repeat(opt, 11)), "\n")
473 call assert_equal(1, v:shell_error)
474 " FIXME: The error message given by Vim is not ideal in case of repeated
475 " -S foo since it does not mention -S.
476 call assert_match('^VIM - Vi IMproved .* (.*)$', out[0])
477 call assert_equal('Too many "+command", "-c command" or "--cmd command" arguments', out[1])
478 call assert_equal('More info with: "vim -h"', out[2])
479 endfor
480
Bram Moolenaar27821262019-05-08 16:41:09 +0200481 if has('gui_gtk')
482 for opt in ['--socketid x', '--socketid 0xg']
483 let out = split(system(GetVimCommand() .. ' ' .. opt), "\n")
484 call assert_equal(1, v:shell_error)
485 call assert_match('^VIM - Vi IMproved .* (.*)$', out[0])
486 call assert_equal('Invalid argument for: "--socketid"', out[1])
487 call assert_equal('More info with: "vim -h"', out[2])
488 endfor
489 endif
Bram Moolenaarba9ea912019-05-07 22:10:50 +0200490endfunc
491
Bram Moolenaarba98bef2016-08-07 15:51:39 +0200492func Test_file_args()
Bram Moolenaarc79745a2019-05-20 22:12:34 +0200493 let after =<< trim [CODE]
494 call writefile(argv(), "Xtestout")
495 qall
496 [CODE]
497
Bram Moolenaarba98bef2016-08-07 15:51:39 +0200498 if RunVim([], after, '')
499 let lines = readfile('Xtestout')
500 call assert_equal(0, len(lines))
501 endif
502
503 if RunVim([], after, 'one')
504 let lines = readfile('Xtestout')
505 call assert_equal(1, len(lines))
506 call assert_equal('one', lines[0])
507 endif
508
509 if RunVim([], after, 'one two three')
510 let lines = readfile('Xtestout')
511 call assert_equal(3, len(lines))
512 call assert_equal('one', lines[0])
513 call assert_equal('two', lines[1])
514 call assert_equal('three', lines[2])
515 endif
516
517 if RunVim([], after, 'one -c echo two')
518 let lines = readfile('Xtestout')
519 call assert_equal(2, len(lines))
520 call assert_equal('one', lines[0])
521 call assert_equal('two', lines[1])
522 endif
523
524 if RunVim([], after, 'one -- -c echo two')
525 let lines = readfile('Xtestout')
526 call assert_equal(4, len(lines))
527 call assert_equal('one', lines[0])
528 call assert_equal('-c', lines[1])
529 call assert_equal('echo', lines[2])
530 call assert_equal('two', lines[3])
531 endif
532
533 call delete('Xtestout')
534endfunc
535
536func Test_startuptime()
537 if !has('startuptime')
538 return
539 endif
540 let after = ['qall']
541 if RunVim([], after, '--startuptime Xtestout one')
542 let lines = readfile('Xtestout')
543 let expected = ['--- VIM STARTING ---', 'parsing arguments',
544 \ 'shell init', 'inits 3', 'start termcap', 'opening buffers']
545 let found = []
546 for line in lines
547 for exp in expected
548 if line =~ exp
549 call add(found, exp)
550 endif
551 endfor
552 endfor
553 call assert_equal(expected, found)
554 endif
555 call delete('Xtestout')
556endfunc
Bram Moolenaar3a938382016-08-07 16:36:40 +0200557
558func Test_read_stdin()
Bram Moolenaarc79745a2019-05-20 22:12:34 +0200559 let after =<< trim [CODE]
560 write Xtestout
561 quit!
562 [CODE]
563
Bram Moolenaar3a938382016-08-07 16:36:40 +0200564 if RunVimPiped([], after, '-', 'echo something | ')
565 let lines = readfile('Xtestout')
Bram Moolenaare4a76ad2016-08-07 16:50:10 +0200566 " MS-Windows adds a space after the word
567 call assert_equal(['something'], split(lines[0]))
Bram Moolenaar3a938382016-08-07 16:36:40 +0200568 endif
569 call delete('Xtestout')
570endfunc
Bram Moolenaar08cab962017-03-04 14:37:18 +0100571
Bram Moolenaar4bfa8af2018-02-03 15:14:46 +0100572func Test_set_shell()
Bram Moolenaarc79745a2019-05-20 22:12:34 +0200573 let after =<< trim [CODE]
574 call writefile([&shell], "Xtestout")
575 quit!
576 [CODE]
577
Bram Moolenaar4bfa8af2018-02-03 15:14:46 +0100578 let $SHELL = '/bin/with space/sh'
579 if RunVimPiped([], after, '', '')
580 let lines = readfile('Xtestout')
581 " MS-Windows adds a space after the word
582 call assert_equal('/bin/with\ space/sh', lines[0])
583 endif
584 call delete('Xtestout')
585endfunc
586
Bram Moolenaar08cab962017-03-04 14:37:18 +0100587func Test_progpath()
588 " Tests normally run with "./vim" or "../vim", these must have been expanded
589 " to a full path.
590 if has('unix')
591 call assert_equal('/', v:progpath[0])
592 elseif has('win32')
593 call assert_equal(':', v:progpath[1])
594 call assert_match('[/\\]', v:progpath[2])
595 endif
596
597 " Only expect "vim" to appear in v:progname.
598 call assert_match('vim\c', v:progname)
599endfunc
Bram Moolenaard5d37532017-03-27 23:02:07 +0200600
601func Test_silent_ex_mode()
602 if !has('unix') || has('gui_running')
603 " can't get output of Vim.
604 return
605 endif
606
607 " This caused an ml_get error.
608 let out = system(GetVimCommand() . '-u NONE -es -c''set verbose=1|h|exe "%norm\<c-y>\<c-d>"'' -c cq')
609 call assert_notmatch('E315:', out)
610endfunc
Bram Moolenaar85045a72017-04-02 16:54:09 +0200611
612func Test_default_term()
613 if !has('unix') || has('gui_running')
614 " can't get output of Vim.
615 return
616 endif
617
618 let save_term = $TERM
Bram Moolenaar08f88b12017-04-02 17:21:16 +0200619 let $TERM = 'unknownxxx'
Bram Moolenaar85045a72017-04-02 16:54:09 +0200620 let out = system(GetVimCommand() . ' -c''set term'' -c cq')
621 call assert_match("defaulting to 'ansi'", out)
622 let $TERM = save_term
623endfunc
Bram Moolenaar09ca9322017-09-26 17:40:45 +0200624
625func Test_zzz_startinsert()
626 " Test :startinsert
627 call writefile(['123456'], 'Xtestout')
Bram Moolenaarc79745a2019-05-20 22:12:34 +0200628 let after =<< trim [CODE]
629 :startinsert
630 call feedkeys("foobar\<c-o>:wq\<cr>","t")
631 [CODE]
632
Bram Moolenaar09ca9322017-09-26 17:40:45 +0200633 if RunVim([], after, 'Xtestout')
634 let lines = readfile('Xtestout')
635 call assert_equal(['foobar123456'], lines)
636 endif
637 " Test :startinsert!
638 call writefile(['123456'], 'Xtestout')
Bram Moolenaarc79745a2019-05-20 22:12:34 +0200639 let after =<< trim [CODE]
640 :startinsert!
641 call feedkeys("foobar\<c-o>:wq\<cr>","t")
642 [CODE]
643
Bram Moolenaar09ca9322017-09-26 17:40:45 +0200644 if RunVim([], after, 'Xtestout')
645 let lines = readfile('Xtestout')
646 call assert_equal(['123456foobar'], lines)
647 endif
648 call delete('Xtestout')
649endfunc
Bram Moolenaar97c2c052019-02-22 13:42:07 +0100650
651func Test_issue_3969()
652 if has('gui_running')
653 " Can't catch the output of gvim.
654 return
655 endif
656 " Check that message is not truncated.
657 let out = system(GetVimCommand() . ' -es -X -V1 -c "echon ''hello''" -cq')
658 call assert_equal('hello', out)
659endfunc
Bram Moolenaarc75e8122019-04-21 15:55:10 +0200660
661func Test_start_with_tabs()
662 if !CanRunVimInTerminal()
Bram Moolenaar5d30ff12019-06-06 16:12:12 +0200663 throw 'Skipped: cannot make screendumps'
Bram Moolenaarc75e8122019-04-21 15:55:10 +0200664 endif
665
666 let buf = RunVimInTerminal('-p a b c', {})
667 call VerifyScreenDump(buf, 'Test_start_with_tabs', {})
668
669 " clean up
670 call StopVimInTerminal(buf)
671endfunc