view src/testdir/test_terminal_fail.vim @ 12407:e9dbdc4d8279 v8.0.1083

patch 8.0.1083: leaking memory in input part of channel commit https://github.com/vim/vim/commit/5b5adf5b9cd226d775643872e65c62674d6ada95 Author: Bram Moolenaar <Bram@vim.org> Date: Sat Sep 9 18:16:43 2017 +0200 patch 8.0.1083: leaking memory in input part of channel Problem: Leaking memory in input part of channel. Solution: Clear the input part of channel. Free the entry. Move failing command test to a separate file to avoid bogus leak reports clouding tests that should not leak.
author Christian Brabandt <cb@256bit.org>
date Sat, 09 Sep 2017 18:30:05 +0200
parents
children f38fcbf343ce
line wrap: on
line source

" This test is in a separate file, because it usually causes reports for memory
" leaks under valgrind.  That is because when fork/exec fails memory is not
" freed.  Since the process exists right away it's not a real leak.

if !has('terminal')
  finish
endif

source shared.vim

func Test_terminal_redir_fails()
  if has('unix')
    let buf = term_start('xyzabc', {'err_io': 'file', 'err_name': 'Xfile'})
    call term_wait(buf)
    call WaitFor('len(readfile("Xfile")) > 0')
    call assert_match('executing job failed', readfile('Xfile')[0])
    call WaitFor('!&modified')
    call delete('Xfile')
    bwipe
  endif
endfunc