Add ccls tests
This commit is contained in:
parent
56658fd3ad
commit
626e47f5c9
@ -9,7 +9,9 @@ function! ale_linters#c#ccls#GetProjectRoot(buffer) abort
|
|||||||
|
|
||||||
if empty(l:project_root)
|
if empty(l:project_root)
|
||||||
let l:project_root = ale#path#FindNearestFile(a:buffer, 'compile_commands.json')
|
let l:project_root = ale#path#FindNearestFile(a:buffer, 'compile_commands.json')
|
||||||
elseif empty(l:project_root)
|
endif
|
||||||
|
|
||||||
|
if empty(l:project_root)
|
||||||
let l:project_root = ale#path#FindNearestFile(a:buffer, '.ccls')
|
let l:project_root = ale#path#FindNearestFile(a:buffer, '.ccls')
|
||||||
endif
|
endif
|
||||||
|
|
||||||
|
@ -9,7 +9,9 @@ function! ale_linters#cpp#ccls#GetProjectRoot(buffer) abort
|
|||||||
|
|
||||||
if empty(l:project_root)
|
if empty(l:project_root)
|
||||||
let l:project_root = ale#path#FindNearestFile(a:buffer, 'compile_commands.json')
|
let l:project_root = ale#path#FindNearestFile(a:buffer, 'compile_commands.json')
|
||||||
elseif empty(l:project_root)
|
endif
|
||||||
|
|
||||||
|
if empty(l:project_root)
|
||||||
let l:project_root = ale#path#FindNearestFile(a:buffer, '.ccls')
|
let l:project_root = ale#path#FindNearestFile(a:buffer, '.ccls')
|
||||||
endif
|
endif
|
||||||
|
|
||||||
|
@ -9,7 +9,9 @@ function! ale_linters#objc#ccls#GetProjectRoot(buffer) abort
|
|||||||
|
|
||||||
if empty(l:project_root)
|
if empty(l:project_root)
|
||||||
let l:project_root = ale#path#FindNearestFile(a:buffer, 'compile_commands.json')
|
let l:project_root = ale#path#FindNearestFile(a:buffer, 'compile_commands.json')
|
||||||
elseif empty(l:project_root)
|
endif
|
||||||
|
|
||||||
|
if empty(l:project_root)
|
||||||
let l:project_root = ale#path#FindNearestFile(a:buffer, '.ccls')
|
let l:project_root = ale#path#FindNearestFile(a:buffer, '.ccls')
|
||||||
endif
|
endif
|
||||||
|
|
||||||
|
@ -378,8 +378,8 @@ Notes:
|
|||||||
* Awk: `gawk`
|
* Awk: `gawk`
|
||||||
* Bash: `language-server`, `shell` (-n flag), `shellcheck`, `shfmt`
|
* Bash: `language-server`, `shell` (-n flag), `shellcheck`, `shfmt`
|
||||||
* Bourne Shell: `shell` (-n flag), `shellcheck`, `shfmt`
|
* Bourne Shell: `shell` (-n flag), `shellcheck`, `shfmt`
|
||||||
* C: `cppcheck`, `cpplint`!!, `clang`, `clangd`, `clangtidy`!!, `clang-format`, `cquery`, `flawfinder`, `gcc`, `uncrustify`
|
* C: `cppcheck`, `cpplint`!!, `clang`, `clangd`, `clangtidy`!!, `clang-format`, `cquery`, `flawfinder`, `gcc`, `uncrustify`, `ccls`
|
||||||
* C++ (filetype cpp): `clang`, `clangd`, `clangcheck`!!, `clangtidy`!!, `clang-format`, `clazy`!!, `cppcheck`, `cpplint`!!, `cquery`, `flawfinder`, `gcc`, `uncrustify`
|
* C++ (filetype cpp): `clang`, `clangd`, `clangcheck`!!, `clangtidy`!!, `clang-format`, `clazy`!!, `cppcheck`, `cpplint`!!, `cquery`, `flawfinder`, `gcc`, `uncrustify`, `ccls`
|
||||||
* CUDA: `nvcc`!!
|
* CUDA: `nvcc`!!
|
||||||
* C#: `mcs`, `mcsc`!!, `uncrustify`
|
* C#: `mcs`, `mcsc`!!, `uncrustify`
|
||||||
* Chef: `foodcritic`
|
* Chef: `foodcritic`
|
||||||
@ -431,7 +431,7 @@ Notes:
|
|||||||
* Nim: `nim check`!!
|
* Nim: `nim check`!!
|
||||||
* nix: `nix-instantiate`
|
* nix: `nix-instantiate`
|
||||||
* nroff: `alex`!!, `proselint`, `write-good`
|
* nroff: `alex`!!, `proselint`, `write-good`
|
||||||
* Objective-C: `clang`, `clangd`, `uncrustify`
|
* Objective-C: `clang`, `clangd`, `uncrustify`, `ccls`
|
||||||
* Objective-C++: `clang`, `clangd`, `uncrustify`
|
* Objective-C++: `clang`, `clangd`, `uncrustify`
|
||||||
* OCaml: `merlin` (see |ale-ocaml-merlin|), `ols`, `ocamlformat`
|
* OCaml: `merlin` (see |ale-ocaml-merlin|), `ols`, `ocamlformat`
|
||||||
* Pawn: `uncrustify`
|
* Pawn: `uncrustify`
|
||||||
|
43
test/command_callback/test_c_ccls_command_callbacks.vader
Normal file
43
test/command_callback/test_c_ccls_command_callbacks.vader
Normal file
@ -0,0 +1,43 @@
|
|||||||
|
" Author: Ye Jingchen <ye.jingchen@gmail.com>, Ben Falconer <ben@falconers.me.uk>
|
||||||
|
" Description: A language server for C
|
||||||
|
|
||||||
|
Before:
|
||||||
|
call ale#assert#SetUpLinterTest('c', 'ccls')
|
||||||
|
|
||||||
|
After:
|
||||||
|
call ale#assert#TearDownLinterTest()
|
||||||
|
|
||||||
|
Execute(The project root should be detected correctly using compile_commands.json file):
|
||||||
|
AssertLSPProject ''
|
||||||
|
|
||||||
|
call ale#test#SetFilename('ccls_paths/with_compile_commands_json/dummy.c')
|
||||||
|
|
||||||
|
AssertLSPProject ale#path#Simplify(g:dir . '/ccls_paths/with_compile_commands_json')
|
||||||
|
|
||||||
|
Execute(The project root should be detected correctly using .ccls file):
|
||||||
|
AssertLSPProject ''
|
||||||
|
|
||||||
|
call ale#test#SetFilename('ccls_paths/with_ccls/dummy.c')
|
||||||
|
|
||||||
|
AssertLSPProject ale#path#Simplify(g:dir . '/ccls_paths/with_ccls')
|
||||||
|
|
||||||
|
Execute(The project root should be detected correctly using .ccls-root file):
|
||||||
|
AssertLSPProject ''
|
||||||
|
|
||||||
|
call ale#test#SetFilename('ccls_paths/with_ccls-root/dummy.c')
|
||||||
|
|
||||||
|
AssertLSPProject ale#path#Simplify(g:dir . '/ccls_paths/with_ccls-root')
|
||||||
|
|
||||||
|
Execute(The executable should be configurable):
|
||||||
|
AssertLinter 'ccls', ale#Escape('ccls')
|
||||||
|
|
||||||
|
let b:ale_c_ccls_executable = 'foobar'
|
||||||
|
|
||||||
|
AssertLinter 'foobar', ale#Escape('foobar')
|
||||||
|
|
||||||
|
Execute(The initialization options should be configurable):
|
||||||
|
AssertLSPOptions {}
|
||||||
|
|
||||||
|
let b:ale_c_ccls_init_options = { 'cacheDirectory': '/tmp/ccls' }
|
||||||
|
|
||||||
|
AssertLSPOptions { 'cacheDirectory': '/tmp/ccls' }
|
43
test/command_callback/test_cpp_ccls_command_callbacks.vader
Normal file
43
test/command_callback/test_cpp_ccls_command_callbacks.vader
Normal file
@ -0,0 +1,43 @@
|
|||||||
|
" Author: Ye Jingchen <ye.jingchen@gmail.com>, Ben Falconer <ben@falconers.me.uk>
|
||||||
|
" Description: A language server for C++
|
||||||
|
|
||||||
|
Before:
|
||||||
|
call ale#assert#SetUpLinterTest('cpp', 'ccls')
|
||||||
|
|
||||||
|
After:
|
||||||
|
call ale#assert#TearDownLinterTest()
|
||||||
|
|
||||||
|
Execute(The project root should be detected correctly using compile_commands.json file):
|
||||||
|
AssertLSPProject ''
|
||||||
|
|
||||||
|
call ale#test#SetFilename('ccls_paths/with_compile_commands_json/dummy.cpp')
|
||||||
|
|
||||||
|
AssertLSPProject ale#path#Simplify(g:dir . '/ccls_paths/with_compile_commands_json')
|
||||||
|
|
||||||
|
Execute(The project root should be detected correctly using .ccls file):
|
||||||
|
AssertLSPProject ''
|
||||||
|
|
||||||
|
call ale#test#SetFilename('ccls_paths/with_ccls/dummy.cpp')
|
||||||
|
|
||||||
|
AssertLSPProject ale#path#Simplify(g:dir . '/ccls_paths/with_ccls')
|
||||||
|
|
||||||
|
Execute(The project root should be detected correctly using .ccls-root file):
|
||||||
|
AssertLSPProject ''
|
||||||
|
|
||||||
|
call ale#test#SetFilename('ccls_paths/with_ccls-root/dummy.cpp')
|
||||||
|
|
||||||
|
AssertLSPProject ale#path#Simplify(g:dir . '/ccls_paths/with_ccls-root')
|
||||||
|
|
||||||
|
Execute(The executable should be configurable):
|
||||||
|
AssertLinter 'ccls', ale#Escape('ccls')
|
||||||
|
|
||||||
|
let b:ale_cpp_ccls_executable = 'foobar'
|
||||||
|
|
||||||
|
AssertLinter 'foobar', ale#Escape('foobar')
|
||||||
|
|
||||||
|
Execute(The initialization options should be configurable):
|
||||||
|
AssertLSPOptions {}
|
||||||
|
|
||||||
|
let b:ale_cpp_ccls_init_options = { 'cacheDirectory': '/tmp/ccls' }
|
||||||
|
|
||||||
|
AssertLSPOptions { 'cacheDirectory': '/tmp/ccls' }
|
40
test/command_callback/test_objc_ccls_command_callbacks.vader
Normal file
40
test/command_callback/test_objc_ccls_command_callbacks.vader
Normal file
@ -0,0 +1,40 @@
|
|||||||
|
Before:
|
||||||
|
call ale#assert#SetUpLinterTest('objc', 'ccls')
|
||||||
|
|
||||||
|
After:
|
||||||
|
call ale#assert#TearDownLinterTest()
|
||||||
|
|
||||||
|
Execute(The project root should be detected correctly using compile_commands.json file):
|
||||||
|
AssertLSPProject ''
|
||||||
|
|
||||||
|
call ale#test#SetFilename('ccls_paths/with_compile_commands_json/dummy.m')
|
||||||
|
|
||||||
|
AssertLSPProject ale#path#Simplify(g:dir . '/ccls_paths/with_compile_commands_json')
|
||||||
|
|
||||||
|
Execute(The project root should be detected correctly using .ccls file):
|
||||||
|
AssertLSPProject ''
|
||||||
|
|
||||||
|
call ale#test#SetFilename('ccls_paths/with_ccls/dummy.m')
|
||||||
|
|
||||||
|
AssertLSPProject ale#path#Simplify(g:dir . '/ccls_paths/with_ccls')
|
||||||
|
|
||||||
|
Execute(The project root should be detected correctly using .ccls-root file):
|
||||||
|
AssertLSPProject ''
|
||||||
|
|
||||||
|
call ale#test#SetFilename('ccls_paths/with_ccls-root/dummy.m')
|
||||||
|
|
||||||
|
AssertLSPProject ale#path#Simplify(g:dir . '/ccls_paths/with_ccls-root')
|
||||||
|
|
||||||
|
Execute(The executable should be configurable):
|
||||||
|
AssertLinter 'ccls', ale#Escape('ccls')
|
||||||
|
|
||||||
|
let b:ale_objc_ccls_executable = 'foobar'
|
||||||
|
|
||||||
|
AssertLinter 'foobar', ale#Escape('foobar')
|
||||||
|
|
||||||
|
Execute(The initialization options should be configurable):
|
||||||
|
AssertLSPOptions {}
|
||||||
|
|
||||||
|
let b:ale_objc_ccls_init_options = { 'cacheDirectory': '/tmp/ccls' }
|
||||||
|
|
||||||
|
AssertLSPOptions { 'cacheDirectory': '/tmp/ccls' }
|
Loading…
Reference in New Issue
Block a user