local helpers = require('test.functional.helpers')(after_each) local thelpers = require('test.functional.terminal.helpers') local feed, clear, nvim = helpers.feed, helpers.clear, helpers.nvim local wait = helpers.wait local eval, execute, source = helpers.eval, helpers.execute, helpers.source local eq, neq = helpers.eq, helpers.neq if helpers.pending_win32(pending) then return end describe('terminal buffer', function() local screen before_each(function() clear() execute('set modifiable swapfile undolevels=20') wait() screen = thelpers.screen_setup() end) describe('when a new file is edited', function() before_each(function() feed(':set bufhidden=wipe:enew') screen:expect([[ ^ | {4:~ }| {4:~ }| {4:~ }| {4:~ }| {4:~ }| :enew | ]]) end) it('will hide the buffer, ignoring the bufhidden option', function() feed(':bnext:l') screen:expect([[ ^ | {4:~ }| {4:~ }| {4:~ }| {4:~ }| {4:~ }| | ]]) end) end) describe('swap and undo', function() before_each(function() feed('') screen:expect([[ tty ready | {2: } | | | | ^ | | ]]) end) it('does not create swap files', function() local swapfile = nvim('command_output', 'swapname'):gsub('\n', '') eq(nil, io.open(swapfile)) end) it('does not create undofiles files', function() local undofile = nvim('eval', 'undofile(bufname("%"))') eq(nil, io.open(undofile)) end) end) it('cannot be modified directly', function() feed('dd') screen:expect([[ tty ready | {2: } | | | | ^ | {8:E21: Cannot make changes, 'modifiable' is off} | ]]) end) it('sends data to the terminal when the "put" operator is used', function() feed('gg"ayj') execute('let @a = "appended " . @a') feed('"ap"ap') screen:expect([[ ^tty ready | appended tty ready | appended tty ready | {2: } | | | :let @a = "appended " . @a | ]]) -- operator count is also taken into consideration feed('3"ap') screen:expect([[ ^tty ready | appended tty ready | appended tty ready | appended tty ready | appended tty ready | appended tty ready | :let @a = "appended " . @a | ]]) end) it('sends data to the terminal when the ":put" command is used', function() feed('gg"ayj') execute('let @a = "appended " . @a') execute('put a') screen:expect([[ ^tty ready | appended tty ready | {2: } | | | | :put a | ]]) -- line argument is only used to move the cursor execute('6put a') screen:expect([[ tty ready | appended tty ready | appended tty ready | {2: } | | ^ | :6put a | ]]) end) it('can be deleted', function() feed(':bd!') screen:expect([[ ^ | {4:~ }| {4:~ }| {4:~ }| {4:~ }| {4:~ }| :bd! | ]]) execute('bnext') screen:expect([[ ^ | {4:~ }| {4:~ }| {4:~ }| {4:~ }| {4:~ }| :bnext | ]]) end) it('handles loss of focus gracefully', function() -- Change the statusline to avoid printing the file name, which varies. nvim('set_option', 'statusline', '==========') execute('set laststatus=0') -- Save the buffer number of the terminal for later testing. local tbuf = eval('bufnr("%")') source([[ function! SplitWindow() new call feedkeys("iabc\") endfunction startinsert call jobstart(['sh', '-c', 'exit'], {'on_exit': function("SplitWindow")}) call feedkeys("\", 't') " vim will expect , but be exited out of " the terminal before it can be entered. ]]) -- We should be in a new buffer now. screen:expect([[ ab^c | {4:~ }| {5:========== }| rows: 2, cols: 50 | {2: } | {1:========== }| | ]]) neq(tbuf, eval('bufnr("%")')) execute('quit!') -- Should exit the new window, not the terminal. eq(tbuf, eval('bufnr("%")')) execute('set laststatus=1') -- Restore laststatus to the default. end) it('term_close() use-after-free #4393', function() if eval("executable('yes')") == 0 then pending('missing "yes" command') return end execute('terminal yes') feed([[]]) execute('bdelete!') end) end)