summaryrefslogtreecommitdiffstats
path: root/src/testdir/test_autocmd.vim
diff options
context:
space:
mode:
authorBram Moolenaar <Bram@vim.org>2022-04-06 17:59:21 +0100
committerBram Moolenaar <Bram@vim.org>2022-04-06 17:59:21 +0100
commitc947b9ae419114ebfef9725814ea41a466fcf879 (patch)
tree3f7f6e0e928cfa8bb7c11279aa1ffce6ff8048b9 /src/testdir/test_autocmd.vim
parent75a0f3c011dfbafd2d60e87d4b2b07572df3e3ec (diff)
patch 8.2.4700: buffer remains active if WinClosed event throws an exceptionv8.2.4700
Problem: Buffer remains active if a WinClosed event throws an exception. Solution: Ignore aborting() when closing the buffer. (closes #10097)
Diffstat (limited to 'src/testdir/test_autocmd.vim')
-rw-r--r--src/testdir/test_autocmd.vim17
1 files changed, 17 insertions, 0 deletions
diff --git a/src/testdir/test_autocmd.vim b/src/testdir/test_autocmd.vim
index 39ba9af7dc..89023a1fb7 100644
--- a/src/testdir/test_autocmd.vim
+++ b/src/testdir/test_autocmd.vim
@@ -348,6 +348,23 @@ func Test_WinClosed()
unlet g:triggered
endfunc
+func Test_WinClosed_throws()
+ vnew
+ let bnr = bufnr()
+ call assert_equal(1, bufloaded(bnr))
+ augroup test-WinClosed
+ autocmd WinClosed * throw 'foo'
+ augroup END
+ try
+ close
+ catch /.*/
+ endtry
+ call assert_equal(0, bufloaded(bnr))
+
+ autocmd! test-WinClosed
+ augroup! test-WinClosed
+endfunc
+
func s:AddAnAutocmd()
augroup vimBarTest
au BufReadCmd * echo 'hello'