diff options
author | Justin M. Keyes <justinkz@gmail.com> | 2019-06-08 14:46:16 +0200 |
---|---|---|
committer | GitHub <noreply@github.com> | 2019-06-08 14:46:16 +0200 |
commit | d486ea37b289ba5a3d6a27af575516da22b2e10b (patch) | |
tree | 44d3a29ff3beff074cd7e47612991ada353faa95 | |
parent | 766657320a81eed0007682bb867fe2cfb90c67a6 (diff) | |
parent | 192460e6b6384330d1b83a6c0ba508ab957625f2 (diff) | |
download | rneovim-d486ea37b289ba5a3d6a27af575516da22b2e10b.tar.gz rneovim-d486ea37b289ba5a3d6a27af575516da22b2e10b.tar.bz2 rneovim-d486ea37b289ba5a3d6a27af575516da22b2e10b.zip |
Merge #10151 from blueyed/vim-8.1.0807
vim-patch:8.1.{0807,0813}
-rw-r--r-- | src/nvim/testdir/test_autocmd.vim | 90 | ||||
-rw-r--r-- | src/nvim/testdir/test_mksession.vim | 4 |
2 files changed, 94 insertions, 0 deletions
diff --git a/src/nvim/testdir/test_autocmd.vim b/src/nvim/testdir/test_autocmd.vim index 8182c6973b..d66e237e45 100644 --- a/src/nvim/testdir/test_autocmd.vim +++ b/src/nvim/testdir/test_autocmd.vim @@ -1671,3 +1671,93 @@ func Test_ReadWrite_Autocmds() call delete('Xtest.c') call delete('test.out') endfunc + +func Test_FileChangedShell_reload() + if !has('unix') + return + endif + augroup testreload + au FileChangedShell Xchanged let g:reason = v:fcs_reason | let v:fcs_choice = 'reload' + augroup END + new Xchanged + call setline(1, 'reload this') + write + " Need to wait until the timestamp would change by at least a second. + sleep 2 + silent !echo 'extra line' >>Xchanged + checktime + call assert_equal('changed', g:reason) + call assert_equal(2, line('$')) + call assert_equal('extra line', getline(2)) + + " Only triggers once + let g:reason = '' + checktime + call assert_equal('', g:reason) + + " When deleted buffer is not reloaded + silent !rm Xchanged + let g:reason = '' + checktime + call assert_equal('deleted', g:reason) + call assert_equal(2, line('$')) + call assert_equal('extra line', getline(2)) + + " When recreated buffer is reloaded + call setline(1, 'buffer is changed') + silent !echo 'new line' >>Xchanged + let g:reason = '' + checktime + call assert_equal('conflict', g:reason) + call assert_equal(1, line('$')) + call assert_equal('new line', getline(1)) + + " Only mode changed + silent !chmod +x Xchanged + let g:reason = '' + checktime + call assert_equal('mode', g:reason) + call assert_equal(1, line('$')) + call assert_equal('new line', getline(1)) + + " Only time changed + sleep 2 + silent !touch Xchanged + let g:reason = '' + checktime + call assert_equal('time', g:reason) + call assert_equal(1, line('$')) + call assert_equal('new line', getline(1)) + + if has('persistent_undo') + " With an undo file the reload can be undone and a change before the + " reload. + set undofile + call setline(2, 'before write') + write + call setline(2, 'after write') + sleep 2 + silent !echo 'different line' >>Xchanged + let g:reason = '' + checktime + call assert_equal('conflict', g:reason) + call assert_equal(3, line('$')) + call assert_equal('before write', getline(2)) + call assert_equal('different line', getline(3)) + " undo the reload + undo + call assert_equal(2, line('$')) + call assert_equal('after write', getline(2)) + " undo the change before reload + undo + call assert_equal(2, line('$')) + call assert_equal('before write', getline(2)) + + set noundofile + endif + + + au! testreload + bwipe! + call delete('Xchanged') +endfunc diff --git a/src/nvim/testdir/test_mksession.vim b/src/nvim/testdir/test_mksession.vim index c790bd32e3..7c5b95ae96 100644 --- a/src/nvim/testdir/test_mksession.vim +++ b/src/nvim/testdir/test_mksession.vim @@ -239,6 +239,10 @@ func Test_mkview_no_file_name() endfunc func Test_mksession_quote_in_filename() + if !has('unix') + " only Unix can handle this weird filename + return + endif let v:errmsg = '' let filename = has('win32') ? 'x''y' : 'x''y"z' %bwipe! |