Use the same formatting as other files for the dogma linter file, and cover the Handler function with tests

This commit is contained in:
w0rp 2017-03-27 12:56:54 +01:00
parent ba97017380
commit 82fde0ea51
2 changed files with 61 additions and 32 deletions

View File

@ -1,44 +1,45 @@
" Author: archseer - https://github.com/archSeer " Author: archseer - https://github.com/archSeer
function! ale_linters#elixir#dogma#Handle(buffer, lines) abort function! ale_linters#elixir#dogma#Handle(buffer, lines) abort
" Matches patterns line the following: " Matches patterns line the following:
" "
" lib/filename.ex:19:7: F: Pipe chain should start with a raw value. " lib/filename.ex:19:7: F: Pipe chain should start with a raw value.
let l:pattern = '\v:(\d+):?(\d+)?: (.): (.+)$' let l:pattern = '\v:(\d+):?(\d+)?: (.): (.+)$'
let l:output = [] let l:output = []
for l:line in a:lines for l:line in a:lines
let l:match = matchlist(l:line, l:pattern) let l:match = matchlist(l:line, l:pattern)
if len(l:match) == 0 if len(l:match) == 0
continue continue
endif endif
let l:type = l:match[3] let l:type = l:match[3]
let l:text = l:match[4] let l:text = l:match[4]
if l:type ==# 'C' if l:type ==# 'C'
let l:type = 'E' let l:type = 'E'
elseif l:type ==# 'R' elseif l:type ==# 'R'
let l:type = 'W' let l:type = 'W'
endif endif
" vcol is Needed to indicate that the column is a character. " vcol is Needed to indicate that the column is a character.
call add(l:output, { call add(l:output, {
\ 'bufnr': a:buffer, \ 'bufnr': a:buffer,
\ 'lnum': l:match[1] + 0, \ 'lnum': l:match[1] + 0,
\ 'col': l:match[2] + 0, \ 'col': l:match[2] + 0,
\ 'type': l:type, \ 'type': l:type,
\ 'text': l:text, \ 'text': l:text,
\}) \})
endfor endfor
return l:output return l:output
endfunction endfunction
call ale#linter#Define('elixir', { call ale#linter#Define('elixir', {
\ 'name': 'dogma', \ 'name': 'dogma',
\ 'executable': 'mix', \ 'executable': 'mix',
\ 'command': 'mix dogma %s --format=flycheck', \ 'command': 'mix dogma %s --format=flycheck',
\ 'lint_file': 1, \ 'lint_file': 1,
\ 'callback': 'ale_linters#elixir#dogma#Handle' }) \ 'callback': 'ale_linters#elixir#dogma#Handle',
\})

View File

@ -0,0 +1,28 @@
Execute(The dogma handler should parse lines correctly):
runtime ale_linters/elixir/dogma.vim
AssertEqual
\ [
\ {
\ 'bufnr': 347,
\ 'lnum': 18,
\ 'col': 5,
\ 'text': 'Some error',
\ 'type': 'E',
\ },
\ {
\ 'bufnr': 347,
\ 'lnum': 19,
\ 'col': 7,
\ 'text': 'Some warning',
\ 'type': 'W',
\ },
\ ],
\ ale_linters#elixir#dogma#Handle(347, [
\ 'This line should be ignored completely',
\ 'lib/filename.ex:18:5: C: Some error',
\ 'lib/filename.ex:19:7: R: Some warning',
\ ])
After:
call ale#linter#Reset()