2017-07-29 20:15:08 +02:00
|
|
|
" Tests for the terminal window.
|
|
|
|
|
2017-08-18 21:07:11 +02:00
|
|
|
if !has('terminal')
|
2017-07-29 20:15:08 +02:00
|
|
|
finish
|
|
|
|
endif
|
|
|
|
|
|
|
|
source shared.vim
|
2018-03-10 20:28:12 +01:00
|
|
|
source screendump.vim
|
2017-07-29 20:15:08 +02:00
|
|
|
|
2017-08-11 22:45:01 +02:00
|
|
|
let s:python = PythonProg()
|
|
|
|
|
2017-08-01 21:44:33 +02:00
|
|
|
" Open a terminal with a shell, assign the job to g:job and return the buffer
|
|
|
|
" number.
|
2017-08-11 19:12:11 +02:00
|
|
|
func Run_shell_in_terminal(options)
|
2017-10-30 21:56:23 +01:00
|
|
|
if has('win32')
|
|
|
|
let buf = term_start([&shell,'/k'], a:options)
|
|
|
|
else
|
|
|
|
let buf = term_start(&shell, a:options)
|
|
|
|
endif
|
2017-07-29 20:15:08 +02:00
|
|
|
|
|
|
|
let termlist = term_list()
|
|
|
|
call assert_equal(1, len(termlist))
|
|
|
|
call assert_equal(buf, termlist[0])
|
|
|
|
|
|
|
|
let g:job = term_getjob(buf)
|
|
|
|
call assert_equal(v:t_job, type(g:job))
|
|
|
|
|
2017-08-05 16:33:56 +02:00
|
|
|
let string = string({'job': term_getjob(buf)})
|
|
|
|
call assert_match("{'job': 'process \\d\\+ run'}", string)
|
|
|
|
|
2017-08-01 21:44:33 +02:00
|
|
|
return buf
|
|
|
|
endfunc
|
|
|
|
|
2017-08-01 20:25:22 +02:00
|
|
|
func Test_terminal_basic()
|
2017-09-21 22:16:21 +02:00
|
|
|
au BufWinEnter * if &buftype == 'terminal' | let b:done = 'yes' | endif
|
2017-08-11 19:12:11 +02:00
|
|
|
let buf = Run_shell_in_terminal({})
|
2017-09-21 22:16:21 +02:00
|
|
|
|
2017-08-03 13:51:25 +02:00
|
|
|
if has("unix")
|
2017-09-08 14:39:30 +02:00
|
|
|
call assert_match('^/dev/', job_info(g:job).tty_out)
|
|
|
|
call assert_match('^/dev/', term_gettty(''))
|
2017-08-03 13:51:25 +02:00
|
|
|
else
|
2017-09-08 14:39:30 +02:00
|
|
|
call assert_match('^\\\\.\\pipe\\', job_info(g:job).tty_out)
|
|
|
|
call assert_match('^\\\\.\\pipe\\', term_gettty(''))
|
2017-08-03 13:51:25 +02:00
|
|
|
endif
|
2017-08-13 20:58:33 +02:00
|
|
|
call assert_equal('t', mode())
|
2017-09-21 22:16:21 +02:00
|
|
|
call assert_equal('yes', b:done)
|
2017-08-13 20:58:33 +02:00
|
|
|
call assert_match('%aR[^\n]*running]', execute('ls'))
|
|
|
|
|
2017-08-01 21:44:33 +02:00
|
|
|
call Stop_shell_in_terminal(buf)
|
|
|
|
call term_wait(buf)
|
2017-08-13 20:58:33 +02:00
|
|
|
call assert_equal('n', mode())
|
|
|
|
call assert_match('%aF[^\n]*finished]', execute('ls'))
|
2017-08-01 21:44:33 +02:00
|
|
|
|
|
|
|
" closing window wipes out the terminal buffer a with finished job
|
|
|
|
close
|
|
|
|
call assert_equal("", bufname(buf))
|
2017-08-01 20:25:22 +02:00
|
|
|
|
2017-09-21 22:16:21 +02:00
|
|
|
au! BufWinEnter
|
2017-08-01 20:25:22 +02:00
|
|
|
unlet g:job
|
|
|
|
endfunc
|
|
|
|
|
|
|
|
func Test_terminal_make_change()
|
2017-08-11 19:12:11 +02:00
|
|
|
let buf = Run_shell_in_terminal({})
|
2017-08-01 21:44:33 +02:00
|
|
|
call Stop_shell_in_terminal(buf)
|
2017-08-01 20:25:22 +02:00
|
|
|
call term_wait(buf)
|
|
|
|
|
|
|
|
setlocal modifiable
|
|
|
|
exe "normal Axxx\<Esc>"
|
|
|
|
call assert_fails(buf . 'bwipe', 'E517')
|
|
|
|
undo
|
|
|
|
|
2017-07-29 20:15:08 +02:00
|
|
|
exe buf . 'bwipe'
|
|
|
|
unlet g:job
|
|
|
|
endfunc
|
|
|
|
|
2017-08-01 21:44:33 +02:00
|
|
|
func Test_terminal_wipe_buffer()
|
2017-08-11 19:12:11 +02:00
|
|
|
let buf = Run_shell_in_terminal({})
|
2017-08-03 22:44:55 +02:00
|
|
|
call assert_fails(buf . 'bwipe', 'E517')
|
|
|
|
exe buf . 'bwipe!'
|
2017-08-01 21:44:33 +02:00
|
|
|
call WaitFor('job_status(g:job) == "dead"')
|
|
|
|
call assert_equal('dead', job_status(g:job))
|
|
|
|
call assert_equal("", bufname(buf))
|
|
|
|
|
|
|
|
unlet g:job
|
|
|
|
endfunc
|
|
|
|
|
2017-09-17 19:08:02 +02:00
|
|
|
func Test_terminal_split_quit()
|
|
|
|
let buf = Run_shell_in_terminal({})
|
|
|
|
call term_wait(buf)
|
|
|
|
split
|
|
|
|
quit!
|
|
|
|
call term_wait(buf)
|
|
|
|
sleep 50m
|
|
|
|
call assert_equal('run', job_status(g:job))
|
|
|
|
|
|
|
|
quit!
|
|
|
|
call WaitFor('job_status(g:job) == "dead"')
|
|
|
|
call assert_equal('dead', job_status(g:job))
|
|
|
|
|
|
|
|
exe buf . 'bwipe'
|
|
|
|
unlet g:job
|
|
|
|
endfunc
|
|
|
|
|
2017-08-01 21:44:33 +02:00
|
|
|
func Test_terminal_hide_buffer()
|
2017-08-11 19:12:11 +02:00
|
|
|
let buf = Run_shell_in_terminal({})
|
2017-08-30 13:31:49 +02:00
|
|
|
setlocal bufhidden=hide
|
2017-08-01 21:44:33 +02:00
|
|
|
quit
|
|
|
|
for nr in range(1, winnr('$'))
|
|
|
|
call assert_notequal(winbufnr(nr), buf)
|
|
|
|
endfor
|
|
|
|
call assert_true(bufloaded(buf))
|
|
|
|
call assert_true(buflisted(buf))
|
|
|
|
|
|
|
|
exe 'split ' . buf . 'buf'
|
|
|
|
call Stop_shell_in_terminal(buf)
|
|
|
|
exe buf . 'bwipe'
|
|
|
|
|
|
|
|
unlet g:job
|
|
|
|
endfunc
|
|
|
|
|
2017-08-03 17:06:45 +02:00
|
|
|
func! s:Nasty_exit_cb(job, st)
|
|
|
|
exe g:buf . 'bwipe!'
|
|
|
|
let g:buf = 0
|
|
|
|
endfunc
|
|
|
|
|
2017-09-09 18:11:00 +02:00
|
|
|
func Get_cat_123_cmd()
|
|
|
|
if has('win32')
|
|
|
|
return 'cmd /c "cls && color 2 && echo 123"'
|
|
|
|
else
|
|
|
|
call writefile(["\<Esc>[32m123"], 'Xtext')
|
|
|
|
return "cat Xtext"
|
|
|
|
endif
|
|
|
|
endfunc
|
|
|
|
|
2017-08-03 17:06:45 +02:00
|
|
|
func Test_terminal_nasty_cb()
|
2017-08-06 21:36:22 +02:00
|
|
|
let cmd = Get_cat_123_cmd()
|
2017-08-03 17:06:45 +02:00
|
|
|
let g:buf = term_start(cmd, {'exit_cb': function('s:Nasty_exit_cb')})
|
|
|
|
let g:job = term_getjob(g:buf)
|
|
|
|
|
|
|
|
call WaitFor('job_status(g:job) == "dead"')
|
|
|
|
call WaitFor('g:buf == 0')
|
|
|
|
unlet g:buf
|
|
|
|
unlet g:job
|
|
|
|
call delete('Xtext')
|
|
|
|
endfunc
|
|
|
|
|
2017-07-29 20:15:08 +02:00
|
|
|
func Check_123(buf)
|
2017-08-02 22:10:34 +02:00
|
|
|
let l = term_scrape(a:buf, 0)
|
|
|
|
call assert_true(len(l) == 0)
|
|
|
|
let l = term_scrape(a:buf, 999)
|
|
|
|
call assert_true(len(l) == 0)
|
2017-08-01 18:41:21 +02:00
|
|
|
let l = term_scrape(a:buf, 1)
|
2017-07-29 20:15:08 +02:00
|
|
|
call assert_true(len(l) > 0)
|
|
|
|
call assert_equal('1', l[0].chars)
|
|
|
|
call assert_equal('2', l[1].chars)
|
|
|
|
call assert_equal('3', l[2].chars)
|
|
|
|
call assert_equal('#00e000', l[0].fg)
|
|
|
|
if &background == 'light'
|
|
|
|
call assert_equal('#ffffff', l[0].bg)
|
|
|
|
else
|
|
|
|
call assert_equal('#000000', l[0].bg)
|
|
|
|
endif
|
|
|
|
|
2017-08-02 22:10:34 +02:00
|
|
|
let l = term_getline(a:buf, -1)
|
|
|
|
call assert_equal('', l)
|
|
|
|
let l = term_getline(a:buf, 0)
|
|
|
|
call assert_equal('', l)
|
|
|
|
let l = term_getline(a:buf, 999)
|
|
|
|
call assert_equal('', l)
|
2017-08-01 18:41:21 +02:00
|
|
|
let l = term_getline(a:buf, 1)
|
2017-07-29 20:15:08 +02:00
|
|
|
call assert_equal('123', l)
|
|
|
|
endfunc
|
|
|
|
|
2017-08-06 21:36:22 +02:00
|
|
|
func Test_terminal_scrape_123()
|
|
|
|
let cmd = Get_cat_123_cmd()
|
2017-07-29 20:15:08 +02:00
|
|
|
let buf = term_start(cmd)
|
|
|
|
|
|
|
|
let termlist = term_list()
|
|
|
|
call assert_equal(1, len(termlist))
|
|
|
|
call assert_equal(buf, termlist[0])
|
|
|
|
|
2017-07-30 18:02:12 +02:00
|
|
|
" Nothing happens with invalid buffer number
|
|
|
|
call term_wait(1234)
|
|
|
|
|
2017-07-29 20:15:08 +02:00
|
|
|
call term_wait(buf)
|
2017-09-04 22:23:19 +02:00
|
|
|
" On MS-Windows we first get a startup message of two lines, wait for the
|
2017-09-05 20:19:42 +02:00
|
|
|
" "cls" to happen, after that we have one line with three characters.
|
2017-11-04 19:24:31 +01:00
|
|
|
call WaitFor({-> len(term_scrape(buf, 1)) == 3})
|
2017-07-29 20:15:08 +02:00
|
|
|
call Check_123(buf)
|
|
|
|
|
|
|
|
" Must still work after the job ended.
|
2017-11-04 19:24:31 +01:00
|
|
|
let job = term_getjob(buf)
|
|
|
|
call WaitFor({-> job_status(job) == "dead"})
|
2017-07-29 20:15:08 +02:00
|
|
|
call term_wait(buf)
|
|
|
|
call Check_123(buf)
|
|
|
|
|
|
|
|
exe buf . 'bwipe'
|
2017-07-30 18:02:12 +02:00
|
|
|
call delete('Xtext')
|
2017-07-29 20:15:08 +02:00
|
|
|
endfunc
|
2017-08-05 17:13:48 +02:00
|
|
|
|
2017-08-06 21:36:22 +02:00
|
|
|
func Test_terminal_scrape_multibyte()
|
|
|
|
if !has('multi_byte')
|
|
|
|
return
|
|
|
|
endif
|
|
|
|
call writefile(["léttまrs"], 'Xtext')
|
|
|
|
if has('win32')
|
2017-08-14 23:07:30 +02:00
|
|
|
" Run cmd with UTF-8 codepage to make the type command print the expected
|
|
|
|
" multibyte characters.
|
2017-11-04 19:24:31 +01:00
|
|
|
let buf = term_start("cmd /K chcp 65001")
|
|
|
|
call term_sendkeys(buf, "type Xtext\<CR>")
|
|
|
|
call term_sendkeys(buf, "exit\<CR>")
|
|
|
|
let line = 4
|
2017-08-06 21:36:22 +02:00
|
|
|
else
|
2017-11-04 19:24:31 +01:00
|
|
|
let buf = term_start("cat Xtext")
|
|
|
|
let line = 1
|
2017-08-06 21:36:22 +02:00
|
|
|
endif
|
|
|
|
|
2017-11-04 19:24:31 +01:00
|
|
|
call WaitFor({-> len(term_scrape(buf, line)) >= 7 && term_scrape(buf, line)[0].chars == "l"})
|
|
|
|
let l = term_scrape(buf, line)
|
2017-08-06 21:36:22 +02:00
|
|
|
call assert_true(len(l) >= 7)
|
|
|
|
call assert_equal('l', l[0].chars)
|
|
|
|
call assert_equal('é', l[1].chars)
|
|
|
|
call assert_equal(1, l[1].width)
|
|
|
|
call assert_equal('t', l[2].chars)
|
|
|
|
call assert_equal('t', l[3].chars)
|
|
|
|
call assert_equal('ま', l[4].chars)
|
|
|
|
call assert_equal(2, l[4].width)
|
|
|
|
call assert_equal('r', l[5].chars)
|
|
|
|
call assert_equal('s', l[6].chars)
|
|
|
|
|
2017-11-04 19:24:31 +01:00
|
|
|
let job = term_getjob(buf)
|
|
|
|
call WaitFor({-> job_status(job) == "dead"})
|
|
|
|
call term_wait(buf)
|
2017-08-06 21:36:22 +02:00
|
|
|
|
2017-11-04 19:24:31 +01:00
|
|
|
exe buf . 'bwipe'
|
2017-08-06 21:36:22 +02:00
|
|
|
call delete('Xtext')
|
|
|
|
endfunc
|
|
|
|
|
2017-08-07 20:38:42 +02:00
|
|
|
func Test_terminal_scroll()
|
|
|
|
call writefile(range(1, 200), 'Xtext')
|
|
|
|
if has('win32')
|
|
|
|
let cmd = 'cmd /c "type Xtext"'
|
|
|
|
else
|
|
|
|
let cmd = "cat Xtext"
|
|
|
|
endif
|
|
|
|
let buf = term_start(cmd)
|
|
|
|
|
2017-11-04 19:24:31 +01:00
|
|
|
let job = term_getjob(buf)
|
|
|
|
call WaitFor({-> job_status(job) == "dead"})
|
2017-08-07 20:38:42 +02:00
|
|
|
call term_wait(buf)
|
|
|
|
if has('win32')
|
|
|
|
" TODO: this should not be needed
|
|
|
|
sleep 100m
|
|
|
|
endif
|
|
|
|
|
2017-08-08 23:06:46 +02:00
|
|
|
let scrolled = term_getscrolled(buf)
|
2017-08-07 20:38:42 +02:00
|
|
|
call assert_equal('1', getline(1))
|
2017-08-08 23:06:46 +02:00
|
|
|
call assert_equal('1', term_getline(buf, 1 - scrolled))
|
2017-08-07 20:38:42 +02:00
|
|
|
call assert_equal('49', getline(49))
|
2017-08-08 23:06:46 +02:00
|
|
|
call assert_equal('49', term_getline(buf, 49 - scrolled))
|
2017-08-07 20:38:42 +02:00
|
|
|
call assert_equal('200', getline(200))
|
2017-08-08 23:06:46 +02:00
|
|
|
call assert_equal('200', term_getline(buf, 200 - scrolled))
|
2017-08-07 20:38:42 +02:00
|
|
|
|
|
|
|
exe buf . 'bwipe'
|
|
|
|
call delete('Xtext')
|
|
|
|
endfunc
|
|
|
|
|
2017-08-05 17:13:48 +02:00
|
|
|
func Test_terminal_size()
|
2017-08-06 21:36:22 +02:00
|
|
|
let cmd = Get_cat_123_cmd()
|
2017-08-05 17:13:48 +02:00
|
|
|
|
2017-08-20 18:09:14 +02:00
|
|
|
exe 'terminal ++rows=5 ' . cmd
|
2017-08-05 17:13:48 +02:00
|
|
|
let size = term_getsize('')
|
|
|
|
bwipe!
|
|
|
|
call assert_equal(5, size[0])
|
|
|
|
|
2017-08-11 21:51:23 +02:00
|
|
|
call term_start(cmd, {'term_rows': 6})
|
|
|
|
let size = term_getsize('')
|
|
|
|
bwipe!
|
|
|
|
call assert_equal(6, size[0])
|
|
|
|
|
2017-08-05 17:13:48 +02:00
|
|
|
vsplit
|
2017-08-20 18:09:14 +02:00
|
|
|
exe 'terminal ++rows=5 ++cols=33 ' . cmd
|
2017-08-05 17:13:48 +02:00
|
|
|
let size = term_getsize('')
|
|
|
|
bwipe!
|
|
|
|
call assert_equal([5, 33], size)
|
|
|
|
|
2017-08-11 21:51:23 +02:00
|
|
|
call term_start(cmd, {'term_rows': 6, 'term_cols': 36})
|
|
|
|
let size = term_getsize('')
|
|
|
|
bwipe!
|
|
|
|
call assert_equal([6, 36], size)
|
|
|
|
|
2017-08-20 18:09:14 +02:00
|
|
|
exe 'vertical terminal ++cols=20 ' . cmd
|
2017-08-05 17:13:48 +02:00
|
|
|
let size = term_getsize('')
|
|
|
|
bwipe!
|
|
|
|
call assert_equal(20, size[1])
|
|
|
|
|
2017-08-11 21:51:23 +02:00
|
|
|
call term_start(cmd, {'vertical': 1, 'term_cols': 26})
|
|
|
|
let size = term_getsize('')
|
|
|
|
bwipe!
|
|
|
|
call assert_equal(26, size[1])
|
|
|
|
|
2017-08-05 17:13:48 +02:00
|
|
|
split
|
2017-08-20 18:09:14 +02:00
|
|
|
exe 'vertical terminal ++rows=6 ++cols=20 ' . cmd
|
2017-08-05 17:13:48 +02:00
|
|
|
let size = term_getsize('')
|
|
|
|
bwipe!
|
|
|
|
call assert_equal([6, 20], size)
|
2017-08-11 21:51:23 +02:00
|
|
|
|
|
|
|
call term_start(cmd, {'vertical': 1, 'term_rows': 7, 'term_cols': 27})
|
|
|
|
let size = term_getsize('')
|
|
|
|
bwipe!
|
|
|
|
call assert_equal([7, 27], size)
|
2017-09-03 19:52:17 +02:00
|
|
|
|
|
|
|
call delete('Xtext')
|
2017-08-11 22:27:50 +02:00
|
|
|
endfunc
|
|
|
|
|
|
|
|
func Test_terminal_curwin()
|
|
|
|
let cmd = Get_cat_123_cmd()
|
|
|
|
call assert_equal(1, winnr('$'))
|
|
|
|
|
|
|
|
split dummy
|
|
|
|
exe 'terminal ++curwin ' . cmd
|
|
|
|
call assert_equal(2, winnr('$'))
|
|
|
|
bwipe!
|
|
|
|
|
|
|
|
split dummy
|
|
|
|
call term_start(cmd, {'curwin': 1})
|
|
|
|
call assert_equal(2, winnr('$'))
|
|
|
|
bwipe!
|
|
|
|
|
|
|
|
split dummy
|
|
|
|
call setline(1, 'change')
|
|
|
|
call assert_fails('terminal ++curwin ' . cmd, 'E37:')
|
|
|
|
call assert_equal(2, winnr('$'))
|
|
|
|
exe 'terminal! ++curwin ' . cmd
|
|
|
|
call assert_equal(2, winnr('$'))
|
|
|
|
bwipe!
|
|
|
|
|
|
|
|
split dummy
|
|
|
|
call setline(1, 'change')
|
|
|
|
call assert_fails("call term_start(cmd, {'curwin': 1})", 'E37:')
|
|
|
|
call assert_equal(2, winnr('$'))
|
|
|
|
bwipe!
|
|
|
|
|
|
|
|
split dummy
|
|
|
|
bwipe!
|
2017-09-03 19:52:17 +02:00
|
|
|
call delete('Xtext')
|
2017-08-05 17:13:48 +02:00
|
|
|
endfunc
|
2017-08-10 23:15:19 +02:00
|
|
|
|
2017-11-21 14:47:57 +01:00
|
|
|
func s:get_sleep_cmd()
|
2017-08-11 22:45:01 +02:00
|
|
|
if s:python != ''
|
|
|
|
let cmd = s:python . " test_short_sleep.py"
|
|
|
|
let waittime = 500
|
2017-08-10 23:15:19 +02:00
|
|
|
else
|
2017-08-11 22:45:01 +02:00
|
|
|
echo 'This will take five seconds...'
|
|
|
|
let waittime = 2000
|
|
|
|
if has('win32')
|
|
|
|
let cmd = $windir . '\system32\timeout.exe 1'
|
|
|
|
else
|
|
|
|
let cmd = 'sleep 1'
|
|
|
|
endif
|
2017-08-10 23:15:19 +02:00
|
|
|
endif
|
2017-11-21 14:47:57 +01:00
|
|
|
return [cmd, waittime]
|
|
|
|
endfunc
|
|
|
|
|
|
|
|
func Test_terminal_finish_open_close()
|
|
|
|
call assert_equal(1, winnr('$'))
|
|
|
|
|
|
|
|
let [cmd, waittime] = s:get_sleep_cmd()
|
2017-08-11 22:45:01 +02:00
|
|
|
|
2017-08-10 23:15:19 +02:00
|
|
|
exe 'terminal ++close ' . cmd
|
|
|
|
call assert_equal(2, winnr('$'))
|
|
|
|
wincmd p
|
2017-08-11 22:45:01 +02:00
|
|
|
call WaitFor("winnr('$') == 1", waittime)
|
2017-08-10 23:15:19 +02:00
|
|
|
|
|
|
|
call term_start(cmd, {'term_finish': 'close'})
|
|
|
|
call assert_equal(2, winnr('$'))
|
|
|
|
wincmd p
|
2017-08-11 22:45:01 +02:00
|
|
|
call WaitFor("winnr('$') == 1", waittime)
|
2017-08-10 23:15:19 +02:00
|
|
|
call assert_equal(1, winnr('$'))
|
|
|
|
|
|
|
|
exe 'terminal ++open ' . cmd
|
2017-08-30 13:31:49 +02:00
|
|
|
close!
|
2017-08-11 22:45:01 +02:00
|
|
|
call WaitFor("winnr('$') == 2", waittime)
|
2017-08-10 23:15:19 +02:00
|
|
|
call assert_equal(2, winnr('$'))
|
|
|
|
bwipe
|
|
|
|
|
|
|
|
call term_start(cmd, {'term_finish': 'open'})
|
2017-08-30 13:31:49 +02:00
|
|
|
close!
|
2017-08-11 22:45:01 +02:00
|
|
|
call WaitFor("winnr('$') == 2", waittime)
|
2017-08-10 23:15:19 +02:00
|
|
|
call assert_equal(2, winnr('$'))
|
2017-08-12 14:32:32 +02:00
|
|
|
bwipe
|
2017-08-10 23:15:19 +02:00
|
|
|
|
2017-08-12 14:32:32 +02:00
|
|
|
exe 'terminal ++hidden ++open ' . cmd
|
|
|
|
call assert_equal(1, winnr('$'))
|
|
|
|
call WaitFor("winnr('$') == 2", waittime)
|
|
|
|
call assert_equal(2, winnr('$'))
|
|
|
|
bwipe
|
|
|
|
|
|
|
|
call term_start(cmd, {'term_finish': 'open', 'hidden': 1})
|
|
|
|
call assert_equal(1, winnr('$'))
|
|
|
|
call WaitFor("winnr('$') == 2", waittime)
|
|
|
|
call assert_equal(2, winnr('$'))
|
2017-08-10 23:15:19 +02:00
|
|
|
bwipe
|
2017-08-12 16:01:04 +02:00
|
|
|
|
|
|
|
call assert_fails("call term_start(cmd, {'term_opencmd': 'open'})", 'E475:')
|
|
|
|
call assert_fails("call term_start(cmd, {'term_opencmd': 'split %x'})", 'E475:')
|
|
|
|
call assert_fails("call term_start(cmd, {'term_opencmd': 'split %d and %s'})", 'E475:')
|
|
|
|
call assert_fails("call term_start(cmd, {'term_opencmd': 'split % and %d'})", 'E475:')
|
|
|
|
|
|
|
|
call term_start(cmd, {'term_finish': 'open', 'term_opencmd': '4split | buffer %d'})
|
2017-08-30 13:31:49 +02:00
|
|
|
close!
|
2017-08-12 16:01:04 +02:00
|
|
|
call WaitFor("winnr('$') == 2", waittime)
|
|
|
|
call assert_equal(2, winnr('$'))
|
|
|
|
call assert_equal(4, winheight(0))
|
|
|
|
bwipe
|
2017-08-10 23:15:19 +02:00
|
|
|
endfunc
|
2017-08-11 19:12:11 +02:00
|
|
|
|
|
|
|
func Test_terminal_cwd()
|
2017-09-10 14:25:49 +02:00
|
|
|
if !executable('pwd')
|
2017-08-11 19:12:11 +02:00
|
|
|
return
|
|
|
|
endif
|
|
|
|
call mkdir('Xdir')
|
|
|
|
let buf = term_start('pwd', {'cwd': 'Xdir'})
|
2017-09-10 14:25:49 +02:00
|
|
|
call WaitFor('"Xdir" == fnamemodify(getline(1), ":t")')
|
|
|
|
call assert_equal('Xdir', fnamemodify(getline(1), ":t"))
|
2017-08-11 19:12:11 +02:00
|
|
|
|
|
|
|
exe buf . 'bwipe'
|
|
|
|
call delete('Xdir', 'rf')
|
|
|
|
endfunc
|
|
|
|
|
2017-11-21 18:11:27 +01:00
|
|
|
func Test_terminal_servername()
|
|
|
|
if !has('clientserver')
|
|
|
|
return
|
|
|
|
endif
|
|
|
|
let g:buf = Run_shell_in_terminal({})
|
|
|
|
" Wait for the shell to display a prompt
|
|
|
|
call WaitFor('term_getline(g:buf, 1) != ""')
|
|
|
|
if has('win32')
|
|
|
|
call term_sendkeys(g:buf, "echo %VIM_SERVERNAME%\r")
|
|
|
|
else
|
|
|
|
call term_sendkeys(g:buf, "echo $VIM_SERVERNAME\r")
|
|
|
|
endif
|
|
|
|
call term_wait(g:buf)
|
|
|
|
call Stop_shell_in_terminal(g:buf)
|
|
|
|
call WaitFor('getline(2) == v:servername')
|
|
|
|
call assert_equal(v:servername, getline(2))
|
|
|
|
|
|
|
|
exe g:buf . 'bwipe'
|
|
|
|
unlet g:buf
|
|
|
|
endfunc
|
|
|
|
|
2017-08-11 19:12:11 +02:00
|
|
|
func Test_terminal_env()
|
2017-08-14 22:01:16 +02:00
|
|
|
let g:buf = Run_shell_in_terminal({'env': {'TESTENV': 'correct'}})
|
2017-08-14 21:45:00 +02:00
|
|
|
" Wait for the shell to display a prompt
|
2017-08-14 22:01:16 +02:00
|
|
|
call WaitFor('term_getline(g:buf, 1) != ""')
|
2017-10-30 21:56:23 +01:00
|
|
|
if has('win32')
|
|
|
|
call term_sendkeys(g:buf, "echo %TESTENV%\r")
|
|
|
|
else
|
|
|
|
call term_sendkeys(g:buf, "echo $TESTENV\r")
|
|
|
|
endif
|
2017-08-14 22:01:16 +02:00
|
|
|
call term_wait(g:buf)
|
|
|
|
call Stop_shell_in_terminal(g:buf)
|
2017-08-14 21:45:00 +02:00
|
|
|
call WaitFor('getline(2) == "correct"')
|
2017-08-11 19:12:11 +02:00
|
|
|
call assert_equal('correct', getline(2))
|
|
|
|
|
2017-08-14 22:01:16 +02:00
|
|
|
exe g:buf . 'bwipe'
|
|
|
|
unlet g:buf
|
2017-08-11 19:12:11 +02:00
|
|
|
endfunc
|
2017-08-13 14:13:19 +02:00
|
|
|
|
|
|
|
" must be last, we can't go back from GUI to terminal
|
|
|
|
func Test_zz_terminal_in_gui()
|
2017-08-13 20:26:20 +02:00
|
|
|
if !CanRunGui()
|
2017-08-13 14:13:19 +02:00
|
|
|
return
|
|
|
|
endif
|
2017-08-29 20:42:07 +02:00
|
|
|
|
|
|
|
" Ignore the "failed to create input context" error.
|
|
|
|
call test_ignore_error('E285:')
|
|
|
|
|
2017-08-13 14:13:19 +02:00
|
|
|
gui -f
|
|
|
|
|
|
|
|
call assert_equal(1, winnr('$'))
|
|
|
|
let buf = Run_shell_in_terminal({'term_finish': 'close'})
|
|
|
|
call Stop_shell_in_terminal(buf)
|
|
|
|
call term_wait(buf)
|
|
|
|
|
|
|
|
" closing window wipes out the terminal buffer a with finished job
|
|
|
|
call WaitFor("winnr('$') == 1")
|
|
|
|
call assert_equal(1, winnr('$'))
|
|
|
|
call assert_equal("", bufname(buf))
|
|
|
|
|
|
|
|
unlet g:job
|
|
|
|
endfunc
|
2017-08-13 17:13:09 +02:00
|
|
|
|
|
|
|
func Test_terminal_list_args()
|
|
|
|
let buf = term_start([&shell, &shellcmdflag, 'echo "123"'])
|
|
|
|
call assert_fails(buf . 'bwipe', 'E517')
|
|
|
|
exe buf . 'bwipe!'
|
|
|
|
call assert_equal("", bufname(buf))
|
|
|
|
endfunction
|
2017-08-18 20:50:30 +02:00
|
|
|
|
|
|
|
func Test_terminal_noblock()
|
2017-11-04 19:24:31 +01:00
|
|
|
let buf = term_start(&shell)
|
2017-09-03 18:08:00 +02:00
|
|
|
if has('mac')
|
|
|
|
" The shell or something else has a problem dealing with more than 1000
|
|
|
|
" characters at the same time.
|
|
|
|
let len = 1000
|
|
|
|
else
|
|
|
|
let len = 5000
|
|
|
|
endif
|
2017-08-18 20:50:30 +02:00
|
|
|
|
|
|
|
for c in ['a','b','c','d','e','f','g','h','i','j','k']
|
2017-11-04 19:24:31 +01:00
|
|
|
call term_sendkeys(buf, 'echo ' . repeat(c, len) . "\<cr>")
|
2017-08-18 20:50:30 +02:00
|
|
|
endfor
|
2017-11-04 19:24:31 +01:00
|
|
|
call term_sendkeys(buf, "echo done\<cr>")
|
2017-08-20 20:21:23 +02:00
|
|
|
|
|
|
|
" On MS-Windows there is an extra empty line below "done". Find "done" in
|
|
|
|
" the last-but-one or the last-but-two line.
|
2017-11-04 19:24:31 +01:00
|
|
|
let lnum = term_getsize(buf)[0] - 1
|
2018-02-02 18:30:36 +01:00
|
|
|
call WaitFor({-> term_getline(buf, lnum) =~ "done" || term_getline(buf, lnum - 1) =~ "done"}, 10000)
|
2017-11-04 19:24:31 +01:00
|
|
|
let line = term_getline(buf, lnum)
|
2017-08-20 20:21:23 +02:00
|
|
|
if line !~ 'done'
|
2017-11-04 19:24:31 +01:00
|
|
|
let line = term_getline(buf, lnum - 1)
|
2017-08-20 20:21:23 +02:00
|
|
|
endif
|
|
|
|
call assert_match('done', line)
|
2017-08-18 20:50:30 +02:00
|
|
|
|
2017-11-04 19:24:31 +01:00
|
|
|
let g:job = term_getjob(buf)
|
|
|
|
call Stop_shell_in_terminal(buf)
|
|
|
|
call term_wait(buf)
|
2017-08-19 15:40:01 +02:00
|
|
|
unlet g:job
|
2017-08-18 20:50:30 +02:00
|
|
|
bwipe
|
|
|
|
endfunc
|
2017-08-20 19:33:47 +02:00
|
|
|
|
|
|
|
func Test_terminal_write_stdin()
|
2017-09-02 14:54:21 +02:00
|
|
|
if !executable('wc')
|
2017-09-02 17:18:35 +02:00
|
|
|
throw 'skipped: wc command not available'
|
2017-08-20 19:33:47 +02:00
|
|
|
endif
|
|
|
|
new
|
|
|
|
call setline(1, ['one', 'two', 'three'])
|
|
|
|
%term wc
|
2017-09-02 17:18:35 +02:00
|
|
|
call WaitFor('getline("$") =~ "3"')
|
2017-09-02 14:54:21 +02:00
|
|
|
let nrs = split(getline('$'))
|
2017-08-20 19:33:47 +02:00
|
|
|
call assert_equal(['3', '3', '14'], nrs)
|
|
|
|
bwipe
|
|
|
|
|
2017-09-02 17:18:35 +02:00
|
|
|
new
|
2017-08-20 19:33:47 +02:00
|
|
|
call setline(1, ['one', 'two', 'three', 'four'])
|
|
|
|
2,3term wc
|
2017-09-02 17:18:35 +02:00
|
|
|
call WaitFor('getline("$") =~ "2"')
|
2017-09-02 14:54:21 +02:00
|
|
|
let nrs = split(getline('$'))
|
2017-08-20 19:33:47 +02:00
|
|
|
call assert_equal(['2', '2', '10'], nrs)
|
|
|
|
bwipe
|
|
|
|
|
2017-09-02 17:18:35 +02:00
|
|
|
if executable('python')
|
|
|
|
new
|
|
|
|
call setline(1, ['print("hello")'])
|
|
|
|
1term ++eof=exit() python
|
|
|
|
" MS-Windows echoes the input, Unix doesn't.
|
|
|
|
call WaitFor('getline("$") =~ "exit" || getline(1) =~ "hello"')
|
|
|
|
if getline(1) =~ 'hello'
|
|
|
|
call assert_equal('hello', getline(1))
|
|
|
|
else
|
|
|
|
call assert_equal('hello', getline(line('$') - 1))
|
|
|
|
endif
|
|
|
|
bwipe
|
|
|
|
|
|
|
|
if has('win32')
|
|
|
|
new
|
|
|
|
call setline(1, ['print("hello")'])
|
|
|
|
1term ++eof=<C-Z> python
|
|
|
|
call WaitFor('getline("$") =~ "Z"')
|
|
|
|
call assert_equal('hello', getline(line('$') - 1))
|
|
|
|
bwipe
|
|
|
|
endif
|
|
|
|
endif
|
|
|
|
|
2017-08-20 19:33:47 +02:00
|
|
|
bwipe!
|
|
|
|
endfunc
|
2017-08-26 22:02:51 +02:00
|
|
|
|
|
|
|
func Test_terminal_no_cmd()
|
|
|
|
" Todo: make this work in the GUI
|
|
|
|
if !has('gui_running')
|
|
|
|
return
|
|
|
|
endif
|
|
|
|
let buf = term_start('NONE', {})
|
|
|
|
call assert_notequal(0, buf)
|
|
|
|
|
2017-09-08 14:39:30 +02:00
|
|
|
let pty = job_info(term_getjob(buf))['tty_out']
|
2017-08-26 22:02:51 +02:00
|
|
|
call assert_notequal('', pty)
|
2017-09-08 14:39:30 +02:00
|
|
|
if has('win32')
|
2017-09-16 17:42:41 +02:00
|
|
|
silent exe '!start cmd /c "echo look here > ' . pty . '"'
|
2017-09-08 14:39:30 +02:00
|
|
|
else
|
|
|
|
call system('echo "look here" > ' . pty)
|
|
|
|
endif
|
2017-09-16 17:42:41 +02:00
|
|
|
let g:buf = buf
|
|
|
|
call WaitFor('term_getline(g:buf, 1) =~ "look here"')
|
2017-09-08 14:39:30 +02:00
|
|
|
|
2017-09-16 17:42:41 +02:00
|
|
|
call assert_match('look here', term_getline(buf, 1))
|
2017-08-26 22:02:51 +02:00
|
|
|
bwipe!
|
|
|
|
endfunc
|
2017-09-03 19:52:17 +02:00
|
|
|
|
|
|
|
func Test_terminal_special_chars()
|
|
|
|
" this file name only works on Unix
|
|
|
|
if !has('unix')
|
|
|
|
return
|
|
|
|
endif
|
|
|
|
call mkdir('Xdir with spaces')
|
|
|
|
call writefile(['x'], 'Xdir with spaces/quoted"file')
|
|
|
|
term ls Xdir\ with\ spaces/quoted\"file
|
|
|
|
call WaitFor('term_getline("", 1) =~ "quoted"')
|
|
|
|
call assert_match('quoted"file', term_getline('', 1))
|
|
|
|
call term_wait('')
|
|
|
|
|
|
|
|
call delete('Xdir with spaces', 'rf')
|
|
|
|
bwipe
|
|
|
|
endfunc
|
2017-09-03 20:59:40 +02:00
|
|
|
|
|
|
|
func Test_terminal_wrong_options()
|
|
|
|
call assert_fails('call term_start(&shell, {
|
|
|
|
\ "in_io": "file",
|
|
|
|
\ "in_name": "xxx",
|
|
|
|
\ "out_io": "file",
|
|
|
|
\ "out_name": "xxx",
|
|
|
|
\ "err_io": "file",
|
|
|
|
\ "err_name": "xxx"
|
|
|
|
\ })', 'E474:')
|
|
|
|
call assert_fails('call term_start(&shell, {
|
|
|
|
\ "out_buf": bufnr("%")
|
|
|
|
\ })', 'E474:')
|
|
|
|
call assert_fails('call term_start(&shell, {
|
|
|
|
\ "err_buf": bufnr("%")
|
|
|
|
\ })', 'E474:')
|
|
|
|
endfunc
|
|
|
|
|
|
|
|
func Test_terminal_redir_file()
|
2017-09-04 22:23:19 +02:00
|
|
|
" TODO: this should work on MS-Window
|
|
|
|
if has('unix')
|
|
|
|
let cmd = Get_cat_123_cmd()
|
|
|
|
let buf = term_start(cmd, {'out_io': 'file', 'out_name': 'Xfile'})
|
|
|
|
call term_wait(buf)
|
|
|
|
call WaitFor('len(readfile("Xfile")) > 0')
|
|
|
|
call assert_match('123', readfile('Xfile')[0])
|
2017-09-10 14:25:49 +02:00
|
|
|
let g:job = term_getjob(buf)
|
|
|
|
call WaitFor('job_status(g:job) == "dead"')
|
2017-09-04 22:23:19 +02:00
|
|
|
call delete('Xfile')
|
2017-09-08 14:39:30 +02:00
|
|
|
bwipe
|
2017-09-04 22:23:19 +02:00
|
|
|
endif
|
2017-09-03 20:59:40 +02:00
|
|
|
|
|
|
|
if has('unix')
|
|
|
|
call writefile(['one line'], 'Xfile')
|
|
|
|
let buf = term_start('cat', {'in_io': 'file', 'in_name': 'Xfile'})
|
|
|
|
call term_wait(buf)
|
|
|
|
call WaitFor('term_getline(' . buf . ', 1) == "one line"')
|
|
|
|
call assert_equal('one line', term_getline(buf, 1))
|
2017-09-05 20:29:25 +02:00
|
|
|
let g:job = term_getjob(buf)
|
|
|
|
call WaitFor('job_status(g:job) == "dead"')
|
2017-09-03 20:59:40 +02:00
|
|
|
bwipe
|
|
|
|
call delete('Xfile')
|
|
|
|
endif
|
|
|
|
endfunc
|
2017-09-14 20:37:57 +02:00
|
|
|
|
|
|
|
func TerminalTmap(remap)
|
|
|
|
let buf = Run_shell_in_terminal({})
|
|
|
|
call assert_equal('t', mode())
|
|
|
|
|
|
|
|
if a:remap
|
|
|
|
tmap 123 456
|
|
|
|
else
|
|
|
|
tnoremap 123 456
|
|
|
|
endif
|
2017-12-05 12:30:03 +01:00
|
|
|
" don't use abcde, it's an existing command
|
|
|
|
tmap 456 abxde
|
2017-09-14 20:37:57 +02:00
|
|
|
call assert_equal('456', maparg('123', 't'))
|
2017-12-05 12:30:03 +01:00
|
|
|
call assert_equal('abxde', maparg('456', 't'))
|
2017-09-14 20:37:57 +02:00
|
|
|
call feedkeys("123", 'tx')
|
2017-09-16 17:35:13 +02:00
|
|
|
let g:buf = buf
|
2017-12-05 12:30:03 +01:00
|
|
|
call WaitFor("term_getline(g:buf,term_getcursor(g:buf)[0]) =~ 'abxde\\|456'")
|
2017-09-14 20:37:57 +02:00
|
|
|
let lnum = term_getcursor(buf)[0]
|
|
|
|
if a:remap
|
2017-12-05 12:30:03 +01:00
|
|
|
call assert_match('abxde', term_getline(buf, lnum))
|
2017-09-14 20:37:57 +02:00
|
|
|
else
|
|
|
|
call assert_match('456', term_getline(buf, lnum))
|
|
|
|
endif
|
|
|
|
|
|
|
|
call term_sendkeys(buf, "\r")
|
|
|
|
call Stop_shell_in_terminal(buf)
|
|
|
|
call term_wait(buf)
|
|
|
|
|
|
|
|
tunmap 123
|
|
|
|
tunmap 456
|
|
|
|
call assert_equal('', maparg('123', 't'))
|
|
|
|
close
|
|
|
|
unlet g:job
|
|
|
|
endfunc
|
|
|
|
|
|
|
|
func Test_terminal_tmap()
|
|
|
|
call TerminalTmap(1)
|
|
|
|
call TerminalTmap(0)
|
|
|
|
endfunc
|
2017-10-15 22:42:23 +02:00
|
|
|
|
|
|
|
func Test_terminal_wall()
|
|
|
|
let buf = Run_shell_in_terminal({})
|
|
|
|
wall
|
|
|
|
call Stop_shell_in_terminal(buf)
|
|
|
|
call term_wait(buf)
|
|
|
|
exe buf . 'bwipe'
|
|
|
|
unlet g:job
|
|
|
|
endfunc
|
2017-10-15 22:56:49 +02:00
|
|
|
|
2018-02-19 23:10:02 +01:00
|
|
|
func Test_terminal_wqall()
|
|
|
|
let buf = Run_shell_in_terminal({})
|
|
|
|
call assert_fails('wqall', 'E948')
|
|
|
|
call Stop_shell_in_terminal(buf)
|
|
|
|
call term_wait(buf)
|
|
|
|
exe buf . 'bwipe'
|
|
|
|
unlet g:job
|
|
|
|
endfunc
|
|
|
|
|
2017-10-15 22:56:49 +02:00
|
|
|
func Test_terminal_composing_unicode()
|
|
|
|
let save_enc = &encoding
|
|
|
|
set encoding=utf-8
|
|
|
|
|
|
|
|
if has('win32')
|
|
|
|
let cmd = "cmd /K chcp 65001"
|
|
|
|
let lnum = [3, 6, 9]
|
|
|
|
else
|
|
|
|
let cmd = &shell
|
|
|
|
let lnum = [1, 3, 5]
|
|
|
|
endif
|
|
|
|
|
|
|
|
enew
|
|
|
|
let buf = term_start(cmd, {'curwin': bufnr('')})
|
2017-11-02 16:58:00 +01:00
|
|
|
let g:job = term_getjob(buf)
|
2017-10-15 22:56:49 +02:00
|
|
|
call term_wait(buf, 50)
|
|
|
|
|
|
|
|
" ascii + composing
|
|
|
|
let txt = "a\u0308bc"
|
|
|
|
call term_sendkeys(buf, "echo " . txt . "\r")
|
|
|
|
call term_wait(buf, 50)
|
|
|
|
call assert_match("echo " . txt, term_getline(buf, lnum[0]))
|
|
|
|
call assert_equal(txt, term_getline(buf, lnum[0] + 1))
|
|
|
|
let l = term_scrape(buf, lnum[0] + 1)
|
|
|
|
call assert_equal("a\u0308", l[0].chars)
|
|
|
|
call assert_equal("b", l[1].chars)
|
|
|
|
call assert_equal("c", l[2].chars)
|
|
|
|
|
|
|
|
" multibyte + composing
|
|
|
|
let txt = "\u304b\u3099\u304e\u304f\u3099\u3052\u3053\u3099"
|
|
|
|
call term_sendkeys(buf, "echo " . txt . "\r")
|
|
|
|
call term_wait(buf, 50)
|
|
|
|
call assert_match("echo " . txt, term_getline(buf, lnum[1]))
|
|
|
|
call assert_equal(txt, term_getline(buf, lnum[1] + 1))
|
|
|
|
let l = term_scrape(buf, lnum[1] + 1)
|
|
|
|
call assert_equal("\u304b\u3099", l[0].chars)
|
|
|
|
call assert_equal("\u304e", l[1].chars)
|
|
|
|
call assert_equal("\u304f\u3099", l[2].chars)
|
|
|
|
call assert_equal("\u3052", l[3].chars)
|
|
|
|
call assert_equal("\u3053\u3099", l[4].chars)
|
|
|
|
|
|
|
|
" \u00a0 + composing
|
|
|
|
let txt = "abc\u00a0\u0308"
|
|
|
|
call term_sendkeys(buf, "echo " . txt . "\r")
|
|
|
|
call term_wait(buf, 50)
|
|
|
|
call assert_match("echo " . txt, term_getline(buf, lnum[2]))
|
|
|
|
call assert_equal(txt, term_getline(buf, lnum[2] + 1))
|
|
|
|
let l = term_scrape(buf, lnum[2] + 1)
|
|
|
|
call assert_equal("\u00a0\u0308", l[3].chars)
|
|
|
|
|
|
|
|
call term_sendkeys(buf, "exit\r")
|
2017-11-02 16:58:00 +01:00
|
|
|
call WaitFor('job_status(g:job) == "dead"')
|
|
|
|
call assert_equal('dead', job_status(g:job))
|
2017-10-15 22:56:49 +02:00
|
|
|
bwipe!
|
2017-11-02 16:58:00 +01:00
|
|
|
unlet g:job
|
2017-10-15 22:56:49 +02:00
|
|
|
let &encoding = save_enc
|
|
|
|
endfunc
|
2017-11-21 14:47:57 +01:00
|
|
|
|
|
|
|
func Test_terminal_aucmd_on_close()
|
|
|
|
fun Nop()
|
|
|
|
let s:called = 1
|
|
|
|
endfun
|
|
|
|
|
|
|
|
aug repro
|
|
|
|
au!
|
|
|
|
au BufWinLeave * call Nop()
|
|
|
|
aug END
|
|
|
|
|
|
|
|
let [cmd, waittime] = s:get_sleep_cmd()
|
|
|
|
|
|
|
|
call assert_equal(1, winnr('$'))
|
|
|
|
new
|
|
|
|
call setline(1, ['one', 'two'])
|
|
|
|
exe 'term ++close ' . cmd
|
|
|
|
wincmd p
|
|
|
|
call WaitFor("winnr('$') == 2", waittime)
|
|
|
|
call assert_equal(1, s:called)
|
|
|
|
bwipe!
|
|
|
|
|
|
|
|
unlet s:called
|
|
|
|
au! repro
|
|
|
|
delfunc Nop
|
|
|
|
endfunc
|
2018-01-26 20:05:18 +01:00
|
|
|
|
|
|
|
func Test_terminal_term_start_empty_command()
|
|
|
|
let cmd = "call term_start('', {'curwin' : 1, 'term_finish' : 'close'})"
|
|
|
|
call assert_fails(cmd, 'E474')
|
|
|
|
let cmd = "call term_start('', {'curwin' : 1, 'term_finish' : 'close'})"
|
|
|
|
call assert_fails(cmd, 'E474')
|
|
|
|
let cmd = "call term_start({}, {'curwin' : 1, 'term_finish' : 'close'})"
|
|
|
|
call assert_fails(cmd, 'E474')
|
|
|
|
let cmd = "call term_start(0, {'curwin' : 1, 'term_finish' : 'close'})"
|
|
|
|
call assert_fails(cmd, 'E474')
|
|
|
|
endfunc
|
2018-01-30 22:31:19 +01:00
|
|
|
|
|
|
|
func Test_terminal_response_to_control_sequence()
|
|
|
|
if !has('unix')
|
|
|
|
return
|
|
|
|
endif
|
|
|
|
|
|
|
|
let buf = Run_shell_in_terminal({})
|
|
|
|
call term_wait(buf)
|
|
|
|
|
2018-02-02 18:22:31 +01:00
|
|
|
new
|
|
|
|
call setline(1, "\x1b[6n")
|
|
|
|
write! Xescape
|
|
|
|
bwipe
|
|
|
|
call term_sendkeys(buf, "cat Xescape\<cr>")
|
|
|
|
|
2018-01-30 22:31:19 +01:00
|
|
|
" wait for the response of control sequence from libvterm (and send it to tty)
|
2018-02-02 18:22:31 +01:00
|
|
|
sleep 200m
|
2018-01-30 22:31:19 +01:00
|
|
|
call term_wait(buf)
|
2018-02-02 18:22:31 +01:00
|
|
|
|
|
|
|
" Wait for output from tty to display, below an empty line.
|
|
|
|
" It should show \e3;1R, but only 1R may show up
|
|
|
|
call assert_match('\<\d\+R', term_getline(buf, 3))
|
2018-01-30 22:31:19 +01:00
|
|
|
|
|
|
|
call term_sendkeys(buf, "\<c-c>")
|
|
|
|
call term_wait(buf)
|
|
|
|
call Stop_shell_in_terminal(buf)
|
|
|
|
|
|
|
|
exe buf . 'bwipe'
|
2018-02-02 18:22:31 +01:00
|
|
|
call delete('Xescape')
|
2018-01-30 22:31:19 +01:00
|
|
|
unlet g:job
|
|
|
|
endfunc
|
2018-03-10 20:28:12 +01:00
|
|
|
|
|
|
|
" Run Vim in a terminal, then start a terminal in that Vim with a kill
|
|
|
|
" argument, check that :qall works.
|
|
|
|
func Test_terminal_qall_kill_arg()
|
|
|
|
if !CanRunVimInTerminal()
|
|
|
|
return
|
|
|
|
endif
|
|
|
|
let buf = RunVimInTerminal('', {})
|
|
|
|
|
|
|
|
" Open a terminal window and wait for the prompt to appear
|
|
|
|
call term_sendkeys(buf, ":term ++kill=kill\<CR>")
|
|
|
|
call WaitFor({-> term_getline(buf, 10) =~ '\[running]'})
|
|
|
|
call WaitFor({-> term_getline(buf, 1) !~ '^\s*$'})
|
|
|
|
|
|
|
|
" make Vim exit, it will kill the shell
|
|
|
|
call term_sendkeys(buf, "\<C-W>:qall\<CR>")
|
|
|
|
call WaitFor({-> term_getstatus(buf) == "finished"})
|
|
|
|
|
|
|
|
" close the terminal window where Vim was running
|
|
|
|
quit
|
|
|
|
endfunc
|
|
|
|
|
|
|
|
" Run Vim in a terminal, then start a terminal in that Vim with a kill
|
|
|
|
" argument, check that :qall works.
|
|
|
|
func Test_terminal_qall_kill_func()
|
|
|
|
if !CanRunVimInTerminal()
|
|
|
|
return
|
|
|
|
endif
|
|
|
|
let buf = RunVimInTerminal('', {})
|
|
|
|
|
|
|
|
" Open a terminal window and wait for the prompt to appear
|
|
|
|
call term_sendkeys(buf, ":term\<CR>")
|
|
|
|
call WaitFor({-> term_getline(buf, 10) =~ '\[running]'})
|
|
|
|
call WaitFor({-> term_getline(buf, 1) !~ '^\s*$'})
|
|
|
|
|
|
|
|
" set kill using term_setkill()
|
|
|
|
call term_sendkeys(buf, "\<C-W>:call term_setkill(bufnr('%'), 'kill')\<CR>")
|
|
|
|
|
|
|
|
" make Vim exit, it will kill the shell
|
|
|
|
call term_sendkeys(buf, "\<C-W>:qall\<CR>")
|
|
|
|
call WaitFor({-> term_getstatus(buf) == "finished"})
|
|
|
|
|
|
|
|
" close the terminal window where Vim was running
|
|
|
|
quit
|
|
|
|
endfunc
|
2018-03-10 20:51:25 +01:00
|
|
|
|
|
|
|
" Run Vim in a terminal, then start a terminal in that Vim without a kill
|
|
|
|
" argument, check that :confirm qall works.
|
|
|
|
func Test_terminal_qall_prompt()
|
|
|
|
if !CanRunVimInTerminal()
|
|
|
|
return
|
|
|
|
endif
|
|
|
|
let buf = RunVimInTerminal('', {})
|
|
|
|
|
|
|
|
" Open a terminal window and wait for the prompt to appear
|
|
|
|
call term_sendkeys(buf, ":term\<CR>")
|
|
|
|
call WaitFor({-> term_getline(buf, 10) =~ '\[running]'})
|
|
|
|
call WaitFor({-> term_getline(buf, 1) !~ '^\s*$'})
|
|
|
|
|
|
|
|
" make Vim exit, it will prompt to kill the shell
|
|
|
|
call term_sendkeys(buf, "\<C-W>:confirm qall\<CR>")
|
|
|
|
call WaitFor({-> term_getline(buf, 20) =~ 'ancel:'})
|
|
|
|
call term_sendkeys(buf, "y")
|
|
|
|
call WaitFor({-> term_getstatus(buf) == "finished"})
|
|
|
|
|
|
|
|
" close the terminal window where Vim was running
|
|
|
|
quit
|
|
|
|
endfunc
|
2018-03-11 16:55:36 +01:00
|
|
|
|
|
|
|
func Test_terminalopen_autocmd()
|
|
|
|
augroup repro
|
|
|
|
au!
|
|
|
|
au TerminalOpen * let s:called += 1
|
|
|
|
augroup END
|
|
|
|
|
|
|
|
let s:called = 0
|
|
|
|
|
|
|
|
" Open a terminal window with :terminal
|
|
|
|
terminal
|
|
|
|
call assert_equal(1, s:called)
|
|
|
|
bwipe!
|
|
|
|
|
|
|
|
" Open a terminal window with term_start()
|
|
|
|
call term_start(&shell)
|
|
|
|
call assert_equal(2, s:called)
|
|
|
|
bwipe!
|
|
|
|
|
|
|
|
" Open a hidden terminal buffer with :terminal
|
|
|
|
terminal ++hidden
|
|
|
|
call assert_equal(3, s:called)
|
|
|
|
for buf in term_list()
|
|
|
|
exe buf . "bwipe!"
|
|
|
|
endfor
|
|
|
|
|
|
|
|
" Open a hidden terminal buffer with term_start()
|
|
|
|
let buf = term_start(&shell, {'hidden': 1})
|
|
|
|
call assert_equal(4, s:called)
|
|
|
|
exe buf . "bwipe!"
|
|
|
|
|
|
|
|
unlet s:called
|
|
|
|
au! repro
|
|
|
|
endfunction
|