From af23d173883f47fd02a9a380c719e4428370b484 Mon Sep 17 00:00:00 2001 From: dundargoc <33953936+dundargoc@users.noreply.github.com> Date: Tue, 7 Mar 2023 04:13:04 +0100 Subject: test: move oldtests to test directory (#22536) The new oldtest directory is in test/old/testdir. The reason for this is that many tests have hardcoded the parent directory name to be 'testdir'. --- test/old/testdir/test_compiler.vim | 78 ++++++++++++++++++++++++++++++++++++++ 1 file changed, 78 insertions(+) create mode 100644 test/old/testdir/test_compiler.vim (limited to 'test/old/testdir/test_compiler.vim') diff --git a/test/old/testdir/test_compiler.vim b/test/old/testdir/test_compiler.vim new file mode 100644 index 0000000000..ec7d143030 --- /dev/null +++ b/test/old/testdir/test_compiler.vim @@ -0,0 +1,78 @@ +" Test the :compiler command + +source check.vim +source shared.vim + +func Test_compiler() + CheckExecutable perl + CheckFeature quickfix + + " $LANG changes the output of Perl. + if $LANG != '' + unlet $LANG + endif + + " %:S does not work properly with 'shellslash' set + let save_shellslash = &shellslash + set noshellslash + + e Xfoo.pl + compiler perl + call assert_equal('perl', b:current_compiler) + call assert_fails('let g:current_compiler', 'E121:') + + let verbose_efm = execute('verbose set efm') + call assert_match('Last set from .*[/\\]compiler[/\\]perl.vim ', verbose_efm) + + call setline(1, ['#!/usr/bin/perl -w', 'use strict;', 'my $foo=1']) + w! + call feedkeys(":make\\", 'tx') + call assert_fails('clist', 'E42:') + + call setline(1, ['#!/usr/bin/perl -w', 'use strict;', '$foo=1']) + w! + call feedkeys(":make\\", 'tx') + let a=execute('clist') + call assert_match('\n \d\+ Xfoo.pl:3: Global symbol "$foo" ' + \ . 'requires explicit package name', a) + + + let &shellslash = save_shellslash + call delete('Xfoo.pl') + bw! +endfunc + +func GetCompilerNames() + return glob('$VIMRUNTIME/compiler/*.vim', 0, 1) + \ ->map({i, v -> substitute(v, '.*[\\/]\([a-zA-Z0-9_\-]*\).vim', '\1', '')}) + \ ->sort() +endfunc + +func Test_compiler_without_arg() + let runtime = substitute($VIMRUNTIME, '\\', '/', 'g') + let a = split(execute('compiler')) + let exp = GetCompilerNames() + call assert_match(runtime .. '/compiler/' .. exp[0] .. '.vim$', a[0]) + call assert_match(runtime .. '/compiler/' .. exp[1] .. '.vim$', a[1]) + call assert_match(runtime .. '/compiler/' .. exp[-1] .. '.vim$', a[-1]) +endfunc + +func Test_compiler_completion() + let clist = GetCompilerNames()->join(' ') + call feedkeys(":compiler \\\"\", 'tx') + call assert_match('^"compiler ' .. clist .. '$', @:) + + call feedkeys(":compiler p\\\"\", 'tx') + call assert_match('"compiler pbx perl\( p[a-z]\+\)\+ pylint pyunit', @:) + + call feedkeys(":compiler! p\\\"\", 'tx') + call assert_match('"compiler! pbx perl\( p[a-z]\+\)\+ pylint pyunit', @:) +endfunc + +func Test_compiler_error() + let g:current_compiler = 'abc' + call assert_fails('compiler doesnotexist', 'E666:') + call assert_equal('abc', g:current_compiler) + call assert_fails('compiler! doesnotexist', 'E666:') + unlet! g:current_compiler +endfunc -- cgit From 8728ba3951a67b293feeefe29b5ccd757d11c42f Mon Sep 17 00:00:00 2001 From: zeertzjq Date: Mon, 25 Sep 2023 05:47:55 +0800 Subject: vim-patch:9.0.1931: make test_compilers fails on ubuntu MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Problem: make test_compilers fails on ubuntu Solution: set LC_ALL=C fix: make test_compiler failed on xubuntu 22.04.3 Problem: 'make test_compiler' failed on Linux xubuntu 22.04.3 but succeeded on e.g. macOS. To reproduce: ``` $ ./configure --with-features=huge --enable-gui=no --enable-perlinterp=yes $ make -j12 $ cd vim/src/testdir $ make test_compiler ...snip... Found errors in Test_compiler(): command line..script /home/dope/sb/vim/src/testdir/runtest.vim[601]..function RunTheTest[54]..Test_compiler line 24: command did not fail: clist command line..script /home/dope/sb/vim/src/testdir/runtest.vim[601]..function RunTheTest[54]..Test_compiler line 30: Pattern '\\n \\d\\+ Xfoo.pl:3: Global symbol "$foo" requires explicit package name' does not match '\n19 Xfoo.pl:3: Global symbol "$foo" requires explicit package name (did you forget to declare "my $foo"?)' make: *** [Makefile:70: test_compiler] Error 1 ``` Solution: set `LC_ALL` to "C" in `Test_compiler()` closes: vim/vim#13173 https://github.com/vim/vim/commit/ca0ffc0d63727850c520a80929698e4c199b17f4 Co-authored-by: Dominique Pellé --- test/old/testdir/test_compiler.vim | 11 +++++------ 1 file changed, 5 insertions(+), 6 deletions(-) (limited to 'test/old/testdir/test_compiler.vim') diff --git a/test/old/testdir/test_compiler.vim b/test/old/testdir/test_compiler.vim index ec7d143030..0b22bafabb 100644 --- a/test/old/testdir/test_compiler.vim +++ b/test/old/testdir/test_compiler.vim @@ -7,10 +7,8 @@ func Test_compiler() CheckExecutable perl CheckFeature quickfix - " $LANG changes the output of Perl. - if $LANG != '' - unlet $LANG - endif + let save_LC_ALL = $LC_ALL + let $LC_ALL= "C" " %:S does not work properly with 'shellslash' set let save_shellslash = &shellslash @@ -40,12 +38,13 @@ func Test_compiler() let &shellslash = save_shellslash call delete('Xfoo.pl') bw! + let $LC_ALL = save_LC_ALL endfunc func GetCompilerNames() return glob('$VIMRUNTIME/compiler/*.vim', 0, 1) - \ ->map({i, v -> substitute(v, '.*[\\/]\([a-zA-Z0-9_\-]*\).vim', '\1', '')}) - \ ->sort() + \ ->map({i, v -> substitute(v, '.*[\\/]\([a-zA-Z0-9_\-]*\).vim', '\1', '')}) + \ ->sort() endfunc func Test_compiler_without_arg() -- cgit