]> granicus.if.org Git - vim/commitdiff
patch 8.1.0003: the :compiler command is not tested v8.1.0003
authorBram Moolenaar <Bram@vim.org>
Sat, 19 May 2018 13:01:10 +0000 (15:01 +0200)
committerBram Moolenaar <Bram@vim.org>
Sat, 19 May 2018 13:01:10 +0000 (15:01 +0200)
Problem:    The :compiler command is not tested.
Solution:   Add a test. (Dominique Pelle, closes #2930)

src/Makefile
src/testdir/test_alot.vim
src/testdir/test_compiler.vim [new file with mode: 0644]
src/version.c

index 98fd14220ba0770162c36377de98b903760216b1..0e4c55562751dc6e7631531e5db702dad18dff25 100644 (file)
@@ -2150,6 +2150,7 @@ test_arglist \
        test_cmdline \
        test_command_count \
        test_comparators \
+       test_compiler \
        test_crypt \
        test_cscope \
        test_cursor_func \
index b8a56502b150d5ce41ccb770d90e64ab5f03cdeb..ac3ca74f53add9688a4b8109bca53f64c6209fb1 100644 (file)
@@ -5,6 +5,7 @@ source test_assign.vim
 source test_bufline.vim
 source test_cd.vim
 source test_changedtick.vim
+source test_compiler.vim
 source test_cursor_func.vim
 source test_delete.vim
 source test_ex_undo.vim
diff --git a/src/testdir/test_compiler.vim b/src/testdir/test_compiler.vim
new file mode 100644 (file)
index 0000000..fd3510d
--- /dev/null
@@ -0,0 +1,50 @@
+" Test the :compiler command
+
+func Test_compiler()
+  if !executable('perl')
+    return
+  endif
+
+  e Xfoo.pl
+  compiler perl
+  call assert_equal('perl', b:current_compiler)
+  call assert_fails('let g:current_compiler', 'E121:')
+
+  call setline(1, ['#!/usr/bin/perl -w', 'use strict;', 'my $foo=1'])
+  w!
+  call feedkeys(":make\<CR>\<CR>", 'tx')
+  call assert_fails('clist', 'E42:')
+
+  call setline(1, ['#!/usr/bin/perl -w', 'use strict;', '$foo=1'])
+  w!
+  call feedkeys(":make\<CR>\<CR>", 'tx')
+  let a=execute('clist')
+  call assert_equal("\n 1 Xfoo.pl:3: Global symbol \"\$foo\" "
+  \ .               "requires explicit package name "
+  \ .               "(did you forget to declare \"my $foo\"?)", a)
+
+  call delete('Xfoo.pl')
+  bw!
+endfunc
+
+func Test_compiler_without_arg()
+  let a=split(execute('compiler'))
+  call assert_equal($VIMRUNTIME . '/compiler/ant.vim',   a[0])
+  call assert_equal($VIMRUNTIME . '/compiler/bcc.vim',   a[1])
+  call assert_equal($VIMRUNTIME . '/compiler/xmlwf.vim', a[-1])
+endfunc
+
+func Test_compiler_completion()
+  call feedkeys(":compiler \<C-A>\<C-B>\"\<CR>", 'tx')
+  call assert_match('^"compiler ant bcc .* xmlwf$', @:)
+
+  call feedkeys(":compiler p\<C-A>\<C-B>\"\<CR>", 'tx')
+  call assert_equal('"compiler pbx perl php pylint pyunit', @:)
+
+  call feedkeys(":compiler! p\<C-A>\<C-B>\"\<CR>", 'tx')
+  call assert_equal('"compiler! pbx perl php pylint pyunit', @:)
+endfunc
+
+func Test_compiler_error()
+  call assert_fails('compiler doesnotexist', 'E666:')
+endfunc
index 9d92ef8cdeba1742c7d0ecf84b0a5dc111107c41..9ceabc7bfc9fe99aa873ad6688ff1a58adf4734c 100644 (file)
@@ -761,6 +761,8 @@ static char *(features[]) =
 
 static int included_patches[] =
 {   /* Add new patch number below this line */
+/**/
+    3,
 /**/
     2,
 /**/