From 5052eca5cb59389275ff1341525214228bad324a Mon Sep 17 00:00:00 2001 From: Horacio Sanson Date: Tue, 11 Dec 2018 23:44:06 +0900 Subject: [PATCH] Add tests to lacheck linter --- ale_linters/tex/lacheck.vim | 2 +- .../test_tex_lacheck_command_callback.vader | 13 +++++++ test/command_callback/tex_paths/sample1.tex | 0 test/command_callback/tex_paths/sample2.tex | 0 test/handler/test_lacheck_handler.vader | 36 +++++++++++++++++++ 5 files changed, 50 insertions(+), 1 deletion(-) create mode 100644 test/command_callback/test_tex_lacheck_command_callback.vader create mode 100644 test/command_callback/tex_paths/sample1.tex create mode 100644 test/command_callback/tex_paths/sample2.tex create mode 100644 test/handler/test_lacheck_handler.vader diff --git a/ale_linters/tex/lacheck.vim b/ale_linters/tex/lacheck.vim index 1d615c59..ee09fb41 100644 --- a/ale_linters/tex/lacheck.vim +++ b/ale_linters/tex/lacheck.vim @@ -21,7 +21,7 @@ function! ale_linters#tex#lacheck#Handle(buffer, lines) abort " lacheck follows `\input{}` commands. We are only interested in " reporting errors for the current buffer only. - if empty(matchstr(fnamemodify(l:match[1], ':t'), bufname(a:buffer))) + if empty(matchstr(fnamemodify(l:match[1], ':t'), fnamemodify(bufname(a:buffer), ':t'))) continue endif diff --git a/test/command_callback/test_tex_lacheck_command_callback.vader b/test/command_callback/test_tex_lacheck_command_callback.vader new file mode 100644 index 00000000..b404cc78 --- /dev/null +++ b/test/command_callback/test_tex_lacheck_command_callback.vader @@ -0,0 +1,13 @@ +Before: + call ale#assert#SetUpLinterTest('tex', 'lacheck') + +After: + call ale#assert#TearDownLinterTest() + +Execute(Executable should default to lacheck): + AssertLinter 'lacheck', ale#Escape('lacheck') . ' %t' + +Execute(Should be able to set a custom executable): + let g:ale_tex_lacheck_executable = 'bin/foo' + + AssertLinter 'bin/foo' , ale#Escape('bin/foo') . ' %t' diff --git a/test/command_callback/tex_paths/sample1.tex b/test/command_callback/tex_paths/sample1.tex new file mode 100644 index 00000000..e69de29b diff --git a/test/command_callback/tex_paths/sample2.tex b/test/command_callback/tex_paths/sample2.tex new file mode 100644 index 00000000..e69de29b diff --git a/test/handler/test_lacheck_handler.vader b/test/handler/test_lacheck_handler.vader new file mode 100644 index 00000000..0bcc3be8 --- /dev/null +++ b/test/handler/test_lacheck_handler.vader @@ -0,0 +1,36 @@ +Before: + runtime ale_linters/tex/lacheck.vim + call ale#test#SetDirectory('/testplugin/test') + +After: + call ale#linter#Reset() + call ale#test#RestoreDirectory() + +Execute(The lacheck handler should parse lines correctly): + + call ale#test#SetFilename('command_callback/tex_paths/sample1.tex') + + AssertEqual + \ [ + \ { + \ 'lnum': 1, + \ 'type': 'W', + \ 'text': 'perhaps you should insert a `~'' before "\ref"' + \ } + \ ], + \ ale_linters#tex#lacheck#Handle(bufnr(''), [ + \ "** sample1:", + \ "\"sample1.tex\", line 1: perhaps you should insert a `~' before \"\\ref\"" + \ ]) + +Execute(The lacheck handler should ignore errors from input files): + + call ale#test#SetFilename('ale_test.tex') + + AssertEqual + \ [ + \ ], + \ ale_linters#tex#lacheck#Handle(255, [ + \ "** ale_input:", + \ "\"ale_input.tex\", line 1: perhaps you should insert a `~' before \"\\ref\"" + \ ])