Mercurial > vim
view src/testdir/summarize.vim @ 33189:c41b1cac349b v9.0.1874
patch 9.0.1874: CI may fail in test_recover_empty_swap
Commit: https://github.com/vim/vim/commit/1c7397f3f1e168541f88bb1bbd93a9f0b1235852
Author: Christian Brabandt <cb@256bit.org>
Date: Tue Sep 5 20:40:25 2023 +0200
patch 9.0.1874: CI may fail in test_recover_empty_swap
Problem: CI may fail in test_recover_empty_swap
Solution: Set directory option
Fix failing Test_recover_empty_swap test
:recover by default not only looks in the current directory, but also in
~/tmp for files to recover. If it finds some files to recover, it will
interactively prompt for a file to recover. However, prompting doesn't
work when running the test suite (and even if it would, there is no one
that can answer the prompt).
So it doesn't really make sense during testing, to inspect different
directories for swap files and prompt and wait (which will lead to a
timeout and therefore a failing test).
So set the 'directory' option temporarily to the current directory only
and reset it back once the test finishes.
closes: #13038
Signed-off-by: Christian Brabandt <cb@256bit.org>
author | Christian Brabandt <cb@256bit.org> |
---|---|
date | Tue, 05 Sep 2023 20:45:03 +0200 |
parents | dbec60b8c253 |
children |
line wrap: on
line source
set cpo&vim if 1 " This is executed only with the eval feature set nocompatible set viminfo= func Count(match, type) if a:type ==# 'executed' let g:executed += (a:match+0) elseif a:type ==# 'failed' let g:failed += a:match+0 elseif a:type ==# 'skipped' let g:skipped += 1 call extend(g:skipped_output, ["\t" .. a:match]) endif endfunc let g:executed = 0 let g:skipped = 0 let g:failed = 0 let g:skipped_output = [] let g:failed_output = [] let output = [""] if $TEST_FILTER != '' call extend(g:skipped_output, ["\tAll tests not matching $TEST_FILTER: '" .. $TEST_FILTER .. "'"]) endif try " This uses the :s command to just fetch and process the output of the " tests, it doesn't actually replace anything. " And it uses "silent" to avoid reporting the number of matches. silent %s/Executed\s\+\zs\d\+\ze\s\+tests\?/\=Count(submatch(0),'executed')/egn silent %s/^SKIPPED \zs.*/\=Count(submatch(0), 'skipped')/egn silent %s/^\(\d\+\)\s\+FAILED:/\=Count(submatch(1), 'failed')/egn call extend(output, ["Skipped:"]) call extend(output, skipped_output) call extend(output, [ \ "", \ "-------------------------------", \ printf("Executed: %5d Tests", g:executed), \ printf(" Skipped: %5d Tests", g:skipped), \ printf(" %s: %5d Tests", g:failed == 0 ? 'Failed' : 'FAILED', g:failed), \ "", \ ]) if filereadable('test.log') " outputs and indents the failed test result call extend(output, ["", "Failures: "]) let failed_output = filter(readfile('test.log'), { v,k -> !empty(k)}) call extend(output, map(failed_output, { v,k -> "\t".k})) " Add a final newline call extend(output, [""]) endif catch " Catch-all finally call writefile(output, 'test_result.log') " overwrites an existing file endtry endif q!