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'))
|
2018-03-29 16:37:16 +02:00
|
|
|
call assert_match('%aR[^\n]*running]', execute('ls R'))
|
|
|
|
call assert_notmatch('%[^\n]*running]', execute('ls F'))
|
|
|
|
call assert_notmatch('%[^\n]*running]', execute('ls ?'))
|
2017-08-13 20:58:33 +02:00
|
|
|
|
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'))
|
2018-03-29 16:37:16 +02:00
|
|
|
call assert_match('%aF[^\n]*finished]', execute('ls F'))
|
|
|
|
call assert_notmatch('%[^\n]*finished]', execute('ls R'))
|
|
|
|
call assert_notmatch('%[^\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
|
|
|
|
|
2018-04-14 21:31:35 +02:00
|
|
|
func Test_terminal_scrollback()
|
|
|
|
let buf = Run_shell_in_terminal({})
|
|
|
|
set terminalscroll=100
|
|
|
|
call writefile(range(150), 'Xtext')
|
|
|
|
if has('win32')
|
|
|
|
call term_sendkeys(buf, "type Xtext\<CR>")
|
|
|
|
else
|
|
|
|
call term_sendkeys(buf, "cat Xtext\<CR>")
|
|
|
|
endif
|
|
|
|
let rows = term_getsize(buf)[0]
|
2018-04-15 13:28:42 +02:00
|
|
|
" On MS-Windows there is an empty line, check both last line and above it.
|
|
|
|
call WaitFor({-> term_getline(buf, rows - 1) . term_getline(buf, rows - 2) =~ '149'})
|
2018-04-14 21:31:35 +02:00
|
|
|
let lines = line('$')
|
2018-04-15 13:10:44 +02:00
|
|
|
call assert_inrange(91, 100, lines)
|
2018-04-14 21:31:35 +02:00
|
|
|
|
|
|
|
call Stop_shell_in_terminal(buf)
|
|
|
|
call term_wait(buf)
|
|
|
|
exe buf . 'bwipe'
|
|
|
|
set terminalscroll&
|
|
|
|
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
|
2018-04-14 17:05:38 +02:00
|
|
|
call assert_equal([5, 33], term_getsize(''))
|
|
|
|
|
|
|
|
call term_setsize('', 6, 0)
|
|
|
|
call assert_equal([6, 33], term_getsize(''))
|
|
|
|
|
|
|
|
call term_setsize('', 0, 35)
|
|
|
|
call assert_equal([6, 35], term_getsize(''))
|
|
|
|
|
|
|
|
call term_setsize('', 7, 30)
|
|
|
|
call assert_equal([7, 30], term_getsize(''))
|
|
|
|
|
2017-08-05 17:13:48 +02:00
|
|
|
bwipe!
|
2018-04-14 21:31:35 +02:00
|
|
|
call assert_fails("call term_setsize('', 7, 30)", "E955:")
|
2017-08-05 17:13:48 +02:00
|
|
|
|
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
|
|
|
|
2018-03-16 22:54:53 +01:00
|
|
|
" shell terminal closes automatically
|
|
|
|
terminal
|
|
|
|
let buf = bufnr('%')
|
|
|
|
call assert_equal(2, winnr('$'))
|
|
|
|
" Wait for the shell to display a prompt
|
|
|
|
call WaitFor({-> term_getline(buf, 1) != ""})
|
|
|
|
call Stop_shell_in_terminal(buf)
|
|
|
|
call WaitFor("winnr('$') == 1", waittime)
|
|
|
|
|
|
|
|
" shell terminal that does not close automatically
|
|
|
|
terminal ++noclose
|
|
|
|
let buf = bufnr('%')
|
|
|
|
call assert_equal(2, winnr('$'))
|
|
|
|
" Wait for the shell to display a prompt
|
|
|
|
call WaitFor({-> term_getline(buf, 1) != ""})
|
|
|
|
call Stop_shell_in_terminal(buf)
|
|
|
|
call assert_equal(2, winnr('$'))
|
|
|
|
quit
|
|
|
|
call assert_equal(1, winnr('$'))
|
|
|
|
|
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
|
2018-03-13 17:55:27 +01:00
|
|
|
let buf = Run_shell_in_terminal({})
|
2017-11-21 18:11:27 +01:00
|
|
|
" Wait for the shell to display a prompt
|
2018-03-13 17:55:27 +01:00
|
|
|
call WaitFor({-> term_getline(buf, 1) != ""})
|
2017-11-21 18:11:27 +01:00
|
|
|
if has('win32')
|
2018-03-13 17:55:27 +01:00
|
|
|
call term_sendkeys(buf, "echo %VIM_SERVERNAME%\r")
|
2017-11-21 18:11:27 +01:00
|
|
|
else
|
2018-03-13 17:55:27 +01:00
|
|
|
call term_sendkeys(buf, "echo $VIM_SERVERNAME\r")
|
2017-11-21 18:11:27 +01:00
|
|
|
endif
|
2018-03-13 17:55:27 +01:00
|
|
|
call term_wait(buf)
|
|
|
|
call Stop_shell_in_terminal(buf)
|
2017-11-21 18:11:27 +01:00
|
|
|
call WaitFor('getline(2) == v:servername')
|
|
|
|
call assert_equal(v:servername, getline(2))
|
|
|
|
|
2018-03-13 17:55:27 +01:00
|
|
|
exe buf . 'bwipe'
|
|
|
|
unlet buf
|
2017-11-21 18:11:27 +01:00
|
|
|
endfunc
|
|
|
|
|
2017-08-11 19:12:11 +02:00
|
|
|
func Test_terminal_env()
|
2018-03-13 17:55:27 +01:00
|
|
|
let buf = Run_shell_in_terminal({'env': {'TESTENV': 'correct'}})
|
2017-08-14 21:45:00 +02:00
|
|
|
" Wait for the shell to display a prompt
|
2018-03-13 17:55:27 +01:00
|
|
|
call WaitFor({-> term_getline(buf, 1) != ""})
|
2017-10-30 21:56:23 +01:00
|
|
|
if has('win32')
|
2018-03-13 17:55:27 +01:00
|
|
|
call term_sendkeys(buf, "echo %TESTENV%\r")
|
2017-10-30 21:56:23 +01:00
|
|
|
else
|
2018-03-13 17:55:27 +01:00
|
|
|
call term_sendkeys(buf, "echo $TESTENV\r")
|
2017-10-30 21:56:23 +01:00
|
|
|
endif
|
2018-03-13 17:55:27 +01:00
|
|
|
call term_wait(buf)
|
|
|
|
call Stop_shell_in_terminal(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))
|
|
|
|
|
2018-03-13 17:55:27 +01:00
|
|
|
exe buf . 'bwipe'
|
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
|
2018-03-13 17:55:27 +01:00
|
|
|
call WaitFor({-> term_getline(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')
|
2018-03-13 17:55:27 +01:00
|
|
|
call WaitFor({-> term_getline(buf, term_getcursor(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({})
|
2018-03-25 21:24:12 +02:00
|
|
|
call WaitFor({-> term_getline(buf, 1) != ''})
|
2018-01-30 22:31:19 +01:00
|
|
|
|
2018-03-25 21:24:12 +02:00
|
|
|
call term_sendkeys(buf, "cat\<CR>")
|
|
|
|
call WaitFor({-> term_getline(buf, 1) =~ 'cat'})
|
2018-02-02 18:22:31 +01:00
|
|
|
|
2018-03-25 21:24:12 +02:00
|
|
|
" Request the cursor position.
|
|
|
|
call term_sendkeys(buf, "\x1b[6n\<CR>")
|
2018-02-02 18:22:31 +01:00
|
|
|
|
|
|
|
" Wait for output from tty to display, below an empty line.
|
2018-03-25 21:24:12 +02:00
|
|
|
call WaitFor({-> term_getline(buf, 4) =~ '3;1R'})
|
2018-01-30 22:31:19 +01:00
|
|
|
|
2018-03-25 21:24:12 +02:00
|
|
|
" End "cat" gently.
|
|
|
|
call term_sendkeys(buf, "\<CR>\<C-D>")
|
2018-01-30 22:31:19 +01:00
|
|
|
|
2018-03-25 21:24:12 +02:00
|
|
|
call Stop_shell_in_terminal(buf)
|
2018-01-30 22:31:19 +01:00
|
|
|
exe buf . 'bwipe'
|
|
|
|
unlet g:job
|
|
|
|
endfunc
|
2018-03-10 20:28:12 +01:00
|
|
|
|
2018-03-20 17:43:01 +01:00
|
|
|
" Run Vim, start a terminal in that Vim with the kill argument,
|
|
|
|
" :qall works.
|
|
|
|
func Run_terminal_qall_kill(line1, line2)
|
|
|
|
" 1. Open a terminal window and wait for the prompt to appear
|
|
|
|
" 2. set kill using term_setkill()
|
|
|
|
" 3. make Vim exit, it will kill the shell
|
|
|
|
let after = [
|
|
|
|
\ a:line1,
|
|
|
|
\ 'let buf = bufnr("%")',
|
|
|
|
\ 'while term_getline(buf, 1) =~ "^\\s*$"',
|
|
|
|
\ ' sleep 10m',
|
|
|
|
\ 'endwhile',
|
|
|
|
\ a:line2,
|
|
|
|
\ 'au VimLeavePre * call writefile(["done"], "Xdone")',
|
|
|
|
\ 'qall',
|
|
|
|
\ ]
|
|
|
|
if !RunVim([], after, '')
|
2018-03-10 20:28:12 +01:00
|
|
|
return
|
|
|
|
endif
|
2018-03-20 17:43:01 +01:00
|
|
|
call assert_equal("done", readfile("Xdone")[0])
|
|
|
|
call delete("Xdone")
|
2018-03-10 20:28:12 +01:00
|
|
|
endfunc
|
|
|
|
|
|
|
|
" Run Vim in a terminal, then start a terminal in that Vim with a kill
|
|
|
|
" argument, check that :qall works.
|
2018-03-20 17:43:01 +01:00
|
|
|
func Test_terminal_qall_kill_arg()
|
|
|
|
call Run_terminal_qall_kill('term ++kill=kill', '')
|
|
|
|
endfunc
|
|
|
|
|
|
|
|
" Run Vim, start a terminal in that Vim, set the kill argument with
|
|
|
|
" term_setkill(), check that :qall works.
|
2018-03-10 20:28:12 +01:00
|
|
|
func Test_terminal_qall_kill_func()
|
2018-03-20 17:43:01 +01:00
|
|
|
call Run_terminal_qall_kill('term', 'call term_setkill(buf, "kill")')
|
|
|
|
endfunc
|
|
|
|
|
|
|
|
" Run Vim, start a terminal in that Vim without the kill argument,
|
|
|
|
" check that :qall does not exit, :qall! does.
|
|
|
|
func Test_terminal_qall_exit()
|
|
|
|
let after = [
|
|
|
|
\ 'term',
|
|
|
|
\ 'let buf = bufnr("%")',
|
|
|
|
\ 'while term_getline(buf, 1) =~ "^\\s*$"',
|
|
|
|
\ ' sleep 10m',
|
|
|
|
\ 'endwhile',
|
|
|
|
\ 'set nomore',
|
|
|
|
\ 'au VimLeavePre * call writefile(["too early"], "Xdone")',
|
|
|
|
\ 'qall',
|
|
|
|
\ 'au! VimLeavePre * exe buf . "bwipe!" | call writefile(["done"], "Xdone")',
|
|
|
|
\ 'cquit',
|
|
|
|
\ ]
|
|
|
|
if !RunVim([], after, '')
|
2018-03-10 20:28:12 +01:00
|
|
|
return
|
|
|
|
endif
|
2018-03-20 17:43:01 +01:00
|
|
|
call assert_equal("done", readfile("Xdone")[0])
|
|
|
|
call delete("Xdone")
|
2018-03-10 20:28:12 +01:00
|
|
|
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
|
|
|
|
2018-03-13 17:55:27 +01:00
|
|
|
func Test_terminal_open_autocmd()
|
2018-03-11 16:55:36 +01:00
|
|
|
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
|
2018-03-24 14:30:32 +01:00
|
|
|
|
|
|
|
func Check_dump01(off)
|
|
|
|
call assert_equal('one two three four five', trim(getline(a:off + 1)))
|
|
|
|
call assert_equal('~ Select Word', trim(getline(a:off + 7)))
|
2018-03-29 17:40:46 +02:00
|
|
|
call assert_equal(':popup PopUp', trim(getline(a:off + 20)))
|
2018-03-24 14:30:32 +01:00
|
|
|
endfunc
|
|
|
|
|
2018-03-29 17:22:24 +02:00
|
|
|
func Test_terminal_dumpwrite_composing()
|
|
|
|
if !CanRunVimInTerminal()
|
|
|
|
return
|
|
|
|
endif
|
|
|
|
let save_enc = &encoding
|
|
|
|
set encoding=utf-8
|
|
|
|
call assert_equal(1, winnr('$'))
|
|
|
|
|
|
|
|
let text = " a\u0300 e\u0302 o\u0308"
|
|
|
|
call writefile([text], 'Xcomposing')
|
|
|
|
let buf = RunVimInTerminal('Xcomposing', {})
|
|
|
|
call WaitFor({-> term_getline(buf, 1) =~ text})
|
|
|
|
call term_dumpwrite(buf, 'Xdump')
|
|
|
|
let dumpline = readfile('Xdump')[0]
|
|
|
|
call assert_match('|à| |ê| |ö', dumpline)
|
|
|
|
|
|
|
|
call StopVimInTerminal(buf)
|
|
|
|
call delete('Xcomposing')
|
|
|
|
call delete('Xdump')
|
|
|
|
let &encoding = save_enc
|
|
|
|
endfunc
|
|
|
|
|
2018-03-24 14:30:32 +01:00
|
|
|
" just testing basic functionality.
|
|
|
|
func Test_terminal_dumpload()
|
|
|
|
call assert_equal(1, winnr('$'))
|
|
|
|
call term_dumpload('dumps/Test_popup_command_01.dump')
|
|
|
|
call assert_equal(2, winnr('$'))
|
|
|
|
call assert_equal(20, line('$'))
|
|
|
|
call Check_dump01(0)
|
|
|
|
quit
|
|
|
|
endfunc
|
|
|
|
|
|
|
|
func Test_terminal_dumpdiff()
|
|
|
|
call assert_equal(1, winnr('$'))
|
|
|
|
call term_dumpdiff('dumps/Test_popup_command_01.dump', 'dumps/Test_popup_command_02.dump')
|
|
|
|
call assert_equal(2, winnr('$'))
|
|
|
|
call assert_equal(62, line('$'))
|
|
|
|
call Check_dump01(0)
|
|
|
|
call Check_dump01(42)
|
|
|
|
call assert_equal(' bbbbbbbbbbbbbbbbbb ', getline(26)[0:29])
|
|
|
|
quit
|
|
|
|
endfunc
|
2018-03-24 17:16:33 +01:00
|
|
|
|
|
|
|
func Test_terminal_dumpdiff_options()
|
|
|
|
set laststatus=0
|
|
|
|
call assert_equal(1, winnr('$'))
|
|
|
|
let height = winheight(0)
|
|
|
|
call term_dumpdiff('dumps/Test_popup_command_01.dump', 'dumps/Test_popup_command_02.dump', {'vertical': 1, 'term_cols': 33})
|
|
|
|
call assert_equal(2, winnr('$'))
|
|
|
|
call assert_equal(height, winheight(winnr()))
|
|
|
|
call assert_equal(33, winwidth(winnr()))
|
|
|
|
call assert_equal('dump diff dumps/Test_popup_command_01.dump', bufname('%'))
|
|
|
|
quit
|
|
|
|
|
|
|
|
call assert_equal(1, winnr('$'))
|
|
|
|
let width = winwidth(0)
|
|
|
|
call term_dumpdiff('dumps/Test_popup_command_01.dump', 'dumps/Test_popup_command_02.dump', {'vertical': 0, 'term_rows': 13, 'term_name': 'something else'})
|
|
|
|
call assert_equal(2, winnr('$'))
|
|
|
|
call assert_equal(width, winwidth(winnr()))
|
|
|
|
call assert_equal(13, winheight(winnr()))
|
|
|
|
call assert_equal('something else', bufname('%'))
|
|
|
|
quit
|
|
|
|
|
|
|
|
call assert_equal(1, winnr('$'))
|
|
|
|
call term_dumpdiff('dumps/Test_popup_command_01.dump', 'dumps/Test_popup_command_02.dump', {'curwin': 1})
|
|
|
|
call assert_equal(1, winnr('$'))
|
|
|
|
bwipe
|
|
|
|
|
|
|
|
set laststatus&
|
|
|
|
endfunc
|
2018-03-25 18:20:17 +02:00
|
|
|
|
2018-04-04 22:57:29 +02:00
|
|
|
func Api_drop_common(options)
|
2018-03-25 18:20:17 +02:00
|
|
|
call assert_equal(1, winnr('$'))
|
|
|
|
|
|
|
|
" Use the title termcap entries to output the escape sequence.
|
|
|
|
call writefile([
|
2018-03-25 20:31:32 +02:00
|
|
|
\ 'set title',
|
2018-03-25 18:20:17 +02:00
|
|
|
\ 'exe "set t_ts=\<Esc>]51; t_fs=\x07"',
|
2018-04-04 22:57:29 +02:00
|
|
|
\ 'let &titlestring = ''["drop","Xtextfile"' . a:options . ']''',
|
2018-03-25 18:20:17 +02:00
|
|
|
\ 'redraw',
|
|
|
|
\ "set t_ts=",
|
|
|
|
\ ], 'Xscript')
|
|
|
|
let buf = RunVimInTerminal('-S Xscript', {})
|
2018-04-11 20:53:49 +02:00
|
|
|
call WaitFor({-> bufnr('Xtextfile') > 0})
|
2018-03-25 18:20:17 +02:00
|
|
|
call assert_equal('Xtextfile', expand('%:t'))
|
|
|
|
call assert_true(winnr('$') >= 3)
|
2018-04-04 22:57:29 +02:00
|
|
|
return buf
|
|
|
|
endfunc
|
|
|
|
|
|
|
|
func Test_terminal_api_drop_newwin()
|
|
|
|
if !CanRunVimInTerminal()
|
|
|
|
return
|
|
|
|
endif
|
|
|
|
let buf = Api_drop_common('')
|
|
|
|
call assert_equal(0, &bin)
|
|
|
|
call assert_equal('', &fenc)
|
|
|
|
|
|
|
|
call StopVimInTerminal(buf)
|
|
|
|
call delete('Xscript')
|
|
|
|
bwipe Xtextfile
|
|
|
|
endfunc
|
|
|
|
|
|
|
|
func Test_terminal_api_drop_newwin_bin()
|
|
|
|
if !CanRunVimInTerminal()
|
|
|
|
return
|
|
|
|
endif
|
|
|
|
let buf = Api_drop_common(',{"bin":1}')
|
|
|
|
call assert_equal(1, &bin)
|
|
|
|
|
|
|
|
call StopVimInTerminal(buf)
|
|
|
|
call delete('Xscript')
|
|
|
|
bwipe Xtextfile
|
|
|
|
endfunc
|
|
|
|
|
|
|
|
func Test_terminal_api_drop_newwin_binary()
|
|
|
|
if !CanRunVimInTerminal()
|
|
|
|
return
|
|
|
|
endif
|
|
|
|
let buf = Api_drop_common(',{"binary":1}')
|
|
|
|
call assert_equal(1, &bin)
|
|
|
|
|
|
|
|
call StopVimInTerminal(buf)
|
|
|
|
call delete('Xscript')
|
|
|
|
bwipe Xtextfile
|
|
|
|
endfunc
|
|
|
|
|
|
|
|
func Test_terminal_api_drop_newwin_nobin()
|
|
|
|
if !CanRunVimInTerminal()
|
|
|
|
return
|
|
|
|
endif
|
|
|
|
set binary
|
|
|
|
let buf = Api_drop_common(',{"nobin":1}')
|
|
|
|
call assert_equal(0, &bin)
|
|
|
|
|
|
|
|
call StopVimInTerminal(buf)
|
|
|
|
call delete('Xscript')
|
|
|
|
bwipe Xtextfile
|
|
|
|
set nobinary
|
|
|
|
endfunc
|
|
|
|
|
|
|
|
func Test_terminal_api_drop_newwin_nobinary()
|
|
|
|
if !CanRunVimInTerminal()
|
|
|
|
return
|
|
|
|
endif
|
|
|
|
set binary
|
|
|
|
let buf = Api_drop_common(',{"nobinary":1}')
|
|
|
|
call assert_equal(0, &bin)
|
|
|
|
|
|
|
|
call StopVimInTerminal(buf)
|
|
|
|
call delete('Xscript')
|
|
|
|
bwipe Xtextfile
|
|
|
|
set nobinary
|
|
|
|
endfunc
|
|
|
|
|
|
|
|
func Test_terminal_api_drop_newwin_ff()
|
|
|
|
if !CanRunVimInTerminal()
|
|
|
|
return
|
|
|
|
endif
|
|
|
|
let buf = Api_drop_common(',{"ff":"dos"}')
|
|
|
|
call assert_equal("dos", &ff)
|
|
|
|
|
|
|
|
call StopVimInTerminal(buf)
|
|
|
|
call delete('Xscript')
|
|
|
|
bwipe Xtextfile
|
|
|
|
endfunc
|
|
|
|
|
|
|
|
func Test_terminal_api_drop_newwin_fileformat()
|
|
|
|
if !CanRunVimInTerminal()
|
|
|
|
return
|
|
|
|
endif
|
|
|
|
let buf = Api_drop_common(',{"fileformat":"dos"}')
|
|
|
|
call assert_equal("dos", &ff)
|
|
|
|
|
|
|
|
call StopVimInTerminal(buf)
|
|
|
|
call delete('Xscript')
|
|
|
|
bwipe Xtextfile
|
|
|
|
endfunc
|
|
|
|
|
|
|
|
func Test_terminal_api_drop_newwin_enc()
|
|
|
|
if !CanRunVimInTerminal()
|
|
|
|
return
|
|
|
|
endif
|
|
|
|
let buf = Api_drop_common(',{"enc":"utf-16"}')
|
|
|
|
call assert_equal("utf-16", &fenc)
|
|
|
|
|
|
|
|
call StopVimInTerminal(buf)
|
|
|
|
call delete('Xscript')
|
|
|
|
bwipe Xtextfile
|
|
|
|
endfunc
|
|
|
|
|
|
|
|
func Test_terminal_api_drop_newwin_encoding()
|
|
|
|
if !CanRunVimInTerminal()
|
|
|
|
return
|
|
|
|
endif
|
|
|
|
let buf = Api_drop_common(',{"encoding":"utf-16"}')
|
|
|
|
call assert_equal("utf-16", &fenc)
|
2018-03-25 18:20:17 +02:00
|
|
|
|
|
|
|
call StopVimInTerminal(buf)
|
|
|
|
call delete('Xscript')
|
|
|
|
bwipe Xtextfile
|
|
|
|
endfunc
|
|
|
|
|
|
|
|
func Test_terminal_api_drop_oldwin()
|
|
|
|
if !CanRunVimInTerminal()
|
|
|
|
return
|
|
|
|
endif
|
|
|
|
let firstwinid = win_getid()
|
|
|
|
split Xtextfile
|
|
|
|
let textfile_winid = win_getid()
|
|
|
|
call assert_equal(2, winnr('$'))
|
|
|
|
call win_gotoid(firstwinid)
|
|
|
|
|
|
|
|
" Use the title termcap entries to output the escape sequence.
|
|
|
|
call writefile([
|
2018-03-25 20:31:32 +02:00
|
|
|
\ 'set title',
|
2018-03-25 18:20:17 +02:00
|
|
|
\ 'exe "set t_ts=\<Esc>]51; t_fs=\x07"',
|
|
|
|
\ 'let &titlestring = ''["drop","Xtextfile"]''',
|
|
|
|
\ 'redraw',
|
|
|
|
\ "set t_ts=",
|
|
|
|
\ ], 'Xscript')
|
2018-03-25 18:56:25 +02:00
|
|
|
let buf = RunVimInTerminal('-S Xscript', {'rows': 10})
|
2018-03-25 18:20:17 +02:00
|
|
|
call WaitFor({-> expand('%:t') =='Xtextfile'})
|
|
|
|
call assert_equal(textfile_winid, win_getid())
|
|
|
|
|
|
|
|
call StopVimInTerminal(buf)
|
|
|
|
call delete('Xscript')
|
|
|
|
bwipe Xtextfile
|
|
|
|
endfunc
|
|
|
|
|
2018-03-26 21:38:52 +02:00
|
|
|
func Tapi_TryThis(bufnum, arg)
|
2018-03-25 18:20:17 +02:00
|
|
|
let g:called_bufnum = a:bufnum
|
|
|
|
let g:called_arg = a:arg
|
|
|
|
endfunc
|
|
|
|
|
2018-03-26 21:38:52 +02:00
|
|
|
func WriteApiCall(funcname)
|
2018-03-25 18:20:17 +02:00
|
|
|
" Use the title termcap entries to output the escape sequence.
|
|
|
|
call writefile([
|
2018-03-25 20:31:32 +02:00
|
|
|
\ 'set title',
|
2018-03-25 18:20:17 +02:00
|
|
|
\ 'exe "set t_ts=\<Esc>]51; t_fs=\x07"',
|
2018-03-26 21:38:52 +02:00
|
|
|
\ 'let &titlestring = ''["call","' . a:funcname . '",["hello",123]]''',
|
2018-03-25 18:20:17 +02:00
|
|
|
\ 'redraw',
|
|
|
|
\ "set t_ts=",
|
|
|
|
\ ], 'Xscript')
|
2018-03-26 21:38:52 +02:00
|
|
|
endfunc
|
|
|
|
|
|
|
|
func Test_terminal_api_call()
|
|
|
|
if !CanRunVimInTerminal()
|
|
|
|
return
|
|
|
|
endif
|
|
|
|
|
|
|
|
call WriteApiCall('Tapi_TryThis')
|
2018-03-25 18:20:17 +02:00
|
|
|
let buf = RunVimInTerminal('-S Xscript', {})
|
|
|
|
call WaitFor({-> exists('g:called_bufnum')})
|
|
|
|
call assert_equal(buf, g:called_bufnum)
|
|
|
|
call assert_equal(['hello', 123], g:called_arg)
|
|
|
|
|
|
|
|
call StopVimInTerminal(buf)
|
|
|
|
call delete('Xscript')
|
|
|
|
unlet g:called_bufnum
|
|
|
|
unlet g:called_arg
|
|
|
|
endfunc
|
2018-03-26 21:38:52 +02:00
|
|
|
|
|
|
|
func Test_terminal_api_call_fails()
|
|
|
|
if !CanRunVimInTerminal()
|
|
|
|
return
|
|
|
|
endif
|
|
|
|
|
|
|
|
call WriteApiCall('TryThis')
|
|
|
|
call ch_logfile('Xlog', 'w')
|
|
|
|
let buf = RunVimInTerminal('-S Xscript', {})
|
|
|
|
call WaitFor({-> string(readfile('Xlog')) =~ 'Invalid function name: TryThis'})
|
|
|
|
|
|
|
|
call StopVimInTerminal(buf)
|
|
|
|
call delete('Xscript')
|
|
|
|
call ch_logfile('', '')
|
|
|
|
call delete('Xlog')
|
|
|
|
endfunc
|
2018-04-10 15:59:11 +02:00
|
|
|
|
|
|
|
func Test_terminal_ansicolors_default()
|
|
|
|
let colors = [
|
|
|
|
\ '#000000', '#e00000',
|
|
|
|
\ '#00e000', '#e0e000',
|
|
|
|
\ '#0000e0', '#e000e0',
|
|
|
|
\ '#00e0e0', '#e0e0e0',
|
|
|
|
\ '#808080', '#ff4040',
|
|
|
|
\ '#40ff40', '#ffff40',
|
|
|
|
\ '#4040ff', '#ff40ff',
|
|
|
|
\ '#40ffff', '#ffffff',
|
|
|
|
\]
|
|
|
|
|
|
|
|
let buf = Run_shell_in_terminal({})
|
|
|
|
call assert_equal(colors, term_getansicolors(buf))
|
|
|
|
call Stop_shell_in_terminal(buf)
|
|
|
|
call term_wait(buf)
|
|
|
|
|
|
|
|
exe buf . 'bwipe'
|
|
|
|
endfunc
|
|
|
|
|
|
|
|
let s:test_colors = [
|
|
|
|
\ '#616e64', '#0d0a79',
|
|
|
|
\ '#6d610d', '#0a7373',
|
|
|
|
\ '#690d0a', '#6d696e',
|
|
|
|
\ '#0d0a6f', '#616e0d',
|
|
|
|
\ '#0a6479', '#6d0d0a',
|
|
|
|
\ '#617373', '#0d0a69',
|
|
|
|
\ '#6d690d', '#0a6e6f',
|
|
|
|
\ '#610d0a', '#6e6479',
|
|
|
|
\]
|
|
|
|
|
|
|
|
func Test_terminal_ansicolors_global()
|
|
|
|
let g:terminal_ansi_colors = reverse(copy(s:test_colors))
|
|
|
|
let buf = Run_shell_in_terminal({})
|
|
|
|
call assert_equal(g:terminal_ansi_colors, term_getansicolors(buf))
|
|
|
|
call Stop_shell_in_terminal(buf)
|
|
|
|
call term_wait(buf)
|
|
|
|
|
|
|
|
exe buf . 'bwipe'
|
|
|
|
unlet g:terminal_ansi_colors
|
|
|
|
endfunc
|
|
|
|
|
|
|
|
func Test_terminal_ansicolors_func()
|
|
|
|
let g:terminal_ansi_colors = reverse(copy(s:test_colors))
|
|
|
|
let buf = Run_shell_in_terminal({'ansi_colors': s:test_colors})
|
|
|
|
call assert_equal(s:test_colors, term_getansicolors(buf))
|
|
|
|
|
|
|
|
call term_setansicolors(buf, g:terminal_ansi_colors)
|
|
|
|
call assert_equal(g:terminal_ansi_colors, term_getansicolors(buf))
|
|
|
|
|
|
|
|
let colors = [
|
|
|
|
\ 'ivory', 'AliceBlue',
|
|
|
|
\ 'grey67', 'dark goldenrod',
|
|
|
|
\ 'SteelBlue3', 'PaleVioletRed4',
|
|
|
|
\ 'MediumPurple2', 'yellow2',
|
|
|
|
\ 'RosyBrown3', 'OrangeRed2',
|
|
|
|
\ 'white smoke', 'navy blue',
|
|
|
|
\ 'grey47', 'gray97',
|
|
|
|
\ 'MistyRose2', 'DodgerBlue4',
|
|
|
|
\]
|
|
|
|
call term_setansicolors(buf, colors)
|
|
|
|
|
|
|
|
let colors[4] = 'Invalid'
|
|
|
|
call assert_fails('call term_setansicolors(buf, colors)', 'E474:')
|
|
|
|
|
|
|
|
call Stop_shell_in_terminal(buf)
|
|
|
|
call term_wait(buf)
|
|
|
|
exe buf . 'bwipe'
|
|
|
|
endfunc
|
2018-04-15 22:25:54 +02:00
|
|
|
|
|
|
|
func Test_terminal_termsize_option()
|
|
|
|
if !CanRunVimInTerminal()
|
|
|
|
return
|
|
|
|
endif
|
|
|
|
set termsize=6x40
|
|
|
|
let text = []
|
|
|
|
for n in range(10)
|
|
|
|
call add(text, repeat(n, 50))
|
|
|
|
endfor
|
|
|
|
call writefile(text, 'Xwinsize')
|
|
|
|
let buf = RunVimInTerminal('Xwinsize', {})
|
|
|
|
let win = bufwinid(buf)
|
|
|
|
call assert_equal([6, 40], term_getsize(buf))
|
|
|
|
call assert_equal(6, winheight(win))
|
|
|
|
call assert_equal(40, winwidth(win))
|
|
|
|
|
|
|
|
" resizing the window doesn't resize the terminal.
|
|
|
|
resize 10
|
|
|
|
vertical resize 60
|
|
|
|
call assert_equal([6, 40], term_getsize(buf))
|
|
|
|
call assert_equal(10, winheight(win))
|
|
|
|
call assert_equal(60, winwidth(win))
|
|
|
|
|
|
|
|
call StopVimInTerminal(buf)
|
|
|
|
call delete('Xwinsize')
|
|
|
|
|
|
|
|
call assert_fails('set termsize=40', 'E474')
|
|
|
|
call assert_fails('set termsize=10+40', 'E474')
|
|
|
|
call assert_fails('set termsize=abc', 'E474')
|
|
|
|
|
|
|
|
set termsize=
|
|
|
|
endfunc
|