diff options
Diffstat (limited to 'test/functional/autocmd/termclose_spec.lua')
-rw-r--r-- | test/functional/autocmd/termclose_spec.lua | 105 |
1 files changed, 77 insertions, 28 deletions
diff --git a/test/functional/autocmd/termclose_spec.lua b/test/functional/autocmd/termclose_spec.lua index 02ea0dbd95..62eac59b16 100644 --- a/test/functional/autocmd/termclose_spec.lua +++ b/test/functional/autocmd/termclose_spec.lua @@ -1,44 +1,93 @@ +local luv = require('luv') local helpers = require('test.functional.helpers')(after_each) -local Screen = require('test.functional.ui.screen') -local clear, execute, feed, nvim, nvim_dir = helpers.clear, -helpers.execute, helpers.feed, helpers.nvim, helpers.nvim_dir -local eval, eq = helpers.eval, helpers.eq +local clear, command, nvim, nvim_dir = + helpers.clear, helpers.command, helpers.nvim, helpers.nvim_dir +local eval, eq, retry = + helpers.eval, helpers.eq, helpers.retry +local ok = helpers.ok +local feed = helpers.feed +local iswin = helpers.iswin + describe('TermClose event', function() - local screen before_each(function() clear() nvim('set_option', 'shell', nvim_dir .. '/shell-test') nvim('set_option', 'shellcmdflag', 'EXE') - screen = Screen.new(20, 4) - screen:attach(false) end) - it('works as expected', function() - execute('autocmd TermClose * echomsg "TermClose works!"') - execute('terminal') - feed('<c-\\><c-n>') - screen:expect([[ - ready $ | - [Process exited 0] | - ^ | - TermClose works! | - ]]) + it('triggers when fast-exiting terminal job stops', function() + command('autocmd TermClose * let g:test_termclose = 23') + command('terminal') + command('call jobstop(b:terminal_job_id)') + retry(nil, nil, function() eq(23, eval('g:test_termclose')) end) + end) + + it('triggers when long-running terminal job gets stopped', function() + nvim('set_option', 'shell', iswin() and 'cmd.exe' or 'sh') + command('autocmd TermClose * let g:test_termclose = 23') + command('terminal') + command('call jobstop(b:terminal_job_id)') + retry(nil, nil, function() eq(23, eval('g:test_termclose')) end) + end) + + it('kills job trapping SIGTERM', function() + if iswin() then return end + nvim('set_option', 'shell', 'sh') + nvim('set_option', 'shellcmdflag', '-c') + command([[ let g:test_job = jobstart('trap "" TERM && echo 1 && sleep 60', { ]] + .. [[ 'on_stdout': {-> execute('let g:test_job_started = 1')}, ]] + .. [[ 'on_exit': {-> execute('let g:test_job_exited = 1')}}) ]]) + retry(nil, nil, function() eq(1, eval('get(g:, "test_job_started", 0)')) end) + + luv.update_time() + local start = luv.now() + command('call jobstop(g:test_job)') + retry(nil, nil, function() eq(1, eval('get(g:, "test_job_exited", 0)')) end) + luv.update_time() + local duration = luv.now() - start + -- Nvim begins SIGTERM after KILL_TIMEOUT_MS. + ok(duration >= 2000) + ok(duration <= 4000) -- Epsilon for slow CI + end) + + it('kills PTY job trapping SIGHUP and SIGTERM', function() + if iswin() then return end + nvim('set_option', 'shell', 'sh') + nvim('set_option', 'shellcmdflag', '-c') + command([[ let g:test_job = jobstart('trap "" HUP TERM && echo 1 && sleep 60', { ]] + .. [[ 'pty': 1,]] + .. [[ 'on_stdout': {-> execute('let g:test_job_started = 1')}, ]] + .. [[ 'on_exit': {-> execute('let g:test_job_exited = 1')}}) ]]) + retry(nil, nil, function() eq(1, eval('get(g:, "test_job_started", 0)')) end) + + luv.update_time() + local start = luv.now() + command('call jobstop(g:test_job)') + retry(nil, nil, function() eq(1, eval('get(g:, "test_job_exited", 0)')) end) + luv.update_time() + local duration = luv.now() - start + -- Nvim begins SIGKILL after (2 * KILL_TIMEOUT_MS). + ok(duration >= 4000) + ok(duration <= 7000) -- Epsilon for slow CI end) it('reports the correct <abuf>', function() - execute('set hidden') - execute('autocmd TermClose * let g:abuf = expand("<abuf>")') - execute('edit foo') - execute('edit bar') + command('set hidden') + command('autocmd TermClose * let g:abuf = expand("<abuf>")') + command('edit foo') + command('edit bar') eq(2, eval('bufnr("%")')) - execute('terminal') - feed('<c-\\><c-n>') - eq(3, eval('bufnr("%")')) - execute('buffer 1') - eq(1, eval('bufnr("%")')) - execute('3bdelete!') - eq('3', eval('g:abuf')) + + command('terminal') + retry(nil, nil, function() eq(3, eval('bufnr("%")')) end) + + command('buffer 1') + retry(nil, nil, function() eq(1, eval('bufnr("%")')) end) + + command('3bdelete!') + retry(nil, nil, function() eq('3', eval('g:abuf')) end) + feed('<c-c>:qa!<cr>') end) end) |