blob: 5e817dee04e5a8d511afaa8202537cb3392d7ff2 [file] [log] [blame]
Bram Moolenaarc6df10e2017-07-29 20:15:08 +02001" Tests for the terminal window.
2
Bram Moolenaarea5d6fa2017-08-18 21:07:11 +02003if !has('terminal')
Bram Moolenaarc6df10e2017-07-29 20:15:08 +02004 finish
5endif
6
7source shared.vim
Bram Moolenaar25cdd9c2018-03-10 20:28:12 +01008source screendump.vim
Bram Moolenaarc6df10e2017-07-29 20:15:08 +02009
Bram Moolenaarb81bc772017-08-11 22:45:01 +020010let s:python = PythonProg()
11
Bram Moolenaar94053a52017-08-01 21:44:33 +020012" Open a terminal with a shell, assign the job to g:job and return the buffer
13" number.
Bram Moolenaar05aafed2017-08-11 19:12:11 +020014func Run_shell_in_terminal(options)
Bram Moolenaarba6febd2017-10-30 21:56:23 +010015 if has('win32')
16 let buf = term_start([&shell,'/k'], a:options)
17 else
18 let buf = term_start(&shell, a:options)
19 endif
Bram Moolenaarc6df10e2017-07-29 20:15:08 +020020
21 let termlist = term_list()
22 call assert_equal(1, len(termlist))
23 call assert_equal(buf, termlist[0])
24
25 let g:job = term_getjob(buf)
26 call assert_equal(v:t_job, type(g:job))
27
Bram Moolenaar35422f42017-08-05 16:33:56 +020028 let string = string({'job': term_getjob(buf)})
29 call assert_match("{'job': 'process \\d\\+ run'}", string)
30
Bram Moolenaar94053a52017-08-01 21:44:33 +020031 return buf
32endfunc
33
Bram Moolenaar20e6cd02017-08-01 20:25:22 +020034func Test_terminal_basic()
Bram Moolenaarb00fdf62017-09-21 22:16:21 +020035 au BufWinEnter * if &buftype == 'terminal' | let b:done = 'yes' | endif
Bram Moolenaar05aafed2017-08-11 19:12:11 +020036 let buf = Run_shell_in_terminal({})
Bram Moolenaarb00fdf62017-09-21 22:16:21 +020037
Bram Moolenaar7c9aec42017-08-03 13:51:25 +020038 if has("unix")
Bram Moolenaar2dc9d262017-09-08 14:39:30 +020039 call assert_match('^/dev/', job_info(g:job).tty_out)
40 call assert_match('^/dev/', term_gettty(''))
Bram Moolenaar7c9aec42017-08-03 13:51:25 +020041 else
Bram Moolenaar2dc9d262017-09-08 14:39:30 +020042 call assert_match('^\\\\.\\pipe\\', job_info(g:job).tty_out)
43 call assert_match('^\\\\.\\pipe\\', term_gettty(''))
Bram Moolenaar7c9aec42017-08-03 13:51:25 +020044 endif
Bram Moolenaar2bb7b6b2017-08-13 20:58:33 +020045 call assert_equal('t', mode())
Bram Moolenaarb00fdf62017-09-21 22:16:21 +020046 call assert_equal('yes', b:done)
Bram Moolenaar2bb7b6b2017-08-13 20:58:33 +020047 call assert_match('%aR[^\n]*running]', execute('ls'))
Bram Moolenaar0751f512018-03-29 16:37:16 +020048 call assert_match('%aR[^\n]*running]', execute('ls R'))
49 call assert_notmatch('%[^\n]*running]', execute('ls F'))
50 call assert_notmatch('%[^\n]*running]', execute('ls ?'))
Bram Moolenaar2bb7b6b2017-08-13 20:58:33 +020051
Bram Moolenaar94053a52017-08-01 21:44:33 +020052 call Stop_shell_in_terminal(buf)
53 call term_wait(buf)
Bram Moolenaar2bb7b6b2017-08-13 20:58:33 +020054 call assert_equal('n', mode())
55 call assert_match('%aF[^\n]*finished]', execute('ls'))
Bram Moolenaar0751f512018-03-29 16:37:16 +020056 call assert_match('%aF[^\n]*finished]', execute('ls F'))
57 call assert_notmatch('%[^\n]*finished]', execute('ls R'))
58 call assert_notmatch('%[^\n]*finished]', execute('ls ?'))
Bram Moolenaar20e6cd02017-08-01 20:25:22 +020059
Bram Moolenaar94053a52017-08-01 21:44:33 +020060 " closing window wipes out the terminal buffer a with finished job
61 close
62 call assert_equal("", bufname(buf))
63
Bram Moolenaarb00fdf62017-09-21 22:16:21 +020064 au! BufWinEnter
Bram Moolenaar20e6cd02017-08-01 20:25:22 +020065 unlet g:job
66endfunc
67
68func Test_terminal_make_change()
Bram Moolenaar05aafed2017-08-11 19:12:11 +020069 let buf = Run_shell_in_terminal({})
Bram Moolenaar94053a52017-08-01 21:44:33 +020070 call Stop_shell_in_terminal(buf)
Bram Moolenaar20e6cd02017-08-01 20:25:22 +020071 call term_wait(buf)
72
73 setlocal modifiable
74 exe "normal Axxx\<Esc>"
75 call assert_fails(buf . 'bwipe', 'E517')
76 undo
77
Bram Moolenaarc6df10e2017-07-29 20:15:08 +020078 exe buf . 'bwipe'
79 unlet g:job
80endfunc
81
Bram Moolenaar94053a52017-08-01 21:44:33 +020082func Test_terminal_wipe_buffer()
Bram Moolenaar05aafed2017-08-11 19:12:11 +020083 let buf = Run_shell_in_terminal({})
Bram Moolenaareb44a682017-08-03 22:44:55 +020084 call assert_fails(buf . 'bwipe', 'E517')
85 exe buf . 'bwipe!'
Bram Moolenaar94053a52017-08-01 21:44:33 +020086 call WaitFor('job_status(g:job) == "dead"')
87 call assert_equal('dead', job_status(g:job))
88 call assert_equal("", bufname(buf))
89
90 unlet g:job
91endfunc
92
Bram Moolenaar8adb0d02017-09-17 19:08:02 +020093func Test_terminal_split_quit()
94 let buf = Run_shell_in_terminal({})
95 call term_wait(buf)
96 split
97 quit!
98 call term_wait(buf)
99 sleep 50m
100 call assert_equal('run', job_status(g:job))
101
102 quit!
103 call WaitFor('job_status(g:job) == "dead"')
104 call assert_equal('dead', job_status(g:job))
105
106 exe buf . 'bwipe'
107 unlet g:job
108endfunc
109
Bram Moolenaar94053a52017-08-01 21:44:33 +0200110func Test_terminal_hide_buffer()
Bram Moolenaar05aafed2017-08-11 19:12:11 +0200111 let buf = Run_shell_in_terminal({})
Bram Moolenaar97a80e42017-08-30 13:31:49 +0200112 setlocal bufhidden=hide
Bram Moolenaar94053a52017-08-01 21:44:33 +0200113 quit
114 for nr in range(1, winnr('$'))
115 call assert_notequal(winbufnr(nr), buf)
116 endfor
117 call assert_true(bufloaded(buf))
118 call assert_true(buflisted(buf))
119
120 exe 'split ' . buf . 'buf'
121 call Stop_shell_in_terminal(buf)
122 exe buf . 'bwipe'
123
124 unlet g:job
125endfunc
126
Bram Moolenaar3c3a80d2017-08-03 17:06:45 +0200127func! s:Nasty_exit_cb(job, st)
128 exe g:buf . 'bwipe!'
129 let g:buf = 0
130endfunc
131
Bram Moolenaar9d189612017-09-09 18:11:00 +0200132func Get_cat_123_cmd()
133 if has('win32')
134 return 'cmd /c "cls && color 2 && echo 123"'
135 else
136 call writefile(["\<Esc>[32m123"], 'Xtext')
137 return "cat Xtext"
138 endif
139endfunc
140
Bram Moolenaar3c3a80d2017-08-03 17:06:45 +0200141func Test_terminal_nasty_cb()
Bram Moolenaar33a43be2017-08-06 21:36:22 +0200142 let cmd = Get_cat_123_cmd()
Bram Moolenaar3c3a80d2017-08-03 17:06:45 +0200143 let g:buf = term_start(cmd, {'exit_cb': function('s:Nasty_exit_cb')})
144 let g:job = term_getjob(g:buf)
145
146 call WaitFor('job_status(g:job) == "dead"')
147 call WaitFor('g:buf == 0')
148 unlet g:buf
149 unlet g:job
150 call delete('Xtext')
151endfunc
152
Bram Moolenaarc6df10e2017-07-29 20:15:08 +0200153func Check_123(buf)
Bram Moolenaar5c838a32017-08-02 22:10:34 +0200154 let l = term_scrape(a:buf, 0)
155 call assert_true(len(l) == 0)
156 let l = term_scrape(a:buf, 999)
157 call assert_true(len(l) == 0)
Bram Moolenaar9c844842017-08-01 18:41:21 +0200158 let l = term_scrape(a:buf, 1)
Bram Moolenaarc6df10e2017-07-29 20:15:08 +0200159 call assert_true(len(l) > 0)
160 call assert_equal('1', l[0].chars)
161 call assert_equal('2', l[1].chars)
162 call assert_equal('3', l[2].chars)
163 call assert_equal('#00e000', l[0].fg)
164 if &background == 'light'
165 call assert_equal('#ffffff', l[0].bg)
166 else
167 call assert_equal('#000000', l[0].bg)
168 endif
169
Bram Moolenaar5c838a32017-08-02 22:10:34 +0200170 let l = term_getline(a:buf, -1)
171 call assert_equal('', l)
172 let l = term_getline(a:buf, 0)
173 call assert_equal('', l)
174 let l = term_getline(a:buf, 999)
175 call assert_equal('', l)
Bram Moolenaar9c844842017-08-01 18:41:21 +0200176 let l = term_getline(a:buf, 1)
Bram Moolenaarc6df10e2017-07-29 20:15:08 +0200177 call assert_equal('123', l)
178endfunc
179
Bram Moolenaar33a43be2017-08-06 21:36:22 +0200180func Test_terminal_scrape_123()
181 let cmd = Get_cat_123_cmd()
Bram Moolenaarc6df10e2017-07-29 20:15:08 +0200182 let buf = term_start(cmd)
183
184 let termlist = term_list()
185 call assert_equal(1, len(termlist))
186 call assert_equal(buf, termlist[0])
187
Bram Moolenaarf144a3f2017-07-30 18:02:12 +0200188 " Nothing happens with invalid buffer number
189 call term_wait(1234)
190
Bram Moolenaarc6df10e2017-07-29 20:15:08 +0200191 call term_wait(buf)
Bram Moolenaar17833372017-09-04 22:23:19 +0200192 " On MS-Windows we first get a startup message of two lines, wait for the
Bram Moolenaar1bfdc072017-09-05 20:19:42 +0200193 " "cls" to happen, after that we have one line with three characters.
Bram Moolenaarab8b1c12017-11-04 19:24:31 +0100194 call WaitFor({-> len(term_scrape(buf, 1)) == 3})
Bram Moolenaarc6df10e2017-07-29 20:15:08 +0200195 call Check_123(buf)
196
197 " Must still work after the job ended.
Bram Moolenaarab8b1c12017-11-04 19:24:31 +0100198 let job = term_getjob(buf)
199 call WaitFor({-> job_status(job) == "dead"})
Bram Moolenaarc6df10e2017-07-29 20:15:08 +0200200 call term_wait(buf)
201 call Check_123(buf)
202
203 exe buf . 'bwipe'
Bram Moolenaarf144a3f2017-07-30 18:02:12 +0200204 call delete('Xtext')
Bram Moolenaarc6df10e2017-07-29 20:15:08 +0200205endfunc
Bram Moolenaarcfcc0222017-08-05 17:13:48 +0200206
Bram Moolenaar33a43be2017-08-06 21:36:22 +0200207func Test_terminal_scrape_multibyte()
208 if !has('multi_byte')
209 return
210 endif
211 call writefile(["léttまrs"], 'Xtext')
212 if has('win32')
Bram Moolenaar36783932017-08-14 23:07:30 +0200213 " Run cmd with UTF-8 codepage to make the type command print the expected
214 " multibyte characters.
Bram Moolenaarab8b1c12017-11-04 19:24:31 +0100215 let buf = term_start("cmd /K chcp 65001")
216 call term_sendkeys(buf, "type Xtext\<CR>")
217 call term_sendkeys(buf, "exit\<CR>")
218 let line = 4
Bram Moolenaar33a43be2017-08-06 21:36:22 +0200219 else
Bram Moolenaarab8b1c12017-11-04 19:24:31 +0100220 let buf = term_start("cat Xtext")
221 let line = 1
Bram Moolenaar33a43be2017-08-06 21:36:22 +0200222 endif
Bram Moolenaar33a43be2017-08-06 21:36:22 +0200223
Bram Moolenaarab8b1c12017-11-04 19:24:31 +0100224 call WaitFor({-> len(term_scrape(buf, line)) >= 7 && term_scrape(buf, line)[0].chars == "l"})
225 let l = term_scrape(buf, line)
Bram Moolenaar33a43be2017-08-06 21:36:22 +0200226 call assert_true(len(l) >= 7)
227 call assert_equal('l', l[0].chars)
228 call assert_equal('é', l[1].chars)
229 call assert_equal(1, l[1].width)
230 call assert_equal('t', l[2].chars)
231 call assert_equal('t', l[3].chars)
232 call assert_equal('ま', l[4].chars)
233 call assert_equal(2, l[4].width)
234 call assert_equal('r', l[5].chars)
235 call assert_equal('s', l[6].chars)
236
Bram Moolenaarab8b1c12017-11-04 19:24:31 +0100237 let job = term_getjob(buf)
238 call WaitFor({-> job_status(job) == "dead"})
239 call term_wait(buf)
Bram Moolenaar33a43be2017-08-06 21:36:22 +0200240
Bram Moolenaarab8b1c12017-11-04 19:24:31 +0100241 exe buf . 'bwipe'
Bram Moolenaar33a43be2017-08-06 21:36:22 +0200242 call delete('Xtext')
243endfunc
244
Bram Moolenaarf8d57a52017-08-07 20:38:42 +0200245func Test_terminal_scroll()
246 call writefile(range(1, 200), 'Xtext')
247 if has('win32')
248 let cmd = 'cmd /c "type Xtext"'
249 else
250 let cmd = "cat Xtext"
251 endif
252 let buf = term_start(cmd)
253
Bram Moolenaarab8b1c12017-11-04 19:24:31 +0100254 let job = term_getjob(buf)
255 call WaitFor({-> job_status(job) == "dead"})
Bram Moolenaarf8d57a52017-08-07 20:38:42 +0200256 call term_wait(buf)
257 if has('win32')
258 " TODO: this should not be needed
259 sleep 100m
260 endif
261
Bram Moolenaar82b9ca02017-08-08 23:06:46 +0200262 let scrolled = term_getscrolled(buf)
Bram Moolenaarf8d57a52017-08-07 20:38:42 +0200263 call assert_equal('1', getline(1))
Bram Moolenaar82b9ca02017-08-08 23:06:46 +0200264 call assert_equal('1', term_getline(buf, 1 - scrolled))
Bram Moolenaarf8d57a52017-08-07 20:38:42 +0200265 call assert_equal('49', getline(49))
Bram Moolenaar82b9ca02017-08-08 23:06:46 +0200266 call assert_equal('49', term_getline(buf, 49 - scrolled))
Bram Moolenaarf8d57a52017-08-07 20:38:42 +0200267 call assert_equal('200', getline(200))
Bram Moolenaar82b9ca02017-08-08 23:06:46 +0200268 call assert_equal('200', term_getline(buf, 200 - scrolled))
Bram Moolenaarf8d57a52017-08-07 20:38:42 +0200269
270 exe buf . 'bwipe'
271 call delete('Xtext')
272endfunc
273
Bram Moolenaarcfcc0222017-08-05 17:13:48 +0200274func Test_terminal_size()
Bram Moolenaar33a43be2017-08-06 21:36:22 +0200275 let cmd = Get_cat_123_cmd()
Bram Moolenaarcfcc0222017-08-05 17:13:48 +0200276
Bram Moolenaarb2412082017-08-20 18:09:14 +0200277 exe 'terminal ++rows=5 ' . cmd
Bram Moolenaarcfcc0222017-08-05 17:13:48 +0200278 let size = term_getsize('')
279 bwipe!
280 call assert_equal(5, size[0])
281
Bram Moolenaar08d384f2017-08-11 21:51:23 +0200282 call term_start(cmd, {'term_rows': 6})
283 let size = term_getsize('')
284 bwipe!
285 call assert_equal(6, size[0])
286
Bram Moolenaarcfcc0222017-08-05 17:13:48 +0200287 vsplit
Bram Moolenaarb2412082017-08-20 18:09:14 +0200288 exe 'terminal ++rows=5 ++cols=33 ' . cmd
Bram Moolenaarcfcc0222017-08-05 17:13:48 +0200289 let size = term_getsize('')
290 bwipe!
291 call assert_equal([5, 33], size)
292
Bram Moolenaar08d384f2017-08-11 21:51:23 +0200293 call term_start(cmd, {'term_rows': 6, 'term_cols': 36})
294 let size = term_getsize('')
295 bwipe!
296 call assert_equal([6, 36], size)
297
Bram Moolenaarb2412082017-08-20 18:09:14 +0200298 exe 'vertical terminal ++cols=20 ' . cmd
Bram Moolenaarcfcc0222017-08-05 17:13:48 +0200299 let size = term_getsize('')
300 bwipe!
301 call assert_equal(20, size[1])
302
Bram Moolenaar08d384f2017-08-11 21:51:23 +0200303 call term_start(cmd, {'vertical': 1, 'term_cols': 26})
304 let size = term_getsize('')
305 bwipe!
306 call assert_equal(26, size[1])
307
Bram Moolenaarcfcc0222017-08-05 17:13:48 +0200308 split
Bram Moolenaarb2412082017-08-20 18:09:14 +0200309 exe 'vertical terminal ++rows=6 ++cols=20 ' . cmd
Bram Moolenaarcfcc0222017-08-05 17:13:48 +0200310 let size = term_getsize('')
311 bwipe!
312 call assert_equal([6, 20], size)
Bram Moolenaar08d384f2017-08-11 21:51:23 +0200313
314 call term_start(cmd, {'vertical': 1, 'term_rows': 7, 'term_cols': 27})
315 let size = term_getsize('')
316 bwipe!
317 call assert_equal([7, 27], size)
Bram Moolenaar9d654a82017-09-03 19:52:17 +0200318
319 call delete('Xtext')
Bram Moolenaarda43b612017-08-11 22:27:50 +0200320endfunc
321
322func Test_terminal_curwin()
323 let cmd = Get_cat_123_cmd()
324 call assert_equal(1, winnr('$'))
325
326 split dummy
327 exe 'terminal ++curwin ' . cmd
328 call assert_equal(2, winnr('$'))
329 bwipe!
330
331 split dummy
332 call term_start(cmd, {'curwin': 1})
333 call assert_equal(2, winnr('$'))
334 bwipe!
335
336 split dummy
337 call setline(1, 'change')
338 call assert_fails('terminal ++curwin ' . cmd, 'E37:')
339 call assert_equal(2, winnr('$'))
340 exe 'terminal! ++curwin ' . cmd
341 call assert_equal(2, winnr('$'))
342 bwipe!
343
344 split dummy
345 call setline(1, 'change')
346 call assert_fails("call term_start(cmd, {'curwin': 1})", 'E37:')
347 call assert_equal(2, winnr('$'))
348 bwipe!
349
350 split dummy
351 bwipe!
Bram Moolenaar9d654a82017-09-03 19:52:17 +0200352 call delete('Xtext')
Bram Moolenaarcfcc0222017-08-05 17:13:48 +0200353endfunc
Bram Moolenaardd693ce2017-08-10 23:15:19 +0200354
Bram Moolenaarff546792017-11-21 14:47:57 +0100355func s:get_sleep_cmd()
Bram Moolenaarb81bc772017-08-11 22:45:01 +0200356 if s:python != ''
357 let cmd = s:python . " test_short_sleep.py"
358 let waittime = 500
Bram Moolenaardd693ce2017-08-10 23:15:19 +0200359 else
Bram Moolenaarb81bc772017-08-11 22:45:01 +0200360 echo 'This will take five seconds...'
361 let waittime = 2000
362 if has('win32')
363 let cmd = $windir . '\system32\timeout.exe 1'
364 else
365 let cmd = 'sleep 1'
366 endif
Bram Moolenaardd693ce2017-08-10 23:15:19 +0200367 endif
Bram Moolenaarff546792017-11-21 14:47:57 +0100368 return [cmd, waittime]
369endfunc
370
371func Test_terminal_finish_open_close()
372 call assert_equal(1, winnr('$'))
373
374 let [cmd, waittime] = s:get_sleep_cmd()
Bram Moolenaarb81bc772017-08-11 22:45:01 +0200375
Bram Moolenaar1dd98332018-03-16 22:54:53 +0100376 " shell terminal closes automatically
377 terminal
378 let buf = bufnr('%')
379 call assert_equal(2, winnr('$'))
380 " Wait for the shell to display a prompt
381 call WaitFor({-> term_getline(buf, 1) != ""})
382 call Stop_shell_in_terminal(buf)
383 call WaitFor("winnr('$') == 1", waittime)
384
385 " shell terminal that does not close automatically
386 terminal ++noclose
387 let buf = bufnr('%')
388 call assert_equal(2, winnr('$'))
389 " Wait for the shell to display a prompt
390 call WaitFor({-> term_getline(buf, 1) != ""})
391 call Stop_shell_in_terminal(buf)
392 call assert_equal(2, winnr('$'))
393 quit
394 call assert_equal(1, winnr('$'))
395
Bram Moolenaardd693ce2017-08-10 23:15:19 +0200396 exe 'terminal ++close ' . cmd
Bram Moolenaardd693ce2017-08-10 23:15:19 +0200397 call assert_equal(2, winnr('$'))
Bram Moolenaardd693ce2017-08-10 23:15:19 +0200398 wincmd p
Bram Moolenaarb81bc772017-08-11 22:45:01 +0200399 call WaitFor("winnr('$') == 1", waittime)
Bram Moolenaardd693ce2017-08-10 23:15:19 +0200400
401 call term_start(cmd, {'term_finish': 'close'})
402 call assert_equal(2, winnr('$'))
Bram Moolenaardd693ce2017-08-10 23:15:19 +0200403 wincmd p
Bram Moolenaarb81bc772017-08-11 22:45:01 +0200404 call WaitFor("winnr('$') == 1", waittime)
Bram Moolenaardd693ce2017-08-10 23:15:19 +0200405 call assert_equal(1, winnr('$'))
406
407 exe 'terminal ++open ' . cmd
Bram Moolenaar97a80e42017-08-30 13:31:49 +0200408 close!
Bram Moolenaarb81bc772017-08-11 22:45:01 +0200409 call WaitFor("winnr('$') == 2", waittime)
Bram Moolenaardd693ce2017-08-10 23:15:19 +0200410 call assert_equal(2, winnr('$'))
411 bwipe
412
413 call term_start(cmd, {'term_finish': 'open'})
Bram Moolenaar97a80e42017-08-30 13:31:49 +0200414 close!
Bram Moolenaarb81bc772017-08-11 22:45:01 +0200415 call WaitFor("winnr('$') == 2", waittime)
Bram Moolenaardd693ce2017-08-10 23:15:19 +0200416 call assert_equal(2, winnr('$'))
Bram Moolenaar8cad9302017-08-12 14:32:32 +0200417 bwipe
Bram Moolenaardd693ce2017-08-10 23:15:19 +0200418
Bram Moolenaar8cad9302017-08-12 14:32:32 +0200419 exe 'terminal ++hidden ++open ' . cmd
420 call assert_equal(1, winnr('$'))
421 call WaitFor("winnr('$') == 2", waittime)
422 call assert_equal(2, winnr('$'))
423 bwipe
424
425 call term_start(cmd, {'term_finish': 'open', 'hidden': 1})
426 call assert_equal(1, winnr('$'))
427 call WaitFor("winnr('$') == 2", waittime)
428 call assert_equal(2, winnr('$'))
Bram Moolenaardd693ce2017-08-10 23:15:19 +0200429 bwipe
Bram Moolenaar37c45832017-08-12 16:01:04 +0200430
431 call assert_fails("call term_start(cmd, {'term_opencmd': 'open'})", 'E475:')
432 call assert_fails("call term_start(cmd, {'term_opencmd': 'split %x'})", 'E475:')
433 call assert_fails("call term_start(cmd, {'term_opencmd': 'split %d and %s'})", 'E475:')
434 call assert_fails("call term_start(cmd, {'term_opencmd': 'split % and %d'})", 'E475:')
435
436 call term_start(cmd, {'term_finish': 'open', 'term_opencmd': '4split | buffer %d'})
Bram Moolenaar97a80e42017-08-30 13:31:49 +0200437 close!
Bram Moolenaar37c45832017-08-12 16:01:04 +0200438 call WaitFor("winnr('$') == 2", waittime)
439 call assert_equal(2, winnr('$'))
440 call assert_equal(4, winheight(0))
441 bwipe
Bram Moolenaardd693ce2017-08-10 23:15:19 +0200442endfunc
Bram Moolenaar05aafed2017-08-11 19:12:11 +0200443
444func Test_terminal_cwd()
Bram Moolenaare9f6fd22017-09-10 14:25:49 +0200445 if !executable('pwd')
Bram Moolenaar05aafed2017-08-11 19:12:11 +0200446 return
447 endif
448 call mkdir('Xdir')
449 let buf = term_start('pwd', {'cwd': 'Xdir'})
Bram Moolenaare9f6fd22017-09-10 14:25:49 +0200450 call WaitFor('"Xdir" == fnamemodify(getline(1), ":t")')
451 call assert_equal('Xdir', fnamemodify(getline(1), ":t"))
Bram Moolenaar05aafed2017-08-11 19:12:11 +0200452
453 exe buf . 'bwipe'
454 call delete('Xdir', 'rf')
455endfunc
456
Bram Moolenaar52dbb5e2017-11-21 18:11:27 +0100457func Test_terminal_servername()
458 if !has('clientserver')
459 return
460 endif
Bram Moolenaar012eb662018-03-13 17:55:27 +0100461 let buf = Run_shell_in_terminal({})
Bram Moolenaar52dbb5e2017-11-21 18:11:27 +0100462 " Wait for the shell to display a prompt
Bram Moolenaar012eb662018-03-13 17:55:27 +0100463 call WaitFor({-> term_getline(buf, 1) != ""})
Bram Moolenaar52dbb5e2017-11-21 18:11:27 +0100464 if has('win32')
Bram Moolenaar012eb662018-03-13 17:55:27 +0100465 call term_sendkeys(buf, "echo %VIM_SERVERNAME%\r")
Bram Moolenaar52dbb5e2017-11-21 18:11:27 +0100466 else
Bram Moolenaar012eb662018-03-13 17:55:27 +0100467 call term_sendkeys(buf, "echo $VIM_SERVERNAME\r")
Bram Moolenaar52dbb5e2017-11-21 18:11:27 +0100468 endif
Bram Moolenaar012eb662018-03-13 17:55:27 +0100469 call term_wait(buf)
470 call Stop_shell_in_terminal(buf)
Bram Moolenaar52dbb5e2017-11-21 18:11:27 +0100471 call WaitFor('getline(2) == v:servername')
472 call assert_equal(v:servername, getline(2))
473
Bram Moolenaar012eb662018-03-13 17:55:27 +0100474 exe buf . 'bwipe'
475 unlet buf
Bram Moolenaar52dbb5e2017-11-21 18:11:27 +0100476endfunc
477
Bram Moolenaar05aafed2017-08-11 19:12:11 +0200478func Test_terminal_env()
Bram Moolenaar012eb662018-03-13 17:55:27 +0100479 let buf = Run_shell_in_terminal({'env': {'TESTENV': 'correct'}})
Bram Moolenaar51c23682017-08-14 21:45:00 +0200480 " Wait for the shell to display a prompt
Bram Moolenaar012eb662018-03-13 17:55:27 +0100481 call WaitFor({-> term_getline(buf, 1) != ""})
Bram Moolenaarba6febd2017-10-30 21:56:23 +0100482 if has('win32')
Bram Moolenaar012eb662018-03-13 17:55:27 +0100483 call term_sendkeys(buf, "echo %TESTENV%\r")
Bram Moolenaarba6febd2017-10-30 21:56:23 +0100484 else
Bram Moolenaar012eb662018-03-13 17:55:27 +0100485 call term_sendkeys(buf, "echo $TESTENV\r")
Bram Moolenaarba6febd2017-10-30 21:56:23 +0100486 endif
Bram Moolenaar012eb662018-03-13 17:55:27 +0100487 call term_wait(buf)
488 call Stop_shell_in_terminal(buf)
Bram Moolenaar51c23682017-08-14 21:45:00 +0200489 call WaitFor('getline(2) == "correct"')
Bram Moolenaar05aafed2017-08-11 19:12:11 +0200490 call assert_equal('correct', getline(2))
491
Bram Moolenaar012eb662018-03-13 17:55:27 +0100492 exe buf . 'bwipe'
Bram Moolenaar05aafed2017-08-11 19:12:11 +0200493endfunc
Bram Moolenaar679653e2017-08-13 14:13:19 +0200494
495" must be last, we can't go back from GUI to terminal
496func Test_zz_terminal_in_gui()
Bram Moolenaar9f0139a2017-08-13 20:26:20 +0200497 if !CanRunGui()
Bram Moolenaar679653e2017-08-13 14:13:19 +0200498 return
499 endif
Bram Moolenaar97f65fa2017-08-29 20:42:07 +0200500
501 " Ignore the "failed to create input context" error.
502 call test_ignore_error('E285:')
503
Bram Moolenaar679653e2017-08-13 14:13:19 +0200504 gui -f
505
506 call assert_equal(1, winnr('$'))
507 let buf = Run_shell_in_terminal({'term_finish': 'close'})
508 call Stop_shell_in_terminal(buf)
509 call term_wait(buf)
510
511 " closing window wipes out the terminal buffer a with finished job
512 call WaitFor("winnr('$') == 1")
513 call assert_equal(1, winnr('$'))
514 call assert_equal("", bufname(buf))
515
516 unlet g:job
517endfunc
Bram Moolenaardcaa6132017-08-13 17:13:09 +0200518
519func Test_terminal_list_args()
520 let buf = term_start([&shell, &shellcmdflag, 'echo "123"'])
521 call assert_fails(buf . 'bwipe', 'E517')
522 exe buf . 'bwipe!'
523 call assert_equal("", bufname(buf))
524endfunction
Bram Moolenaar97bd5e62017-08-18 20:50:30 +0200525
526func Test_terminal_noblock()
Bram Moolenaarab8b1c12017-11-04 19:24:31 +0100527 let buf = term_start(&shell)
Bram Moolenaard8d85bf2017-09-03 18:08:00 +0200528 if has('mac')
529 " The shell or something else has a problem dealing with more than 1000
530 " characters at the same time.
531 let len = 1000
532 else
533 let len = 5000
534 endif
Bram Moolenaar97bd5e62017-08-18 20:50:30 +0200535
536 for c in ['a','b','c','d','e','f','g','h','i','j','k']
Bram Moolenaarab8b1c12017-11-04 19:24:31 +0100537 call term_sendkeys(buf, 'echo ' . repeat(c, len) . "\<cr>")
Bram Moolenaar97bd5e62017-08-18 20:50:30 +0200538 endfor
Bram Moolenaarab8b1c12017-11-04 19:24:31 +0100539 call term_sendkeys(buf, "echo done\<cr>")
Bram Moolenaareef05312017-08-20 20:21:23 +0200540
541 " On MS-Windows there is an extra empty line below "done". Find "done" in
542 " the last-but-one or the last-but-two line.
Bram Moolenaarab8b1c12017-11-04 19:24:31 +0100543 let lnum = term_getsize(buf)[0] - 1
Bram Moolenaar21810142018-02-02 18:30:36 +0100544 call WaitFor({-> term_getline(buf, lnum) =~ "done" || term_getline(buf, lnum - 1) =~ "done"}, 10000)
Bram Moolenaarab8b1c12017-11-04 19:24:31 +0100545 let line = term_getline(buf, lnum)
Bram Moolenaareef05312017-08-20 20:21:23 +0200546 if line !~ 'done'
Bram Moolenaarab8b1c12017-11-04 19:24:31 +0100547 let line = term_getline(buf, lnum - 1)
Bram Moolenaareef05312017-08-20 20:21:23 +0200548 endif
549 call assert_match('done', line)
Bram Moolenaar97bd5e62017-08-18 20:50:30 +0200550
Bram Moolenaarab8b1c12017-11-04 19:24:31 +0100551 let g:job = term_getjob(buf)
552 call Stop_shell_in_terminal(buf)
553 call term_wait(buf)
Bram Moolenaard21f8b52017-08-19 15:40:01 +0200554 unlet g:job
Bram Moolenaar97bd5e62017-08-18 20:50:30 +0200555 bwipe
556endfunc
Bram Moolenaar37819ed2017-08-20 19:33:47 +0200557
558func Test_terminal_write_stdin()
Bram Moolenaar3346cc42017-09-02 14:54:21 +0200559 if !executable('wc')
Bram Moolenaardada6d22017-09-02 17:18:35 +0200560 throw 'skipped: wc command not available'
Bram Moolenaar37819ed2017-08-20 19:33:47 +0200561 endif
562 new
563 call setline(1, ['one', 'two', 'three'])
564 %term wc
Bram Moolenaardada6d22017-09-02 17:18:35 +0200565 call WaitFor('getline("$") =~ "3"')
Bram Moolenaar3346cc42017-09-02 14:54:21 +0200566 let nrs = split(getline('$'))
Bram Moolenaar37819ed2017-08-20 19:33:47 +0200567 call assert_equal(['3', '3', '14'], nrs)
568 bwipe
569
Bram Moolenaardada6d22017-09-02 17:18:35 +0200570 new
Bram Moolenaar37819ed2017-08-20 19:33:47 +0200571 call setline(1, ['one', 'two', 'three', 'four'])
572 2,3term wc
Bram Moolenaardada6d22017-09-02 17:18:35 +0200573 call WaitFor('getline("$") =~ "2"')
Bram Moolenaar3346cc42017-09-02 14:54:21 +0200574 let nrs = split(getline('$'))
Bram Moolenaar37819ed2017-08-20 19:33:47 +0200575 call assert_equal(['2', '2', '10'], nrs)
576 bwipe
577
Bram Moolenaardada6d22017-09-02 17:18:35 +0200578 if executable('python')
579 new
580 call setline(1, ['print("hello")'])
581 1term ++eof=exit() python
582 " MS-Windows echoes the input, Unix doesn't.
583 call WaitFor('getline("$") =~ "exit" || getline(1) =~ "hello"')
584 if getline(1) =~ 'hello'
585 call assert_equal('hello', getline(1))
586 else
587 call assert_equal('hello', getline(line('$') - 1))
588 endif
589 bwipe
590
591 if has('win32')
592 new
593 call setline(1, ['print("hello")'])
594 1term ++eof=<C-Z> python
595 call WaitFor('getline("$") =~ "Z"')
596 call assert_equal('hello', getline(line('$') - 1))
597 bwipe
598 endif
599 endif
600
Bram Moolenaar37819ed2017-08-20 19:33:47 +0200601 bwipe!
602endfunc
Bram Moolenaar13ebb032017-08-26 22:02:51 +0200603
604func Test_terminal_no_cmd()
Bram Moolenaar13ebb032017-08-26 22:02:51 +0200605 " Todo: make this work in the GUI
606 if !has('gui_running')
607 return
608 endif
609 let buf = term_start('NONE', {})
610 call assert_notequal(0, buf)
611
Bram Moolenaar2dc9d262017-09-08 14:39:30 +0200612 let pty = job_info(term_getjob(buf))['tty_out']
Bram Moolenaar13ebb032017-08-26 22:02:51 +0200613 call assert_notequal('', pty)
Bram Moolenaar2dc9d262017-09-08 14:39:30 +0200614 if has('win32')
Bram Moolenaare738a1a2017-09-16 17:42:41 +0200615 silent exe '!start cmd /c "echo look here > ' . pty . '"'
Bram Moolenaar2dc9d262017-09-08 14:39:30 +0200616 else
617 call system('echo "look here" > ' . pty)
618 endif
Bram Moolenaar012eb662018-03-13 17:55:27 +0100619 call WaitFor({-> term_getline(buf, 1) =~ "look here"})
Bram Moolenaar2dc9d262017-09-08 14:39:30 +0200620
Bram Moolenaare738a1a2017-09-16 17:42:41 +0200621 call assert_match('look here', term_getline(buf, 1))
Bram Moolenaar13ebb032017-08-26 22:02:51 +0200622 bwipe!
623endfunc
Bram Moolenaar9d654a82017-09-03 19:52:17 +0200624
625func Test_terminal_special_chars()
626 " this file name only works on Unix
627 if !has('unix')
628 return
629 endif
630 call mkdir('Xdir with spaces')
631 call writefile(['x'], 'Xdir with spaces/quoted"file')
632 term ls Xdir\ with\ spaces/quoted\"file
633 call WaitFor('term_getline("", 1) =~ "quoted"')
634 call assert_match('quoted"file', term_getline('', 1))
635 call term_wait('')
636
637 call delete('Xdir with spaces', 'rf')
638 bwipe
639endfunc
Bram Moolenaare88fc7a2017-09-03 20:59:40 +0200640
641func Test_terminal_wrong_options()
642 call assert_fails('call term_start(&shell, {
643 \ "in_io": "file",
644 \ "in_name": "xxx",
645 \ "out_io": "file",
646 \ "out_name": "xxx",
647 \ "err_io": "file",
648 \ "err_name": "xxx"
649 \ })', 'E474:')
650 call assert_fails('call term_start(&shell, {
651 \ "out_buf": bufnr("%")
652 \ })', 'E474:')
653 call assert_fails('call term_start(&shell, {
654 \ "err_buf": bufnr("%")
655 \ })', 'E474:')
656endfunc
657
658func Test_terminal_redir_file()
Bram Moolenaar17833372017-09-04 22:23:19 +0200659 " TODO: this should work on MS-Window
660 if has('unix')
661 let cmd = Get_cat_123_cmd()
662 let buf = term_start(cmd, {'out_io': 'file', 'out_name': 'Xfile'})
663 call term_wait(buf)
664 call WaitFor('len(readfile("Xfile")) > 0')
665 call assert_match('123', readfile('Xfile')[0])
Bram Moolenaare9f6fd22017-09-10 14:25:49 +0200666 let g:job = term_getjob(buf)
667 call WaitFor('job_status(g:job) == "dead"')
Bram Moolenaar17833372017-09-04 22:23:19 +0200668 call delete('Xfile')
Bram Moolenaar2dc9d262017-09-08 14:39:30 +0200669 bwipe
Bram Moolenaar17833372017-09-04 22:23:19 +0200670 endif
Bram Moolenaare88fc7a2017-09-03 20:59:40 +0200671
672 if has('unix')
Bram Moolenaare88fc7a2017-09-03 20:59:40 +0200673 call writefile(['one line'], 'Xfile')
674 let buf = term_start('cat', {'in_io': 'file', 'in_name': 'Xfile'})
675 call term_wait(buf)
676 call WaitFor('term_getline(' . buf . ', 1) == "one line"')
677 call assert_equal('one line', term_getline(buf, 1))
Bram Moolenaar8b53b792017-09-05 20:29:25 +0200678 let g:job = term_getjob(buf)
679 call WaitFor('job_status(g:job) == "dead"')
Bram Moolenaare88fc7a2017-09-03 20:59:40 +0200680 bwipe
681 call delete('Xfile')
682 endif
683endfunc
Bram Moolenaar69fbc9e2017-09-14 20:37:57 +0200684
685func TerminalTmap(remap)
686 let buf = Run_shell_in_terminal({})
687 call assert_equal('t', mode())
688
689 if a:remap
690 tmap 123 456
691 else
692 tnoremap 123 456
693 endif
Bram Moolenaar461fe502017-12-05 12:30:03 +0100694 " don't use abcde, it's an existing command
695 tmap 456 abxde
Bram Moolenaar69fbc9e2017-09-14 20:37:57 +0200696 call assert_equal('456', maparg('123', 't'))
Bram Moolenaar461fe502017-12-05 12:30:03 +0100697 call assert_equal('abxde', maparg('456', 't'))
Bram Moolenaar69fbc9e2017-09-14 20:37:57 +0200698 call feedkeys("123", 'tx')
Bram Moolenaar012eb662018-03-13 17:55:27 +0100699 call WaitFor({-> term_getline(buf, term_getcursor(buf)[0]) =~ 'abxde\|456'})
Bram Moolenaar69fbc9e2017-09-14 20:37:57 +0200700 let lnum = term_getcursor(buf)[0]
701 if a:remap
Bram Moolenaar461fe502017-12-05 12:30:03 +0100702 call assert_match('abxde', term_getline(buf, lnum))
Bram Moolenaar69fbc9e2017-09-14 20:37:57 +0200703 else
704 call assert_match('456', term_getline(buf, lnum))
705 endif
706
707 call term_sendkeys(buf, "\r")
708 call Stop_shell_in_terminal(buf)
709 call term_wait(buf)
710
711 tunmap 123
712 tunmap 456
713 call assert_equal('', maparg('123', 't'))
714 close
715 unlet g:job
716endfunc
717
718func Test_terminal_tmap()
719 call TerminalTmap(1)
720 call TerminalTmap(0)
721endfunc
Bram Moolenaar059db5c2017-10-15 22:42:23 +0200722
723func Test_terminal_wall()
724 let buf = Run_shell_in_terminal({})
725 wall
726 call Stop_shell_in_terminal(buf)
727 call term_wait(buf)
728 exe buf . 'bwipe'
729 unlet g:job
730endfunc
Bram Moolenaar6daeef12017-10-15 22:56:49 +0200731
Bram Moolenaar7a760922018-02-19 23:10:02 +0100732func Test_terminal_wqall()
733 let buf = Run_shell_in_terminal({})
734 call assert_fails('wqall', 'E948')
735 call Stop_shell_in_terminal(buf)
736 call term_wait(buf)
737 exe buf . 'bwipe'
738 unlet g:job
739endfunc
740
Bram Moolenaar6daeef12017-10-15 22:56:49 +0200741func Test_terminal_composing_unicode()
742 let save_enc = &encoding
743 set encoding=utf-8
744
745 if has('win32')
746 let cmd = "cmd /K chcp 65001"
747 let lnum = [3, 6, 9]
748 else
749 let cmd = &shell
750 let lnum = [1, 3, 5]
751 endif
752
753 enew
754 let buf = term_start(cmd, {'curwin': bufnr('')})
Bram Moolenaar3e1c6172017-11-02 16:58:00 +0100755 let g:job = term_getjob(buf)
Bram Moolenaar6daeef12017-10-15 22:56:49 +0200756 call term_wait(buf, 50)
757
758 " ascii + composing
759 let txt = "a\u0308bc"
760 call term_sendkeys(buf, "echo " . txt . "\r")
761 call term_wait(buf, 50)
762 call assert_match("echo " . txt, term_getline(buf, lnum[0]))
763 call assert_equal(txt, term_getline(buf, lnum[0] + 1))
764 let l = term_scrape(buf, lnum[0] + 1)
765 call assert_equal("a\u0308", l[0].chars)
766 call assert_equal("b", l[1].chars)
767 call assert_equal("c", l[2].chars)
768
769 " multibyte + composing
770 let txt = "\u304b\u3099\u304e\u304f\u3099\u3052\u3053\u3099"
771 call term_sendkeys(buf, "echo " . txt . "\r")
772 call term_wait(buf, 50)
773 call assert_match("echo " . txt, term_getline(buf, lnum[1]))
774 call assert_equal(txt, term_getline(buf, lnum[1] + 1))
775 let l = term_scrape(buf, lnum[1] + 1)
776 call assert_equal("\u304b\u3099", l[0].chars)
777 call assert_equal("\u304e", l[1].chars)
778 call assert_equal("\u304f\u3099", l[2].chars)
779 call assert_equal("\u3052", l[3].chars)
780 call assert_equal("\u3053\u3099", l[4].chars)
781
782 " \u00a0 + composing
783 let txt = "abc\u00a0\u0308"
784 call term_sendkeys(buf, "echo " . txt . "\r")
785 call term_wait(buf, 50)
786 call assert_match("echo " . txt, term_getline(buf, lnum[2]))
787 call assert_equal(txt, term_getline(buf, lnum[2] + 1))
788 let l = term_scrape(buf, lnum[2] + 1)
789 call assert_equal("\u00a0\u0308", l[3].chars)
790
791 call term_sendkeys(buf, "exit\r")
Bram Moolenaar3e1c6172017-11-02 16:58:00 +0100792 call WaitFor('job_status(g:job) == "dead"')
793 call assert_equal('dead', job_status(g:job))
Bram Moolenaar6daeef12017-10-15 22:56:49 +0200794 bwipe!
Bram Moolenaar3e1c6172017-11-02 16:58:00 +0100795 unlet g:job
Bram Moolenaar6daeef12017-10-15 22:56:49 +0200796 let &encoding = save_enc
797endfunc
Bram Moolenaarff546792017-11-21 14:47:57 +0100798
799func Test_terminal_aucmd_on_close()
800 fun Nop()
801 let s:called = 1
802 endfun
803
804 aug repro
805 au!
806 au BufWinLeave * call Nop()
807 aug END
808
809 let [cmd, waittime] = s:get_sleep_cmd()
810
811 call assert_equal(1, winnr('$'))
812 new
813 call setline(1, ['one', 'two'])
814 exe 'term ++close ' . cmd
815 wincmd p
816 call WaitFor("winnr('$') == 2", waittime)
817 call assert_equal(1, s:called)
818 bwipe!
819
820 unlet s:called
821 au! repro
822 delfunc Nop
823endfunc
Bram Moolenaarede35bb2018-01-26 20:05:18 +0100824
825func Test_terminal_term_start_empty_command()
826 let cmd = "call term_start('', {'curwin' : 1, 'term_finish' : 'close'})"
827 call assert_fails(cmd, 'E474')
828 let cmd = "call term_start('', {'curwin' : 1, 'term_finish' : 'close'})"
829 call assert_fails(cmd, 'E474')
830 let cmd = "call term_start({}, {'curwin' : 1, 'term_finish' : 'close'})"
831 call assert_fails(cmd, 'E474')
832 let cmd = "call term_start(0, {'curwin' : 1, 'term_finish' : 'close'})"
833 call assert_fails(cmd, 'E474')
834endfunc
Bram Moolenaarb50773c2018-01-30 22:31:19 +0100835
836func Test_terminal_response_to_control_sequence()
837 if !has('unix')
838 return
839 endif
840
841 let buf = Run_shell_in_terminal({})
Bram Moolenaar086eb872018-03-25 21:24:12 +0200842 call WaitFor({-> term_getline(buf, 1) != ''})
Bram Moolenaarb50773c2018-01-30 22:31:19 +0100843
Bram Moolenaar086eb872018-03-25 21:24:12 +0200844 call term_sendkeys(buf, "cat\<CR>")
845 call WaitFor({-> term_getline(buf, 1) =~ 'cat'})
Bram Moolenaard4a282f2018-02-02 18:22:31 +0100846
Bram Moolenaar086eb872018-03-25 21:24:12 +0200847 " Request the cursor position.
848 call term_sendkeys(buf, "\x1b[6n\<CR>")
Bram Moolenaard4a282f2018-02-02 18:22:31 +0100849
850 " Wait for output from tty to display, below an empty line.
Bram Moolenaar086eb872018-03-25 21:24:12 +0200851 call WaitFor({-> term_getline(buf, 4) =~ '3;1R'})
Bram Moolenaarb50773c2018-01-30 22:31:19 +0100852
Bram Moolenaar086eb872018-03-25 21:24:12 +0200853 " End "cat" gently.
854 call term_sendkeys(buf, "\<CR>\<C-D>")
855
Bram Moolenaarb50773c2018-01-30 22:31:19 +0100856 call Stop_shell_in_terminal(buf)
Bram Moolenaarb50773c2018-01-30 22:31:19 +0100857 exe buf . 'bwipe'
858 unlet g:job
859endfunc
Bram Moolenaar25cdd9c2018-03-10 20:28:12 +0100860
Bram Moolenaar3e8d3852018-03-20 17:43:01 +0100861" Run Vim, start a terminal in that Vim with the kill argument,
862" :qall works.
863func Run_terminal_qall_kill(line1, line2)
864 " 1. Open a terminal window and wait for the prompt to appear
865 " 2. set kill using term_setkill()
866 " 3. make Vim exit, it will kill the shell
867 let after = [
868 \ a:line1,
869 \ 'let buf = bufnr("%")',
870 \ 'while term_getline(buf, 1) =~ "^\\s*$"',
871 \ ' sleep 10m',
872 \ 'endwhile',
873 \ a:line2,
874 \ 'au VimLeavePre * call writefile(["done"], "Xdone")',
875 \ 'qall',
876 \ ]
877 if !RunVim([], after, '')
Bram Moolenaar25cdd9c2018-03-10 20:28:12 +0100878 return
879 endif
Bram Moolenaar3e8d3852018-03-20 17:43:01 +0100880 call assert_equal("done", readfile("Xdone")[0])
881 call delete("Xdone")
Bram Moolenaar25cdd9c2018-03-10 20:28:12 +0100882endfunc
883
884" Run Vim in a terminal, then start a terminal in that Vim with a kill
885" argument, check that :qall works.
Bram Moolenaar3e8d3852018-03-20 17:43:01 +0100886func Test_terminal_qall_kill_arg()
887 call Run_terminal_qall_kill('term ++kill=kill', '')
888endfunc
889
890" Run Vim, start a terminal in that Vim, set the kill argument with
891" term_setkill(), check that :qall works.
Bram Moolenaar25cdd9c2018-03-10 20:28:12 +0100892func Test_terminal_qall_kill_func()
Bram Moolenaar3e8d3852018-03-20 17:43:01 +0100893 call Run_terminal_qall_kill('term', 'call term_setkill(buf, "kill")')
894endfunc
895
896" Run Vim, start a terminal in that Vim without the kill argument,
897" check that :qall does not exit, :qall! does.
898func Test_terminal_qall_exit()
899 let after = [
900 \ 'term',
901 \ 'let buf = bufnr("%")',
902 \ 'while term_getline(buf, 1) =~ "^\\s*$"',
903 \ ' sleep 10m',
904 \ 'endwhile',
905 \ 'set nomore',
906 \ 'au VimLeavePre * call writefile(["too early"], "Xdone")',
907 \ 'qall',
908 \ 'au! VimLeavePre * exe buf . "bwipe!" | call writefile(["done"], "Xdone")',
909 \ 'cquit',
910 \ ]
911 if !RunVim([], after, '')
Bram Moolenaar25cdd9c2018-03-10 20:28:12 +0100912 return
913 endif
Bram Moolenaar3e8d3852018-03-20 17:43:01 +0100914 call assert_equal("done", readfile("Xdone")[0])
915 call delete("Xdone")
Bram Moolenaar25cdd9c2018-03-10 20:28:12 +0100916endfunc
Bram Moolenaar435acdb2018-03-10 20:51:25 +0100917
918" Run Vim in a terminal, then start a terminal in that Vim without a kill
919" argument, check that :confirm qall works.
920func Test_terminal_qall_prompt()
921 if !CanRunVimInTerminal()
922 return
923 endif
924 let buf = RunVimInTerminal('', {})
925
926 " Open a terminal window and wait for the prompt to appear
927 call term_sendkeys(buf, ":term\<CR>")
928 call WaitFor({-> term_getline(buf, 10) =~ '\[running]'})
929 call WaitFor({-> term_getline(buf, 1) !~ '^\s*$'})
930
931 " make Vim exit, it will prompt to kill the shell
932 call term_sendkeys(buf, "\<C-W>:confirm qall\<CR>")
933 call WaitFor({-> term_getline(buf, 20) =~ 'ancel:'})
934 call term_sendkeys(buf, "y")
935 call WaitFor({-> term_getstatus(buf) == "finished"})
936
937 " close the terminal window where Vim was running
938 quit
939endfunc
Bram Moolenaarb852c3e2018-03-11 16:55:36 +0100940
Bram Moolenaar012eb662018-03-13 17:55:27 +0100941func Test_terminal_open_autocmd()
Bram Moolenaarb852c3e2018-03-11 16:55:36 +0100942 augroup repro
943 au!
944 au TerminalOpen * let s:called += 1
945 augroup END
946
947 let s:called = 0
948
949 " Open a terminal window with :terminal
950 terminal
951 call assert_equal(1, s:called)
952 bwipe!
953
954 " Open a terminal window with term_start()
955 call term_start(&shell)
956 call assert_equal(2, s:called)
957 bwipe!
958
959 " Open a hidden terminal buffer with :terminal
960 terminal ++hidden
961 call assert_equal(3, s:called)
962 for buf in term_list()
963 exe buf . "bwipe!"
964 endfor
965
966 " Open a hidden terminal buffer with term_start()
967 let buf = term_start(&shell, {'hidden': 1})
968 call assert_equal(4, s:called)
969 exe buf . "bwipe!"
970
971 unlet s:called
972 au! repro
973endfunction
Bram Moolenaar45d2a642018-03-24 14:30:32 +0100974
975func Check_dump01(off)
976 call assert_equal('one two three four five', trim(getline(a:off + 1)))
977 call assert_equal('~ Select Word', trim(getline(a:off + 7)))
978 call assert_equal(':popup PopUp :', trim(getline(a:off + 20)))
979endfunc
980
981" just testing basic functionality.
982func Test_terminal_dumpload()
983 call assert_equal(1, winnr('$'))
984 call term_dumpload('dumps/Test_popup_command_01.dump')
985 call assert_equal(2, winnr('$'))
986 call assert_equal(20, line('$'))
987 call Check_dump01(0)
988 quit
989endfunc
990
991func Test_terminal_dumpdiff()
992 call assert_equal(1, winnr('$'))
993 call term_dumpdiff('dumps/Test_popup_command_01.dump', 'dumps/Test_popup_command_02.dump')
994 call assert_equal(2, winnr('$'))
995 call assert_equal(62, line('$'))
996 call Check_dump01(0)
997 call Check_dump01(42)
998 call assert_equal(' bbbbbbbbbbbbbbbbbb ', getline(26)[0:29])
999 quit
1000endfunc
Bram Moolenaar897e63c2018-03-24 17:16:33 +01001001
1002func Test_terminal_dumpdiff_options()
1003 set laststatus=0
1004 call assert_equal(1, winnr('$'))
1005 let height = winheight(0)
1006 call term_dumpdiff('dumps/Test_popup_command_01.dump', 'dumps/Test_popup_command_02.dump', {'vertical': 1, 'term_cols': 33})
1007 call assert_equal(2, winnr('$'))
1008 call assert_equal(height, winheight(winnr()))
1009 call assert_equal(33, winwidth(winnr()))
1010 call assert_equal('dump diff dumps/Test_popup_command_01.dump', bufname('%'))
1011 quit
1012
1013 call assert_equal(1, winnr('$'))
1014 let width = winwidth(0)
1015 call term_dumpdiff('dumps/Test_popup_command_01.dump', 'dumps/Test_popup_command_02.dump', {'vertical': 0, 'term_rows': 13, 'term_name': 'something else'})
1016 call assert_equal(2, winnr('$'))
1017 call assert_equal(width, winwidth(winnr()))
1018 call assert_equal(13, winheight(winnr()))
1019 call assert_equal('something else', bufname('%'))
1020 quit
1021
1022 call assert_equal(1, winnr('$'))
1023 call term_dumpdiff('dumps/Test_popup_command_01.dump', 'dumps/Test_popup_command_02.dump', {'curwin': 1})
1024 call assert_equal(1, winnr('$'))
1025 bwipe
1026
1027 set laststatus&
1028endfunc
Bram Moolenaar8fbaeb12018-03-25 18:20:17 +02001029
1030func Test_terminal_api_drop_newwin()
1031 if !CanRunVimInTerminal()
1032 return
1033 endif
1034 call assert_equal(1, winnr('$'))
1035
1036 " Use the title termcap entries to output the escape sequence.
1037 call writefile([
Bram Moolenaarcf67a502018-03-25 20:31:32 +02001038 \ 'set title',
Bram Moolenaar8fbaeb12018-03-25 18:20:17 +02001039 \ 'exe "set t_ts=\<Esc>]51; t_fs=\x07"',
1040 \ 'let &titlestring = ''["drop","Xtextfile"]''',
1041 \ 'redraw',
1042 \ "set t_ts=",
1043 \ ], 'Xscript')
1044 let buf = RunVimInTerminal('-S Xscript', {})
1045 call WaitFor({-> bufnr('Xtextfile') > 0})
1046 call assert_equal('Xtextfile', expand('%:t'))
1047 call assert_true(winnr('$') >= 3)
1048
1049 call StopVimInTerminal(buf)
1050 call delete('Xscript')
1051 bwipe Xtextfile
1052endfunc
1053
1054func Test_terminal_api_drop_oldwin()
1055 if !CanRunVimInTerminal()
1056 return
1057 endif
1058 let firstwinid = win_getid()
1059 split Xtextfile
1060 let textfile_winid = win_getid()
1061 call assert_equal(2, winnr('$'))
1062 call win_gotoid(firstwinid)
1063
1064 " Use the title termcap entries to output the escape sequence.
1065 call writefile([
Bram Moolenaarcf67a502018-03-25 20:31:32 +02001066 \ 'set title',
Bram Moolenaar8fbaeb12018-03-25 18:20:17 +02001067 \ 'exe "set t_ts=\<Esc>]51; t_fs=\x07"',
1068 \ 'let &titlestring = ''["drop","Xtextfile"]''',
1069 \ 'redraw',
1070 \ "set t_ts=",
1071 \ ], 'Xscript')
Bram Moolenaar15a1c3f2018-03-25 18:56:25 +02001072 let buf = RunVimInTerminal('-S Xscript', {'rows': 10})
Bram Moolenaar8fbaeb12018-03-25 18:20:17 +02001073 call WaitFor({-> expand('%:t') =='Xtextfile'})
1074 call assert_equal(textfile_winid, win_getid())
1075
1076 call StopVimInTerminal(buf)
1077 call delete('Xscript')
1078 bwipe Xtextfile
1079endfunc
1080
Bram Moolenaar2a77d212018-03-26 21:38:52 +02001081func Tapi_TryThis(bufnum, arg)
Bram Moolenaar8fbaeb12018-03-25 18:20:17 +02001082 let g:called_bufnum = a:bufnum
1083 let g:called_arg = a:arg
1084endfunc
1085
Bram Moolenaar2a77d212018-03-26 21:38:52 +02001086func WriteApiCall(funcname)
1087 " Use the title termcap entries to output the escape sequence.
1088 call writefile([
1089 \ 'set title',
1090 \ 'exe "set t_ts=\<Esc>]51; t_fs=\x07"',
1091 \ 'let &titlestring = ''["call","' . a:funcname . '",["hello",123]]''',
1092 \ 'redraw',
1093 \ "set t_ts=",
1094 \ ], 'Xscript')
1095endfunc
1096
Bram Moolenaar8fbaeb12018-03-25 18:20:17 +02001097func Test_terminal_api_call()
1098 if !CanRunVimInTerminal()
1099 return
1100 endif
Bram Moolenaar2de50f82018-03-25 19:09:56 +02001101
Bram Moolenaar2a77d212018-03-26 21:38:52 +02001102 call WriteApiCall('Tapi_TryThis')
Bram Moolenaar8fbaeb12018-03-25 18:20:17 +02001103 let buf = RunVimInTerminal('-S Xscript', {})
1104 call WaitFor({-> exists('g:called_bufnum')})
1105 call assert_equal(buf, g:called_bufnum)
1106 call assert_equal(['hello', 123], g:called_arg)
1107
1108 call StopVimInTerminal(buf)
1109 call delete('Xscript')
1110 unlet g:called_bufnum
1111 unlet g:called_arg
1112endfunc
Bram Moolenaar2a77d212018-03-26 21:38:52 +02001113
1114func Test_terminal_api_call_fails()
1115 if !CanRunVimInTerminal()
1116 return
1117 endif
1118
1119 call WriteApiCall('TryThis')
1120 call ch_logfile('Xlog', 'w')
1121 let buf = RunVimInTerminal('-S Xscript', {})
1122 call WaitFor({-> string(readfile('Xlog')) =~ 'Invalid function name: TryThis'})
1123
1124 call StopVimInTerminal(buf)
1125 call delete('Xscript')
1126 call ch_logfile('', '')
1127 call delete('Xlog')
1128endfunc