Skip to content

Commit f267f8b

Browse files
committed
patch 7.4.2240
Problem: Tests using the sleep time can be flaky. Solution: Use reltime() if available. (Partly by Shane Harper)
1 parent 9baf297 commit f267f8b

3 files changed

Lines changed: 37 additions & 7 deletions

File tree

src/testdir/shared.vim

Lines changed: 15 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -109,19 +109,31 @@ func s:kill_server(cmd)
109109
endfunc
110110

111111
" Wait for up to a second for "expr" to become true.
112-
" Return time slept in milliseconds.
112+
" Return time slept in milliseconds. With the +reltime feature this can be
113+
" more than the actual waiting time. Without +reltime it can also be less.
113114
func WaitFor(expr)
114-
let slept = 0
115+
" using reltime() is more accurate, but not always available
116+
if has('reltime')
117+
let start = reltime()
118+
else
119+
let slept = 0
120+
endif
115121
for i in range(100)
116122
try
117123
if eval(a:expr)
124+
if has('reltime')
125+
return float2nr(reltimefloat(reltime(start)) * 1000)
126+
endif
118127
return slept
119128
endif
120129
catch
121130
endtry
122-
let slept += 10
131+
if !has('reltime')
132+
let slept += 10
133+
endif
123134
sleep 10m
124135
endfor
136+
return 1000
125137
endfunc
126138

127139
" Run Vim, using the "vimcmd" file and "-u NORC".

src/testdir/test_timers.vim

Lines changed: 20 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -19,15 +19,23 @@ func Test_oneshot()
1919
let timer = timer_start(50, 'MyHandler')
2020
let slept = WaitFor('g:val == 1')
2121
call assert_equal(1, g:val)
22-
call assert_inrange(30, 100, slept)
22+
if has('reltime')
23+
call assert_inrange(50, 100, slept)
24+
else
25+
call assert_inrange(20, 100, slept)
26+
endif
2327
endfunc
2428

2529
func Test_repeat_three()
2630
let g:val = 0
2731
let timer = timer_start(50, 'MyHandler', {'repeat': 3})
2832
let slept = WaitFor('g:val == 3')
2933
call assert_equal(3, g:val)
30-
call assert_inrange(80, 200, slept)
34+
if has('reltime')
35+
call assert_inrange(150, 200, slept)
36+
else
37+
call assert_inrange(80, 200, slept)
38+
endif
3139
endfunc
3240

3341
func Test_repeat_many()
@@ -48,7 +56,11 @@ func Test_with_partial_callback()
4856
call timer_start(50, s:meow.bite)
4957
let slept = WaitFor('g:val == 1')
5058
call assert_equal(1, g:val)
51-
call assert_inrange(30, 100, slept)
59+
if has('reltime')
60+
call assert_inrange(50, 100, slept)
61+
else
62+
call assert_inrange(20, 100, slept)
63+
endif
5264
endfunc
5365

5466
func Test_retain_partial()
@@ -109,7 +121,11 @@ func Test_paused()
109121

110122
let slept = WaitFor('g:val == 1')
111123
call assert_equal(1, g:val)
112-
call assert_inrange(0, 10, slept)
124+
if has('reltime')
125+
call assert_inrange(0, 30, slept)
126+
else
127+
call assert_inrange(0, 10, slept)
128+
endif
113129
endfunc
114130

115131
" vim: shiftwidth=2 sts=2 expandtab

src/version.c

Lines changed: 2 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -763,6 +763,8 @@ static char *(features[]) =
763763

764764
static int included_patches[] =
765765
{ /* Add new patch number below this line */
766+
/**/
767+
2240,
766768
/**/
767769
2239,
768770
/**/

0 commit comments

Comments
 (0)