1
0
forked from aniani/vim

patch 8.2.2031: some tests fail when run under valgrind

Problem:    Some tests fail when run under valgrind.
Solution:   Avoid timing problems.
This commit is contained in:
Bram Moolenaar
2020-11-22 14:24:00 +01:00
parent 4b2ce1297e
commit 18dc355395
6 changed files with 30 additions and 18 deletions

View File

@@ -2181,18 +2181,21 @@ func Test_issue_5150()
else else
let cmd = 'grep foo' let cmd = 'grep foo'
endif endif
let g:job = job_start(cmd, {}) let g:job = job_start(cmd, {})
sleep 50m " give the job time to start
call job_stop(g:job) call job_stop(g:job)
sleep 50m call WaitForAssert({-> assert_equal(-1, job_info(g:job).exitval)})
call assert_equal(-1, job_info(g:job).exitval)
let g:job = job_start(cmd, {}) let g:job = job_start(cmd, {})
sleep 50m
call job_stop(g:job, 'term') call job_stop(g:job, 'term')
sleep 50m call WaitForAssert({-> assert_equal(-1, job_info(g:job).exitval)})
call assert_equal(-1, job_info(g:job).exitval)
let g:job = job_start(cmd, {}) let g:job = job_start(cmd, {})
call job_stop(g:job, 'kill')
sleep 50m sleep 50m
call assert_equal(-1, job_info(g:job).exitval) call job_stop(g:job, 'kill')
call WaitForAssert({-> assert_equal(-1, job_info(g:job).exitval)})
endfunc endfunc
func Test_issue_5485() func Test_issue_5485()

View File

@@ -63,8 +63,9 @@ func Test_client_server()
call remote_send(name, ":gui -f\<CR>") call remote_send(name, ":gui -f\<CR>")
endif endif
" Wait for the server to be up and answering requests. " Wait for the server to be up and answering requests.
sleep 100m " When using valgrind this can be very, very slow.
call WaitForAssert({-> assert_true(name->remote_expr("v:version", "", 1) != "")}) sleep 1
call WaitForAssert({-> assert_match('\d', name->remote_expr("v:version", "", 1))}, 10000)
call remote_send(name, ":let testvar = 'maybe'\<CR>") call remote_send(name, ":let testvar = 'maybe'\<CR>")
call WaitForAssert({-> assert_equal('maybe', remote_expr(name, "testvar", "", 2))}) call WaitForAssert({-> assert_equal('maybe', remote_expr(name, "testvar", "", 2))})

View File

