aboutsummaryrefslogtreecommitdiff
path: root/test/functional/api/vim_spec.lua
diff options
context:
space:
mode:
authorSean Dewar <6256228+seandewar@users.noreply.github.com>2024-03-19 10:55:33 +0000
committerSean Dewar <6256228+seandewar@users.noreply.github.com>2024-03-19 15:43:08 +0000
commitd5c23d72a5e4d2abb0903e58c4953fa0303d4ad6 (patch)
treed12a2bbdb9d0b046f424141ba611280569b04ef5 /test/functional/api/vim_spec.lua
parentaca2048bcd57937ea1c7b7f0325f25d5b82588db (diff)
downloadrneovim-d5c23d72a5e4d2abb0903e58c4953fa0303d4ad6.tar.gz
rneovim-d5c23d72a5e4d2abb0903e58c4953fa0303d4ad6.tar.bz2
rneovim-d5c23d72a5e4d2abb0903e58c4953fa0303d4ad6.zip
fix(api): nvim_create_buf leaks memory if buffer is loaded early
Problem: memory leak in nvim_create_buf if buflist_new autocommands load the new buffer early. Solution: do not open a memfile in that case.
Diffstat (limited to 'test/functional/api/vim_spec.lua')
-rw-r--r--test/functional/api/vim_spec.lua9
1 files changed, 9 insertions, 0 deletions
diff --git a/test/functional/api/vim_spec.lua b/test/functional/api/vim_spec.lua
index 09a45242ec..a3f70efcea 100644
--- a/test/functional/api/vim_spec.lua
+++ b/test/functional/api/vim_spec.lua
@@ -3135,6 +3135,15 @@ describe('API', function()
-- nowadays this works because we don't execute any spurious autocmds at all #24824
assert_alive()
end)
+
+ it('no memory leak when autocommands load the buffer immediately', function()
+ exec([[
+ autocmd BufNew * ++once call bufload(expand("<abuf>")->str2nr())
+ \| let loaded = bufloaded(expand("<abuf>")->str2nr())
+ ]])
+ api.nvim_create_buf(false, true)
+ eq(1, eval('g:loaded'))
+ end)
end)
describe('nvim_get_runtime_file', function()