summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorw0rp <devw0rp@gmail.com>2019-05-13 21:57:44 +0100
committerw0rp <devw0rp@gmail.com>2019-05-13 21:57:44 +0100
commit07b596efb52ef56dda212777c30bad58269ce6d9 (patch)
treea0941f64f6d156ce3a58cac1a1bb6e83a4ee8623
parent70604828fa8a6713f1e7db2e4e58d44f9099ac87 (diff)
downloadale-07b596efb52ef56dda212777c30bad58269ce6d9.zip
Close #791 - Handle exceptions for puglint
-rw-r--r--ale_linters/pug/puglint.vim16
-rw-r--r--test/handler/test_puglint_handler.vader45
2 files changed, 60 insertions, 1 deletions
diff --git a/ale_linters/pug/puglint.vim b/ale_linters/pug/puglint.vim
index c4e0e233..c819cc45 100644
--- a/ale_linters/pug/puglint.vim
+++ b/ale_linters/pug/puglint.vim
@@ -31,6 +31,20 @@ function! ale_linters#pug#puglint#GetCommand(buffer) abort
\ . ' -r inline %t'
endfunction
+function! ale_linters#pug#puglint#Handle(buffer, lines) abort
+ for l:line in a:lines[:10]
+ if l:line =~# '^SyntaxError: '
+ return [{
+ \ 'lnum': 1,
+ \ 'text': 'puglint configuration error (type :ALEDetail for more information)',
+ \ 'detail': join(a:lines, "\n"),
+ \}]
+ endif
+ endfor
+
+ return ale#handlers#unix#HandleAsError(a:buffer, a:lines)
+endfunction
+
call ale#linter#Define('pug', {
\ 'name': 'puglint',
\ 'executable': {b -> ale#node#FindExecutable(b, 'pug_puglint', [
@@ -38,5 +52,5 @@ call ale#linter#Define('pug', {
\ ])},
\ 'output_stream': 'stderr',
\ 'command': function('ale_linters#pug#puglint#GetCommand'),
-\ 'callback': 'ale#handlers#unix#HandleAsError',
+\ 'callback': 'ale_linters#pug#puglint#Handle',
\})
diff --git a/test/handler/test_puglint_handler.vader b/test/handler/test_puglint_handler.vader
new file mode 100644
index 00000000..f37518bb
--- /dev/null
+++ b/test/handler/test_puglint_handler.vader
@@ -0,0 +1,45 @@
+Before:
+ runtime ale_linters/pug/puglint.vim
+
+After:
+ call ale#linter#Reset()
+
+Execute(Regular errors should be handled):
+ AssertEqual
+ \ [
+ \ {
+ \ 'lnum': 1,
+ \ 'col': 5,
+ \ 'type': 'E',
+ \ 'text': 'Static attribute "class" must be written as class literal',
+ \ },
+ \ ],
+ \ ale_linters#pug#puglint#Handle(0, [
+ \ '/tmp/vwYwsJA/233/test.pug:1:5 Static attribute "class" must be written as class literal',
+ \ ])
+
+Execute(syntax errors in the configuration file should be handled):
+ AssertEqual
+ \ [
+ \ {
+ \ 'lnum': 1,
+ \ 'text': 'puglint configuration error (type :ALEDetail for more information)',
+ \ 'detail': join(
+ \ [
+ \ 'undefined:2',
+ \ ' disallowClassAttributeWithStaticValue: true',
+ \ ' ^',
+ \ 'SyntaxError: Unexpected token d in JSON at position 4',
+ \ ' at JSON.parse (<anonymous>)',
+ \ ],
+ \ "\n"
+ \ ),
+ \ },
+ \ ],
+ \ ale_linters#pug#puglint#Handle(0, [
+ \ 'undefined:2',
+ \ ' disallowClassAttributeWithStaticValue: true',
+ \ ' ^',
+ \ 'SyntaxError: Unexpected token d in JSON at position 4',
+ \ ' at JSON.parse (<anonymous>)',
+ \ ])