@@ -17,14 +17,18 @@ func CheckCWD()
endfunc endfunc
command! -nargs=0 -bar CheckCWD call CheckCWD() command! -nargs=0 -bar CheckCWD call CheckCWD()
" "options" argument can contain:
" 'msec' - time to wait for a match
" 'match' - "pattern" to use "lines" as pattern instead of text
func CheckDbgOutput(buf, lines, options = {}) func CheckDbgOutput(buf, lines, options = {})
" Verify the expected output " Verify the expected output
let lnum = 20 - len(a:lines) let lnum = 20 - len(a:lines)
let msec = get(a:options, 'msec', 1000)
for l in a:lines for l in a:lines
if get(a:options, 'match', 'equal') ==# 'pattern' if get(a:options, 'match', 'equal') ==# 'pattern'
call WaitForAssert({-> assert_match(l, term_getline(a:buf, lnum))}, 200) call WaitForAssert({-> assert_match(l, term_getline(a:buf, lnum))}, msec)
else else
call WaitForAssert({-> assert_equal(l, term_getline(a:buf, lnum))}, 200) call WaitForAssert({-> assert_equal(l, term_getline(a:buf, lnum))}, msec)
endif endif
let lnum += 1 let lnum += 1
endfor endfor
@@ -198,7 +202,7 @@ func Test_Debugger()
" Start a debug session, so that reading the last line from the terminal " Start a debug session, so that reading the last line from the terminal
" works properly. " works properly.
call RunDbgCmd(buf, ':debug echo Foo()') call RunDbgCmd(buf, ':debug echo Foo()', ['cmd: echo Foo()'])
" No breakpoints " No breakpoints
call RunDbgCmd(buf, 'breakl', ['No breakpoints defined']) call RunDbgCmd(buf, 'breakl', ['No breakpoints defined'])
@@ -809,9 +813,10 @@ func Test_Backtrace_CmdLine()
\ '-S Xtest1.vim -c "debug call GlobalFunction()"', \ '-S Xtest1.vim -c "debug call GlobalFunction()"',
\ {'wait_for_ruler': 0}) \ {'wait_for_ruler': 0})
" Need to wait for the vim-in-terminal to be ready " Need to wait for the vim-in-terminal to be ready.
" With valgrind this can take quite long.
call CheckDbgOutput(buf, ['command line', call CheckDbgOutput(buf, ['command line',
\ 'cmd: call GlobalFunction()']) \ 'cmd: call GlobalFunction()'], #{msec: 5000})
" At this point the ontly thing in the stack is the cmdline " At this point the ontly thing in the stack is the cmdline
call RunDbgCmd(buf, 'backtrace', [ call RunDbgCmd(buf, 'backtrace', [
@@ -967,7 +972,7 @@ func Test_debug_backtrace_level()
\ 'Entering Debug mode. Type "cont" to continue.', \ 'Entering Debug mode. Type "cont" to continue.',
\ 'command line..script ' .. file1, \ 'command line..script ' .. file1,
\ 'line 1: let s:file1_var = ''file1''' \ 'line 1: let s:file1_var = ''file1'''
\ ]) \ ], #{msec: 5000})
" step throught the initial declarations " step throught the initial declarations
call RunDbgCmd(buf, 'step', [ 'line 2: let g:global_var = ''global''' ] ) call RunDbgCmd(buf, 'step', [ 'line 2: let g:global_var = ''global''' ] )

View File

@@ -98,8 +98,6 @@ func Do_test_quotestar_for_x11()
" Running in a terminal and the GUI is available: Tell the server to open " Running in a terminal and the GUI is available: Tell the server to open
" the GUI and check that the remote command still works. " the GUI and check that the remote command still works.
" Need to wait for the GUI to start up, otherwise the send hangs in trying
" to send to the terminal window.
if has('gui_athena') || has('gui_motif') if has('gui_athena') || has('gui_motif')
" For those GUIs, ignore the 'failed to create input context' error. " For those GUIs, ignore the 'failed to create input context' error.
call remote_send(name, ":call test_ignore_error('E285') | gui -f\<CR>") call remote_send(name, ":call test_ignore_error('E285') | gui -f\<CR>")
@@ -107,7 +105,10 @@ func Do_test_quotestar_for_x11()
call remote_send(name, ":gui -f\<CR>") call remote_send(name, ":gui -f\<CR>")
endif endif
" Wait for the server in the GUI to be up and answering requests. " Wait for the server in the GUI to be up and answering requests.
" First need to wait for the GUI to start up, otherwise the send hangs in
" trying to send to the terminal window.
" On some systems and with valgrind this can be very slow. " On some systems and with valgrind this can be very slow.
sleep 1
call WaitForAssert({-> assert_match("1", remote_expr(name, "has('gui_running')", "", 1))}, 10000) call WaitForAssert({-> assert_match("1", remote_expr(name, "has('gui_running')", "", 1))}, 10000)
call remote_send(name, ":let @* = 'maybe'\<CR>") call remote_send(name, ":let @* = 'maybe'\<CR>")

View File

@@ -37,7 +37,7 @@ def TestCompilingError()
for i in range(1, 9) for i in range(1, 9)
text ..= term_getline(buf, i) text ..= term_getline(buf, i)
endfor endfor
if text =~ 'Error detected' if text =~ 'Variable not found: nothing'
break break
endif endif
sleep 20m sleep 20m

View File

@@ -750,6 +750,8 @@ static char *(features[]) =
static int included_patches[] = static int included_patches[] =
{ /* Add new patch number below this line */ { /* Add new patch number below this line */
/**/
2031,
/**/ /**/
2030, 2030,
/**/ /**/