All patches and comments are welcome. Please squash your changes to logical
commits before using git-format-patch and git-send-email to
patches@git.madduck.net.
If you'd read over the Git project's submission guidelines and adhered to them,
I'd be especially grateful.
2 Save g:ale_go_go111module
5 let $GOPATH = '/non/existent/directory'
7 call ale#assert#SetUpLinterTest('go', 'gopls')
10 if isdirectory(g:dir . '/.git')
11 call delete(g:dir . '/.git', 'd')
14 unlet! b:ale_go_go111module
15 unlet! b:ale_go_go111module
16 unlet! b:ale_completion_enabled
18 call ale#assert#TearDownLinterTest()
20 Execute(The default command should be correct):
21 AssertLinter 'gopls', ale#Escape('gopls') . ' --mode stdio'
23 Execute(The executable should be configurable):
24 let b:ale_go_gopls_executable = 'boo'
26 AssertLinter 'boo', ale#Escape('boo') . ' --mode stdio'
28 Execute(gopls should be found in GOPATH):
29 " This is a directory with a fake executable
30 let $GOPATH = ale#test#GetFilename('../test-files/go/gopath')
33 \ ale#test#GetFilename('../test-files/go/gopath/bin/gopls'),
34 \ ale#Escape(ale#test#GetFilename('../test-files/go/gopath/bin/gopls'))
37 Execute(Global settings should be preferre for gopls if use_global = 1):
38 " This is a directory with a fake executable
39 let $GOPATH = ale#test#GetFilename('../test-files/go/gopath')
40 let b:ale_go_gopls_executable = 'boo'
41 let b:ale_go_gopls_use_global = 1
43 AssertLinter 'boo', ale#Escape('boo') . ' --mode stdio'
45 Execute(Settings options should work):
46 call ale#test#SetFilename('../test-files/go/go1/prj1/file.go')
47 " let b:ale_completion_enabled = 1
48 let b:ale_go_gopls_options = ''
51 \ ale#Escape('gopls') . ''
53 let b:ale_go_gopls_options = '--mode stdio --trace'
56 \ ale#Escape('gopls') . ' --mode stdio --trace'
58 let b:ale_go_gopls_init_options = {'ui.diagnostic.analyses': {'composites': v:false}}
59 AssertLSPOptions {'ui.diagnostic.analyses': {'composites': v:false}}
61 Execute(Go environment variables should be passed on):
62 let b:ale_go_go111module = 'off'
65 \ ale#Env('GO111MODULE', 'off') . ale#Escape('gopls') . ' --mode stdio'
67 Execute(Project directories should be detected based on 'go.mod' being present):
68 call ale#test#SetFilename('../test-files/go/test.go')
70 AssertLSPProject ale#path#Simplify(g:dir . '/../test-files/go')
72 Execute(Project directories with .git should be detected):
73 call ale#test#SetFilename('test.go')
75 if !isdirectory(g:dir . '/.git')
76 call mkdir(g:dir . '/.git')
79 AssertLSPProject g:dir
81 Execute('go.mod' should be ignored if modules are off):
82 call ale#test#SetFilename('../test-files/go/test.go')
84 let b:ale_go_go111module = 'off'
85 let b:parent_dir = ale#path#Simplify(g:dir . '/..')
86 let b:git_dir = b:parent_dir . '/.git'
88 if !isdirectory(b:git_dir)
92 AssertLSPProject b:parent_dir
94 call delete(b:git_dir, 'd')