mirror of
https://github.com/vim/vim.git
synced 2025-10-02 05:04:20 -04:00
patch 8.2.2169: Vim9: test leaves file behind
Problem: Vim9: test leaves file behind. Solution: Rename script files. (Dominique Pellé, closes #7511) Use try/finally.
This commit is contained in:
@@ -2412,7 +2412,7 @@ def Test_vim9_comment()
|
||||
'delcommand Echo',
|
||||
])
|
||||
CheckScriptSuccess([
|
||||
'vim9script'
|
||||
'vim9script',
|
||||
'command Echo cd # comment',
|
||||
'Echo',
|
||||
'delcommand Echo',
|
||||
@@ -2949,6 +2949,7 @@ def Test_restoring_cpo()
|
||||
endif
|
||||
delete('Xsourced')
|
||||
delete('Xclose')
|
||||
delete('Xdone')
|
||||
enddef
|
||||
|
||||
|
||||
|
@@ -5,13 +5,18 @@ let s:sequence = 1
|
||||
|
||||
" Check that "lines" inside a ":def" function has no error.
|
||||
func CheckDefSuccess(lines)
|
||||
let fname = 'Xdef' .. s:sequence
|
||||
let cwd = getcwd()
|
||||
let fname = 'XdefSuccess' .. s:sequence
|
||||
let s:sequence += 1
|
||||
call writefile(['def Func()'] + a:lines + ['enddef', 'defcompile'], fname)
|
||||
try
|
||||
exe 'so ' .. fname
|
||||
call Func()
|
||||
delfunc! Func
|
||||
finally
|
||||
call chdir(cwd)
|
||||
call delete(fname)
|
||||
endtry
|
||||
endfunc
|
||||
|
||||
" Check that "lines" inside ":def" results in an "error" message.
|
||||
@@ -19,12 +24,17 @@ endfunc
|
||||
" Add a line before and after to make it less likely that the line number is
|
||||
" accidentally correct.
|
||||
func CheckDefFailure(lines, error, lnum = -3)
|
||||
let fname = 'Xdef' .. s:sequence
|
||||
call writefile(['def Func()', '# comment'] + a:lines + ['#comment', 'enddef', 'defcompile'], fname)
|
||||
call assert_fails('so ' .. fname, a:error, a:lines, a:lnum + 1)
|
||||
delfunc! Func
|
||||
call delete(fname)
|
||||
let cwd = getcwd()
|
||||
let fname = 'XdefFailure' .. s:sequence
|
||||
let s:sequence += 1
|
||||
call writefile(['def Func()', '# comment'] + a:lines + ['#comment', 'enddef', 'defcompile'], fname)
|
||||
try
|
||||
call assert_fails('so ' .. fname, a:error, a:lines, a:lnum + 1)
|
||||
finally
|
||||
call chdir(cwd)
|
||||
call delete(fname)
|
||||
delfunc! Func
|
||||
endtry
|
||||
endfunc
|
||||
|
||||
" Check that "lines" inside ":def" results in an "error" message when executed.
|
||||
@@ -32,29 +42,44 @@ endfunc
|
||||
" Add a line before and after to make it less likely that the line number is
|
||||
" accidentally correct.
|
||||
func CheckDefExecFailure(lines, error, lnum = -3)
|
||||
let fname = 'Xdef' .. s:sequence
|
||||
let cwd = getcwd()
|
||||
let fname = 'XdefExecFailure' .. s:sequence
|
||||
let s:sequence += 1
|
||||
call writefile(['def Func()', '# comment'] + a:lines + ['#comment', 'enddef'], fname)
|
||||
try
|
||||
exe 'so ' .. fname
|
||||
call assert_fails('call Func()', a:error, a:lines, a:lnum + 1)
|
||||
delfunc! Func
|
||||
finally
|
||||
call chdir(cwd)
|
||||
call delete(fname)
|
||||
delfunc! Func
|
||||
endtry
|
||||
endfunc
|
||||
|
||||
def CheckScriptFailure(lines: list<string>, error: string, lnum = -3)
|
||||
var fname = 'Xdef' .. s:sequence
|
||||
var cwd = getcwd()
|
||||
var fname = 'XScriptFailure' .. s:sequence
|
||||
s:sequence += 1
|
||||
writefile(lines, fname)
|
||||
try
|
||||
assert_fails('so ' .. fname, error, lines, lnum)
|
||||
finally
|
||||
chdir(cwd)
|
||||
delete(fname)
|
||||
endtry
|
||||
enddef
|
||||
|
||||
def CheckScriptSuccess(lines: list<string>)
|
||||
var fname = 'Xdef' .. s:sequence
|
||||
var cwd = getcwd()
|
||||
var fname = 'XScriptSuccess' .. s:sequence
|
||||
s:sequence += 1
|
||||
writefile(lines, fname)
|
||||
try
|
||||
exe 'so ' .. fname
|
||||
finally
|
||||
chdir(cwd)
|
||||
delete(fname)
|
||||
endtry
|
||||
enddef
|
||||
|
||||
def CheckDefAndScriptSuccess(lines: list<string>)
|
||||
|
@@ -750,6 +750,8 @@ static char *(features[]) =
|
||||
|
||||
static int included_patches[] =
|
||||
{ /* Add new patch number below this line */
|
||||
/**/
|
||||
2169,
|
||||
/**/
|
||||
2168,
|
||||
/**/
|
||||
|
Reference in New Issue
Block a user