diff options
Diffstat (limited to 'src')
| -rw-r--r-- | src/nvim/testdir/test_excmd.vim | 120 | 
1 files changed, 85 insertions, 35 deletions
| diff --git a/src/nvim/testdir/test_excmd.vim b/src/nvim/testdir/test_excmd.vim index 7d581d5efd..f844999d8d 100644 --- a/src/nvim/testdir/test_excmd.vim +++ b/src/nvim/testdir/test_excmd.vim @@ -242,49 +242,58 @@ func Test_confirm_cmd()    CheckNotGui    CheckRunVimInTerminal -  call writefile(['foo1'], 'foo') -  call writefile(['bar1'], 'bar') +  call writefile(['foo1'], 'Xfoo') +  call writefile(['bar1'], 'Xbar')    " Test for saving all the modified buffers -  let buf = RunVimInTerminal('', {'rows': 20}) -  call term_sendkeys(buf, ":set nomore\n") -  call term_sendkeys(buf, ":new foo\n") -  call term_sendkeys(buf, ":call setline(1, 'foo2')\n") -  call term_sendkeys(buf, ":new bar\n") -  call term_sendkeys(buf, ":call setline(1, 'bar2')\n") -  call term_sendkeys(buf, ":wincmd b\n") +  let lines =<< trim END +    set nomore +    new Xfoo +    call setline(1, 'foo2') +    new Xbar +    call setline(1, 'bar2') +    wincmd b +  END +  call writefile(lines, 'Xscript') +  let buf = RunVimInTerminal('-S Xscript', {'rows': 20})    call term_sendkeys(buf, ":confirm qall\n")    call WaitForAssert({-> assert_match('\[Y\]es, (N)o, Save (A)ll, (D)iscard All, (C)ancel: ', term_getline(buf, 20))}, 1000)    call term_sendkeys(buf, "A")    call StopVimInTerminal(buf) -  call assert_equal(['foo2'], readfile('foo')) -  call assert_equal(['bar2'], readfile('bar')) +  call assert_equal(['foo2'], readfile('Xfoo')) +  call assert_equal(['bar2'], readfile('Xbar'))    " Test for discarding all the changes to modified buffers -  let buf = RunVimInTerminal('', {'rows': 20}) -  call term_sendkeys(buf, ":set nomore\n") -  call term_sendkeys(buf, ":new foo\n") -  call term_sendkeys(buf, ":call setline(1, 'foo3')\n") -  call term_sendkeys(buf, ":new bar\n") -  call term_sendkeys(buf, ":call setline(1, 'bar3')\n") -  call term_sendkeys(buf, ":wincmd b\n") +  let lines =<< trim END +    set nomore +    new Xfoo +    call setline(1, 'foo3') +    new Xbar +    call setline(1, 'bar3') +    wincmd b +  END +  call writefile(lines, 'Xscript') +  let buf = RunVimInTerminal('-S Xscript', {'rows': 20})    call term_sendkeys(buf, ":confirm qall\n")    call WaitForAssert({-> assert_match('\[Y\]es, (N)o, Save (A)ll, (D)iscard All, (C)ancel: ', term_getline(buf, 20))}, 1000)    call term_sendkeys(buf, "D")    call StopVimInTerminal(buf) -  call assert_equal(['foo2'], readfile('foo')) -  call assert_equal(['bar2'], readfile('bar')) +  call assert_equal(['foo2'], readfile('Xfoo')) +  call assert_equal(['bar2'], readfile('Xbar'))    " Test for saving and discarding changes to some buffers -  let buf = RunVimInTerminal('', {'rows': 20}) -  call term_sendkeys(buf, ":set nomore\n") -  call term_sendkeys(buf, ":new foo\n") -  call term_sendkeys(buf, ":call setline(1, 'foo4')\n") -  call term_sendkeys(buf, ":new bar\n") -  call term_sendkeys(buf, ":call setline(1, 'bar4')\n") -  call term_sendkeys(buf, ":wincmd b\n") +  let lines =<< trim END +    set nomore +    new Xfoo +    call setline(1, 'foo4') +    new Xbar +    call setline(1, 'bar4') +    wincmd b +  END +  call writefile(lines, 'Xscript') +  let buf = RunVimInTerminal('-S Xscript', {'rows': 20})    call term_sendkeys(buf, ":confirm qall\n")    call WaitForAssert({-> assert_match('\[Y\]es, (N)o, Save (A)ll, (D)iscard All, (C)ancel: ', term_getline(buf, 20))}, 1000)    call term_sendkeys(buf, "N") @@ -292,11 +301,12 @@ func Test_confirm_cmd()    call term_sendkeys(buf, "Y")    call StopVimInTerminal(buf) -  call assert_equal(['foo4'], readfile('foo')) -  call assert_equal(['bar2'], readfile('bar')) +  call assert_equal(['foo4'], readfile('Xfoo')) +  call assert_equal(['bar2'], readfile('Xbar')) -  call delete('foo') -  call delete('bar') +  call delete('Xscript') +  call delete('Xfoo') +  call delete('Xbar')  endfunc  func Test_confirm_cmd_cancel() @@ -304,10 +314,13 @@ func Test_confirm_cmd_cancel()    CheckRunVimInTerminal    " Test for closing a window with a modified buffer -  let buf = RunVimInTerminal('', {'rows': 20}) -  call term_sendkeys(buf, ":set nomore\n") -  call term_sendkeys(buf, ":new\n") -  call term_sendkeys(buf, ":call setline(1, 'abc')\n") +  let lines =<< trim END +    set nomore +    new +    call setline(1, 'abc') +  END +  call writefile(lines, 'Xscript') +  let buf = RunVimInTerminal('-S Xscript', {'rows': 20})    call term_sendkeys(buf, ":confirm close\n")    call WaitForAssert({-> assert_match('^\[Y\]es, (N)o, (C)ancel: *$',          \ term_getline(buf, 20))}, 1000) @@ -320,6 +333,43 @@ func Test_confirm_cmd_cancel()    call WaitForAssert({-> assert_match('^ *0,0-1         All$',          \ term_getline(buf, 20))}, 1000)    call StopVimInTerminal(buf) +  call delete('Xscript') +endfunc + +" The ":confirm" prompt was sometimes used with the terminal in cooked mode. +" This test verifies that a "\<CR>" character is NOT required to respond to a +" prompt from the ":conf q" and ":conf wq" commands. +func Test_confirm_q_wq() +  CheckNotGui +  CheckRunVimInTerminal + +  call writefile(['foo'], 'Xfoo') + +  let lines =<< trim END +    set hidden nomore +    call setline(1, 'abc') +    edit Xfoo +  END +  call writefile(lines, 'Xscript') +  let buf = RunVimInTerminal('-S Xscript', {'rows': 20}) +  call term_sendkeys(buf, ":confirm q\n") +  call WaitForAssert({-> assert_match('^\[Y\]es, (N)o, (C)ancel: *$', +        \ term_getline(buf, 20))}, 1000) +  call term_sendkeys(buf, 'C') +  call WaitForAssert({-> assert_notmatch('^\[Y\]es, (N)o, (C)ancel: C*$', +        \ term_getline(buf, 20))}, 1000) + +  call term_sendkeys(buf, ":edit Xfoo\n") +  call term_sendkeys(buf, ":confirm wq\n") +  call WaitForAssert({-> assert_match('^\[Y\]es, (N)o, (C)ancel: *$', +        \ term_getline(buf, 20))}, 1000) +  call term_sendkeys(buf, 'C') +  call WaitForAssert({-> assert_notmatch('^\[Y\]es, (N)o, (C)ancel: C*$', +        \ term_getline(buf, 20))}, 1000) +  call StopVimInTerminal(buf) + +  call delete('Xscript') +  call delete('Xfoo')  endfunc  func Test_confirm_write_ro() | 
