blob: af2b3c1d4fa4a3fa58643cbb2133e536321d45b2 [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
4
5" Check that loading startup.vim works.
Bram Moolenaarb9a46fe2016-07-29 18:13:42 +02006func Test_startup_script()
7 set compatible
8 source $VIMRUNTIME/defaults.vim
9
10 call assert_equal(0, &compatible)
11endfunc
Bram Moolenaar66459b72016-08-06 19:01:55 +020012
13" Verify the order in which plugins are loaded:
14" 1. plugins in non-after directories
15" 2. packages
16" 3. plugins in after directories
17func Test_after_comes_later()
Bram Moolenaar32860432016-08-06 19:24:23 +020018 if !has('packages')
19 return
20 endif
Bram Moolenaar66459b72016-08-06 19:01:55 +020021 let before = [
Bram Moolenaar446cce62016-08-06 21:37:27 +020022 \ 'set nocp viminfo+=nviminfo',
23 \ 'set guioptions+=M',
Bram Moolenaar66459b72016-08-06 19:01:55 +020024 \ 'let $HOME = "/does/not/exist"',
25 \ 'set loadplugins',
Bram Moolenaar07ecfa62017-06-27 14:43:55 +020026 \ 'set rtp=Xhere,Xafter,Xanother',
Bram Moolenaar66459b72016-08-06 19:01:55 +020027 \ 'set packpath=Xhere,Xafter',
28 \ 'set nomore',
Bram Moolenaar07ecfa62017-06-27 14:43:55 +020029 \ 'let g:sequence = ""',
Bram Moolenaar66459b72016-08-06 19:01:55 +020030 \ ]
31 let after = [
32 \ 'redir! > Xtestout',
33 \ 'scriptnames',
34 \ 'redir END',
Bram Moolenaar07ecfa62017-06-27 14:43:55 +020035 \ 'redir! > Xsequence',
36 \ 'echo g:sequence',
37 \ 'redir END',
Bram Moolenaar66459b72016-08-06 19:01:55 +020038 \ 'quit',
39 \ ]
40 call mkdir('Xhere/plugin', 'p')
Bram Moolenaar07ecfa62017-06-27 14:43:55 +020041 call writefile(['let g:sequence .= "here "'], 'Xhere/plugin/here.vim')
42 call mkdir('Xanother/plugin', 'p')
43 call writefile(['let g:sequence .= "another "'], 'Xanother/plugin/another.vim')
Bram Moolenaar66459b72016-08-06 19:01:55 +020044 call mkdir('Xhere/pack/foo/start/foobar/plugin', 'p')
Bram Moolenaar07ecfa62017-06-27 14:43:55 +020045 call writefile(['let g:sequence .= "pack "'], 'Xhere/pack/foo/start/foobar/plugin/foo.vim')
Bram Moolenaar66459b72016-08-06 19:01:55 +020046
47 call mkdir('Xafter/plugin', 'p')
Bram Moolenaar07ecfa62017-06-27 14:43:55 +020048 call writefile(['let g:sequence .= "after "'], 'Xafter/plugin/later.vim')
Bram Moolenaar66459b72016-08-06 19:01:55 +020049
Bram Moolenaar472a0a82016-08-06 22:31:42 +020050 if RunVim(before, after, '')
Bram Moolenaar66459b72016-08-06 19:01:55 +020051
Bram Moolenaar83b3c3d2016-08-06 19:16:43 +020052 let lines = readfile('Xtestout')
Bram Moolenaar07ecfa62017-06-27 14:43:55 +020053 let expected = ['Xbefore.vim', 'here.vim', 'another.vim', 'foo.vim', 'later.vim', 'Xafter.vim']
Bram Moolenaar83b3c3d2016-08-06 19:16:43 +020054 let found = []
55 for line in lines
56 for one in expected
57 if line =~ one
58 call add(found, one)
59 endif
60 endfor
Bram Moolenaar66459b72016-08-06 19:01:55 +020061 endfor
Bram Moolenaar83b3c3d2016-08-06 19:16:43 +020062 call assert_equal(expected, found)
63 endif
Bram Moolenaar66459b72016-08-06 19:01:55 +020064
Bram Moolenaar07ecfa62017-06-27 14:43:55 +020065 call assert_equal('here another pack after', substitute(join(readfile('Xsequence', 1), ''), '\s\+$', '', ''))
66
Bram Moolenaar66459b72016-08-06 19:01:55 +020067 call delete('Xtestout')
Bram Moolenaar07ecfa62017-06-27 14:43:55 +020068 call delete('Xsequence')
Bram Moolenaar66459b72016-08-06 19:01:55 +020069 call delete('Xhere', 'rf')
Bram Moolenaar07ecfa62017-06-27 14:43:55 +020070 call delete('Xanother', 'rf')
Bram Moolenaar66459b72016-08-06 19:01:55 +020071 call delete('Xafter', 'rf')
72endfunc
Bram Moolenaar472a0a82016-08-06 22:31:42 +020073
Bram Moolenaarce876aa2017-06-04 17:47:42 +020074func Test_pack_in_rtp_when_plugins_run()
75 if !has('packages')
76 return
77 endif
78 let before = [
79 \ 'set nocp viminfo+=nviminfo',
80 \ 'set guioptions+=M',
81 \ 'let $HOME = "/does/not/exist"',
82 \ 'set loadplugins',
83 \ 'set rtp=Xhere',
84 \ 'set packpath=Xhere',
85 \ 'set nomore',
86 \ ]
87 let after = [
88 \ 'quit',
89 \ ]
90 call mkdir('Xhere/plugin', 'p')
91 call writefile(['redir! > Xtestout', 'silent set runtimepath?', 'silent! call foo#Trigger()', 'redir END'], 'Xhere/plugin/here.vim')
92 call mkdir('Xhere/pack/foo/start/foobar/autoload', 'p')
93 call writefile(['function! foo#Trigger()', 'echo "autoloaded foo"', 'endfunction'], 'Xhere/pack/foo/start/foobar/autoload/foo.vim')
94
95 if RunVim(before, after, '')
96
97 let lines = filter(readfile('Xtestout'), '!empty(v:val)')
98 call assert_match('Xhere[/\\]pack[/\\]foo[/\\]start[/\\]foobar', get(lines, 0))
99 call assert_match('autoloaded foo', get(lines, 1))
100 endif
101
102 call delete('Xtestout')
103 call delete('Xhere', 'rf')
104endfunc
105
Bram Moolenaar472a0a82016-08-06 22:31:42 +0200106func Test_help_arg()
Bram Moolenaar3321e9d2016-08-06 23:03:59 +0200107 if !has('unix') && has('gui')
108 " this doesn't work with gvim on MS-Windows
109 return
110 endif
Bram Moolenaar472a0a82016-08-06 22:31:42 +0200111 if RunVim([], [], '--help >Xtestout')
112 let lines = readfile('Xtestout')
113 call assert_true(len(lines) > 20)
Bram Moolenaarba98bef2016-08-07 15:51:39 +0200114 call assert_match('Vi IMproved', lines[0])
Bram Moolenaar472a0a82016-08-06 22:31:42 +0200115
116 " check if couple of lines are there
Bram Moolenaar50fa8dd2016-08-09 22:58:21 +0200117 let found = []
Bram Moolenaar472a0a82016-08-06 22:31:42 +0200118 for line in lines
119 if line =~ '-R.*Readonly mode'
Bram Moolenaar50fa8dd2016-08-09 22:58:21 +0200120 call add(found, 'Readonly mode')
Bram Moolenaar472a0a82016-08-06 22:31:42 +0200121 endif
Bram Moolenaar50fa8dd2016-08-09 22:58:21 +0200122 " Watch out for a second --version line in the Gnome version.
123 if line =~ '--version.*Print version information and exit'
124 call add(found, "--version")
Bram Moolenaar472a0a82016-08-06 22:31:42 +0200125 endif
126 endfor
Bram Moolenaar50fa8dd2016-08-09 22:58:21 +0200127 call assert_equal(['Readonly mode', '--version'], found)
Bram Moolenaar472a0a82016-08-06 22:31:42 +0200128 endif
129 call delete('Xtestout')
130endfunc
Bram Moolenaarba98bef2016-08-07 15:51:39 +0200131
132func Test_compatible_args()
133 let after = [
134 \ 'call writefile([string(&compatible)], "Xtestout")',
135 \ 'set viminfo+=nviminfo',
136 \ 'quit',
137 \ ]
138 if RunVim([], after, '-C')
139 let lines = readfile('Xtestout')
140 call assert_equal('1', lines[0])
141 endif
142
143 if RunVim([], after, '-N')
144 let lines = readfile('Xtestout')
145 call assert_equal('0', lines[0])
146 endif
147
148 call delete('Xtestout')
149endfunc
150
151func Test_file_args()
152 let after = [
153 \ 'call writefile(argv(), "Xtestout")',
154 \ 'qall',
155 \ ]
156 if RunVim([], after, '')
157 let lines = readfile('Xtestout')
158 call assert_equal(0, len(lines))
159 endif
160
161 if RunVim([], after, 'one')
162 let lines = readfile('Xtestout')
163 call assert_equal(1, len(lines))
164 call assert_equal('one', lines[0])
165 endif
166
167 if RunVim([], after, 'one two three')
168 let lines = readfile('Xtestout')
169 call assert_equal(3, len(lines))
170 call assert_equal('one', lines[0])
171 call assert_equal('two', lines[1])
172 call assert_equal('three', lines[2])
173 endif
174
175 if RunVim([], after, 'one -c echo two')
176 let lines = readfile('Xtestout')
177 call assert_equal(2, len(lines))
178 call assert_equal('one', lines[0])
179 call assert_equal('two', lines[1])
180 endif
181
182 if RunVim([], after, 'one -- -c echo two')
183 let lines = readfile('Xtestout')
184 call assert_equal(4, len(lines))
185 call assert_equal('one', lines[0])
186 call assert_equal('-c', lines[1])
187 call assert_equal('echo', lines[2])
188 call assert_equal('two', lines[3])
189 endif
190
191 call delete('Xtestout')
192endfunc
193
194func Test_startuptime()
195 if !has('startuptime')
196 return
197 endif
198 let after = ['qall']
199 if RunVim([], after, '--startuptime Xtestout one')
200 let lines = readfile('Xtestout')
201 let expected = ['--- VIM STARTING ---', 'parsing arguments',
202 \ 'shell init', 'inits 3', 'start termcap', 'opening buffers']
203 let found = []
204 for line in lines
205 for exp in expected
206 if line =~ exp
207 call add(found, exp)
208 endif
209 endfor
210 endfor
211 call assert_equal(expected, found)
212 endif
213 call delete('Xtestout')
214endfunc
Bram Moolenaar3a938382016-08-07 16:36:40 +0200215
216func Test_read_stdin()
217 let after = [
218 \ 'write Xtestout',
219 \ 'quit!',
220 \ ]
221 if RunVimPiped([], after, '-', 'echo something | ')
222 let lines = readfile('Xtestout')
Bram Moolenaare4a76ad2016-08-07 16:50:10 +0200223 " MS-Windows adds a space after the word
224 call assert_equal(['something'], split(lines[0]))
Bram Moolenaar3a938382016-08-07 16:36:40 +0200225 endif
226 call delete('Xtestout')
227endfunc
Bram Moolenaar08cab962017-03-04 14:37:18 +0100228
229func Test_progpath()
230 " Tests normally run with "./vim" or "../vim", these must have been expanded
231 " to a full path.
232 if has('unix')
233 call assert_equal('/', v:progpath[0])
234 elseif has('win32')
235 call assert_equal(':', v:progpath[1])
236 call assert_match('[/\\]', v:progpath[2])
237 endif
238
239 " Only expect "vim" to appear in v:progname.
240 call assert_match('vim\c', v:progname)
241endfunc
Bram Moolenaard5d37532017-03-27 23:02:07 +0200242
243func Test_silent_ex_mode()
244 if !has('unix') || has('gui_running')
245 " can't get output of Vim.
246 return
247 endif
248
249 " This caused an ml_get error.
250 let out = system(GetVimCommand() . '-u NONE -es -c''set verbose=1|h|exe "%norm\<c-y>\<c-d>"'' -c cq')
251 call assert_notmatch('E315:', out)
252endfunc
Bram Moolenaar85045a72017-04-02 16:54:09 +0200253
254func Test_default_term()
255 if !has('unix') || has('gui_running')
256 " can't get output of Vim.
257 return
258 endif
259
260 let save_term = $TERM
Bram Moolenaar08f88b12017-04-02 17:21:16 +0200261 let $TERM = 'unknownxxx'
Bram Moolenaar85045a72017-04-02 16:54:09 +0200262 let out = system(GetVimCommand() . ' -c''set term'' -c cq')
263 call assert_match("defaulting to 'ansi'", out)
264 let $TERM = save_term
265endfunc