diff options
author | Bram Moolenaar <Bram@vim.org> | 2019-01-05 00:02:57 +0100 |
---|---|---|
committer | Bram Moolenaar <Bram@vim.org> | 2019-01-05 00:02:57 +0100 |
commit | 8b62d87e4243d3dc9bf4f17bfe1a8953077a70c9 (patch) | |
tree | 3d1d16641f92aedc102ebb93a341256571e0b928 /src/testdir/test_channel.vim | |
parent | 4164bb204e97a2ff3d6c43cba779bdff9e853892 (diff) | |
download | vim-git-8b62d87e4243d3dc9bf4f17bfe1a8953077a70c9.tar.gz |
patch 8.1.0692: if a buffer was deleted a channel can't write to itv8.1.0692
Problem: If a buffer was deleted a channel can't write to it.
Solution: When the buffer exists but was unloaded, prepare it for writing.
(closes #3764)
Diffstat (limited to 'src/testdir/test_channel.vim')
-rw-r--r-- | src/testdir/test_channel.vim | 22 |
1 files changed, 22 insertions, 0 deletions
diff --git a/src/testdir/test_channel.vim b/src/testdir/test_channel.vim index bbc604853..091cd4ba1 100644 --- a/src/testdir/test_channel.vim +++ b/src/testdir/test_channel.vim @@ -1645,6 +1645,28 @@ func Test_collapse_buffers() bwipe! endfunc +func Test_write_to_deleted_buffer() + if !executable('echo') || !has('job') + return + endif + let job = job_start('echo hello', {'out_io': 'buffer', 'out_name': 'test_buffer', 'out_msg': 0}) + call WaitForAssert({-> assert_equal("dead", job_status(job))}) + let bufnr = bufnr('test_buffer') + call assert_equal(['hello'], getbufline(bufnr, 1, '$')) + call assert_equal('nofile', getbufvar(bufnr, '&buftype')) + call assert_equal('hide', getbufvar(bufnr, '&bufhidden')) + bdel test_buffer + call assert_equal([], getbufline(bufnr, 1, '$')) + + let job = job_start('echo hello', {'out_io': 'buffer', 'out_name': 'test_buffer', 'out_msg': 0}) + call WaitForAssert({-> assert_equal("dead", job_status(job))}) + call assert_equal(['hello'], getbufline(bufnr, 1, '$')) + call assert_equal('nofile', getbufvar(bufnr, '&buftype')) + call assert_equal('hide', getbufvar(bufnr, '&bufhidden')) + + bwipe! test_buffer +endfunc + func Test_cmd_parsing() if !has('unix') return |