summaryrefslogtreecommitdiff
path: root/test
diff options
context:
space:
mode:
authorw0rp <devw0rp@gmail.com>2021-05-27 22:03:39 +0100
committerw0rp <devw0rp@gmail.com>2021-05-27 22:03:46 +0100
commit1b08791228f5aca4545a3fba6699b29a003028fe (patch)
tree42cb78fe66f93100217ecb1230c269c26d58db1b /test
parenta02a4f2811f810877f3c3859cca963f9578ff94a (diff)
downloadale-1b08791228f5aca4545a3fba6699b29a003028fe.zip
Make staticcheck configurable with GOPATH detection
Diffstat (limited to 'test')
-rw-r--r--test/linter/test_staticcheck.vader24
-rw-r--r--test/test-files/go/gopath/bin/staticcheck0
2 files changed, 19 insertions, 5 deletions
diff --git a/test/linter/test_staticcheck.vader b/test/linter/test_staticcheck.vader
index 993d9491..d690ebd0 100644
--- a/test/linter/test_staticcheck.vader
+++ b/test/linter/test_staticcheck.vader
@@ -1,5 +1,8 @@
Before:
Save g:ale_go_go111module
+ Save $GOPATH
+
+ let $GOPATH = '/non/existent/directory'
call ale#assert#SetUpLinterTest('go', 'staticcheck')
call ale#test#SetFilename('test.go')
@@ -11,25 +14,36 @@ After:
Execute(The staticcheck callback should return the right defaults):
AssertLinterCwd '%s:h'
- AssertLinter 'staticcheck', 'staticcheck %s:t'
+ AssertLinter 'staticcheck', ale#Escape('staticcheck') . ' %s:t'
+
+Execute(staticcheck should be found in GOPATH):
+ " This is a directory with a fake executable
+ let $GOPATH = ale#test#GetFilename('../test-files/go/gopath')
+
+ AssertLinter
+ \ ale#test#GetFilename('../test-files/go/gopath/bin/staticcheck'),
+ \ ale#Escape(ale#test#GetFilename('../test-files/go/gopath/bin/staticcheck'))
+ \ . ' %s:t'
Execute(The staticcheck callback should use configured options):
let b:ale_go_staticcheck_options = '-test'
- AssertLinter 'staticcheck', 'staticcheck -test %s:t'
+ AssertLinter 'staticcheck', ale#Escape('staticcheck') . ' -test %s:t'
Execute(The staticcheck `lint_package` option should use the correct command):
let b:ale_go_staticcheck_lint_package = 1
AssertLinterCwd '%s:h'
- AssertLinter 'staticcheck', 'staticcheck .'
+ AssertLinter 'staticcheck', ale#Escape('staticcheck') . ' .'
Execute(The staticcheck callback should use the `GO111MODULE` option if set):
let b:ale_go_go111module = 'off'
- AssertLinter 'staticcheck', ale#Env('GO111MODULE', 'off') . 'staticcheck %s:t'
+ AssertLinter 'staticcheck',
+ \ ale#Env('GO111MODULE', 'off') . ale#Escape('staticcheck') . ' %s:t'
" Test with lint_package option set
let b:ale_go_staticcheck_lint_package = 1
- AssertLinter 'staticcheck', ale#Env('GO111MODULE', 'off') . 'staticcheck .'
+ AssertLinter 'staticcheck',
+ \ ale#Env('GO111MODULE', 'off') . ale#Escape('staticcheck') . ' .'
diff --git a/test/test-files/go/gopath/bin/staticcheck b/test/test-files/go/gopath/bin/staticcheck
new file mode 100644
index 00000000..e69de29b
--- /dev/null
+++ b/test/test-files/go/gopath/bin/staticcheck