summaryrefslogtreecommitdiff
path: root/test
diff options
context:
space:
mode:
authorJeff Willette <jrwillette88@gmail.com>2017-12-05 03:42:36 +0900
committerw0rp <w0rp@users.noreply.github.com>2017-12-04 18:42:36 +0000
commite2a8f759d870ed7a1f0ee4698a73b65e9f36e54d (patch)
treead865d322b60b007449a0e19891342f1bd87b1de /test
parent159733c45998e87c9b15a60112319b5e77c63e65 (diff)
downloadale-e2a8f759d870ed7a1f0ee4698a73b65e9f36e54d.zip
Added option for `gometalinter` to lint package (#1156)
* Added option for `gometalinter` to lint package * added tests for the `gometalinter` command * changed gometalinter commands to use BufferCdString
Diffstat (limited to 'test')
-rw-r--r--test/command_callback/test_gometalinter_command_callback.vader32
-rw-r--r--test/handler/test_gometalinter_handler.vader12
2 files changed, 30 insertions, 14 deletions
diff --git a/test/command_callback/test_gometalinter_command_callback.vader b/test/command_callback/test_gometalinter_command_callback.vader
index 912396cb..93a541c8 100644
--- a/test/command_callback/test_gometalinter_command_callback.vader
+++ b/test/command_callback/test_gometalinter_command_callback.vader
@@ -1,9 +1,11 @@
Before:
Save b:ale_go_gometalinter_executable
Save b:ale_go_gometalinter_options
+ Save b:ale_go_gometalinter_lint_package
let b:ale_go_gometalinter_executable = 'gometalinter'
let b:ale_go_gometalinter_options = ''
+ let b:ale_go_gometalinter_lint_package = 0
runtime ale_linters/go/gometalinter.vim
@@ -21,9 +23,10 @@ Execute(The gometalinter callback should return the right defaults):
\ 'gometalinter',
\ ale_linters#go#gometalinter#GetExecutable(bufnr(''))
AssertEqual
- \ ale#Escape('gometalinter')
- \ . ' --include=' . ale#Escape('^' . ale#util#EscapePCRE(expand('%')))
- \ . ' ' . ale#Escape(getcwd()),
+ \ 'cd ' . ale#Escape(expand('%:p:h')) . ' && '
+ \ . ale#Escape('gometalinter')
+ \ . ' --include=' . ale#Escape(ale#util#EscapePCRE(expand('%' . ':t')))
+ \ . ' .',
\ ale_linters#go#gometalinter#GetCommand(bufnr(''))
Execute(The gometalinter callback should use a configured executable):
@@ -33,17 +36,26 @@ Execute(The gometalinter callback should use a configured executable):
\ 'something else',
\ ale_linters#go#gometalinter#GetExecutable(bufnr(''))
AssertEqual
- \ ale#Escape('something else')
- \ . ' --include=' . ale#Escape('^' . ale#util#EscapePCRE(expand('%')))
- \ . ' ' . ale#Escape(getcwd()),
+ \ 'cd ' . ale#Escape(expand('%:p:h')) . ' && '
+ \ . ale#Escape('something else')
+ \ . ' --include=' . ale#Escape(ale#util#EscapePCRE(expand('%' . ':t')))
+ \ . ' .',
\ ale_linters#go#gometalinter#GetCommand(bufnr(''))
Execute(The gometalinter callback should use configured options):
let b:ale_go_gometalinter_options = '--foobar'
AssertEqual
- \ ale#Escape('gometalinter')
- \ . ' --include=' . ale#Escape('^' . ale#util#EscapePCRE(expand('%')))
- \ . ' --foobar'
- \ . ' ' . ale#Escape(getcwd()),
+ \ 'cd ' . ale#Escape(expand('%:p:h')) . ' && '
+ \ . ale#Escape('gometalinter')
+ \ . ' --include=' . ale#Escape(ale#util#EscapePCRE(expand('%' . ':t')))
+ \ . ' --foobar' . ' .',
+ \ ale_linters#go#gometalinter#GetCommand(bufnr(''))
+
+Execute(The gometalinter `lint_package` option should use the correct command):
+ let b:ale_go_gometalinter_lint_package = 1
+
+ AssertEqual
+ \ 'cd ' . ale#Escape(expand('%:p:h')) . ' && '
+ \ . ale#Escape('gometalinter') . ' .',
\ ale_linters#go#gometalinter#GetCommand(bufnr(''))
diff --git a/test/handler/test_gometalinter_handler.vader b/test/handler/test_gometalinter_handler.vader
index 603ba22d..703040e2 100644
--- a/test/handler/test_gometalinter_handler.vader
+++ b/test/handler/test_gometalinter_handler.vader
@@ -29,8 +29,10 @@ Execute (The gometalinter handler should handle names with spaces):
\ 'C:\something\file with spaces.go:37:5:error: expected ''package'', found ''IDENT'' gibberish (golint)',
\ ]), 'v:val[1:5]')
-Execute (The gometalinter handler should handle relative paths correctly):
- silent file /foo/bar/baz.go
+Execute (The gometalinter handler should handle paths correctly):
+ call ale#test#SetFilename('app/test.go')
+
+ let file = ale#path#GetAbsPath(expand('%:p:h'), 'test.go')
AssertEqual
\ [
@@ -39,15 +41,17 @@ Execute (The gometalinter handler should handle relative paths correctly):
\ 'col': 3,
\ 'text': 'expected ''package'', found ''IDENT'' gibberish (staticcheck)',
\ 'type': 'W',
+ \ 'filename': ale#path#Winify(expand('%:p:h') . '/test.go'),
\ },
\ {
\ 'lnum': 37,
\ 'col': 5,
\ 'text': 'expected ''package'', found ''IDENT'' gibberish (golint)',
\ 'type': 'E',
+ \ 'filename': ale#path#Winify(expand('%:p:h') . '/test.go'),
\ },
\ ],
\ ale_linters#go#gometalinter#Handler(bufnr(''), [
- \ 'baz.go:12:3:warning: expected ''package'', found ''IDENT'' gibberish (staticcheck)',
- \ 'baz.go:37:5:error: expected ''package'', found ''IDENT'' gibberish (golint)',
+ \ file . ':12:3:warning: expected ''package'', found ''IDENT'' gibberish (staticcheck)',
+ \ file . ':37:5:error: expected ''package'', found ''IDENT'' gibberish (golint)',
\ ])