diff options
author | zeertzjq <zeertzjq@outlook.com> | 2022-06-13 06:02:00 +0800 |
---|---|---|
committer | GitHub <noreply@github.com> | 2022-06-12 15:02:00 -0700 |
commit | 429c40cce3fce3b5391afef8208d65a80a316018 (patch) | |
tree | f468e6244bc01662180306904c0c008999713d22 /test/functional/lua/buffer_updates_spec.lua | |
parent | feba56af7d032c948a78c21735502bebe45f8361 (diff) | |
download | rneovim-429c40cce3fce3b5391afef8208d65a80a316018.tar.gz rneovim-429c40cce3fce3b5391afef8208d65a80a316018.tar.bz2 rneovim-429c40cce3fce3b5391afef8208d65a80a316018.zip |
fix(buffer): disable buffer-updates before removing from window #18933
There can be other places that access window buffer info (e.g.
`tabpagebuflist()`), so checking `w_closing` in `win_findbuf()` doesn't
solve the crash in all cases, and may also cause Nvim's behavior to
diverge from Vim.
Fix #14998
Diffstat (limited to 'test/functional/lua/buffer_updates_spec.lua')
-rw-r--r-- | test/functional/lua/buffer_updates_spec.lua | 11 |
1 files changed, 8 insertions, 3 deletions
diff --git a/test/functional/lua/buffer_updates_spec.lua b/test/functional/lua/buffer_updates_spec.lua index cbd78ccd53..f32274468a 100644 --- a/test/functional/lua/buffer_updates_spec.lua +++ b/test/functional/lua/buffer_updates_spec.lua @@ -252,9 +252,8 @@ describe('lua buffer event callbacks: on_lines', function() eq(2, meths.win_get_cursor(0)[1]) end) - it('does not SEGFAULT when calling win_findbuf in on_detach', function() - - exec_lua[[ + it('does not SEGFAULT when accessing window buffer info in on_detach #14998', function() + local code = [[ local buf = vim.api.nvim_create_buf(false, false) vim.cmd"split" @@ -262,13 +261,19 @@ describe('lua buffer event callbacks: on_lines', function() vim.api.nvim_buf_attach(buf, false, { on_detach = function(_, buf) + vim.fn.tabpagebuflist() vim.fn.win_findbuf(buf) end }) ]] + exec_lua(code) command("q!") helpers.assert_alive() + + exec_lua(code) + command("bd!") + helpers.assert_alive() end) it('#12718 lnume', function() |