Added tests
This commit is contained in:
parent
df72c5f1c1
commit
f64f0bb48c
@ -1,9 +1,12 @@
|
|||||||
" Author: Bartolomeo Stellato <bartolomeo.stellato@gmail.com>
|
" Author: Bartolomeo Stellato <bartolomeo.stellato@gmail.com>
|
||||||
" Description: A language server for Julia
|
" Description: A language server for Julia
|
||||||
|
|
||||||
|
" Set julia executable variable
|
||||||
|
call ale#Set('julia_executable', 'julia')
|
||||||
|
|
||||||
function! ale_linters#julia#languageserver#GetCommand(buffer) abort
|
function! ale_linters#julia#languageserver#GetCommand(buffer) abort
|
||||||
let l:julia_executable = ale#Var(a:buffer, 'julia_executable')
|
let l:julia_executable = ale#Var(a:buffer, 'julia_executable')
|
||||||
return ale#Escape(l:julia_executable) . ale#Escape("--startup-file=no --history-file=no -e 'using LanguageServer; server = LanguageServer.LanguageServerInstance(STDIN, STDOUT, false); server.runlinter = true; run(server);'")
|
return ale#Escape(l:julia_executable . " --startup-file=no --history-file=no -e 'using LanguageServer; server = LanguageServer.LanguageServerInstance(STDIN, STDOUT, false); server.runlinter = true; run(server);'")
|
||||||
endfunction
|
endfunction
|
||||||
|
|
||||||
call ale#linter#Define('julia', {
|
call ale#linter#Define('julia', {
|
||||||
|
@ -1,27 +1,20 @@
|
|||||||
" Author: Bartolomeo Stellato bartolomeo.stellato@gmail.com
|
" Author: Bartolomeo Stellato bartolomeo.stellato@gmail.com
|
||||||
" Description: Functions for integrating with Julia tools
|
" Description: Functions for integrating with Julia tools
|
||||||
|
|
||||||
" Set julia executable variable
|
|
||||||
call ale#Set('julia_executable', 'julia')
|
|
||||||
|
|
||||||
" Find the nearest dir contining a git project as julia project
|
" Find the nearest dir contining a git project as julia project
|
||||||
let g:__ale_julia_project_filenames = ['.git/HEAD']
|
let g:__ale_julia_project_filenames = ['REQUIRE']
|
||||||
|
|
||||||
function! ale#julia#FindProjectRoot(buffer) abort
|
function! ale#julia#FindProjectRoot(buffer) abort
|
||||||
for l:project_filename in g:__ale_julia_project_filenames
|
for l:project_filename in g:__ale_julia_project_filenames
|
||||||
let l:full_path = ale#path#FindNearestFile(a:buffer, l:project_filename)
|
let l:full_path = ale#path#FindNearestFile(a:buffer, l:project_filename)
|
||||||
|
|
||||||
if !empty(l:full_path)
|
if !empty(l:full_path)
|
||||||
let l:path = fnamemodify(l:full_path, ':h')
|
let l:path = fnamemodify(l:full_path, ':p:h')
|
||||||
|
|
||||||
" Correct .git path detection.
|
|
||||||
if fnamemodify(l:path, ':t') is# '.git'
|
|
||||||
let l:path = fnamemodify(l:path, ':h')
|
|
||||||
endif
|
|
||||||
|
|
||||||
return l:path
|
return l:path
|
||||||
endif
|
endif
|
||||||
|
|
||||||
endfor
|
endfor
|
||||||
|
|
||||||
return ''
|
return ''
|
||||||
endfunction
|
|
||||||
|
|
||||||
|
endfunction
|
||||||
|
@ -0,0 +1,20 @@
|
|||||||
|
Before:
|
||||||
|
call ale#assert#SetUpLinterTest('julia', 'languageserver')
|
||||||
|
|
||||||
|
After:
|
||||||
|
call ale#assert#TearDownLinterTest()
|
||||||
|
|
||||||
|
Execute(The default executable path should be correct):
|
||||||
|
AssertLinter 'julia', ale#Escape("julia" . " --startup-file=no --history-file=no -e 'using LanguageServer; server = LanguageServer.LanguageServerInstance(STDIN, STDOUT, false); server.runlinter = true; run(server);'")
|
||||||
|
|
||||||
|
Execute(The executable should be configurable):
|
||||||
|
let g:ale_julia_executable = 'julia-new'
|
||||||
|
|
||||||
|
AssertLinter 'julia-new', ale#Escape("julia-new" . " --startup-file=no --history-file=no -e 'using LanguageServer; server = LanguageServer.LanguageServerInstance(STDIN, STDOUT, false); server.runlinter = true; run(server);'")
|
||||||
|
|
||||||
|
Execute(The project root should be detected correctly):
|
||||||
|
AssertLSPProject ''
|
||||||
|
|
||||||
|
call ale#test#SetFilename('julia-languageserver-project/test.jl')
|
||||||
|
|
||||||
|
AssertLSPProject ale#path#Simplify(g:dir . '/julia-languageserver-project')
|
Loading…
Reference in New Issue
Block a user