coc-gauge
Gauge language server extension for coc-nvim.
Gauge is a light-weight cross-platform test automation tool.
Notes:
- This is not an official repository by Gauge project.
- Some code blocks are taken from coc-nvim and gauge-vscode
- Currently, I'm checking only JavaScript as step implementation language, but others may work.
Motivation
The gauge
command offers language server feature, so you can use it's featue with just setup coc config like below.
{
"languageserver": {
"gauge": {
"command": "gauge",
"args": ["daemon", "--lsp", "--dir", "."],
"filetypes": ["spec"],
"rootPatterns": ["manifest.json"]
}
}
}
However, it lacks many features compared to gauge-vscode.
By using this extension, you can get the below features in neovim/vim!
- Running tests
- Debugging tests
- Renaming step (It works just using the LSP, but is insufficient)
- Listing locations that refer a step
Install
:CocInstall coc-gauge
Commands And Keymaps
Command | <Plug>(keymap) | Description |
---|---|---|
coc-gauge.runAll | coc-gauge-run-all | Run all specs |
coc-gauge.runSpec | coc-gauge-run-spec | Run spec opened in current buffer |
coc-gauge.runScenarioUnderCursor | coc-gauge-run-scenario-under-cursor | Run scenario under the cursor |
coc-gauge.runRepeat | coc-gauge-run-repeat | Run with last launched config |
coc-gauge.debugAll | coc-gauge-debug-all | Debug all specs |
coc-gauge.debugSpec | coc-gauge-debug-spec | Debug spec opened in current buffer |
coc-gauge.debugScenarioUnderCursor | coc-gauge-debug-scenario-under-cursor | Debug scenario under the cursor |
coc-gauge.debugRepeat | coc-gauge-debug-repeat | Debug with last launched config |
coc-gauge.stop | coc-gauge-stop | Stop runnning gauge test |
coc-gauge.renameStep | coc-gauge-rename-step | Rename step under the cursor (*) |
coc-gauge.restartGaugeService | coc-gauge-restart-service | Restart Gauge language server |
*: You can also rename a step by executing CocAction('coc-rename')
, but it does
not work properly, because coc.nvim renaming command uses <cword>
to get the
name, but step name is generally separated by space characters.
Config
- coc-gauge.enable(default: true)
Enable this extention. - coc-gauge.verbose(default: false)
Run gauge command with '--verbose' option. - coc-gauge.coc-gauge.autoScrollOutputWindow(default: false) [Experimental] Automatically scroll the output window to the bottom.
Debug
vimspector is required to be installed for debugging.
Place the following json file as <project-root>/.vimspector.json
for
debugging.
{
"configurations": {
"run": {
"adapter": "vscode-node",
"configuration": {
"request": "attach",
"stopOnEntry": true,
"protocol": "inspector",
"console": "integratedTerminal"
},
"breakpoints": {
"exception": {
"all": "N",
"caught": "",
"uncaught": "Y"
}
}
}
}
}
The exception part is important! If you don't set the part, vimspector asks you some questions before attaching the session. However, Gauge wait for just 1 second. Therefore, during the dialogue, Gauge gives up waiting for attaching from debugging session, then resume running without any breakpoints.
Autocommands
filetype=spec
is set on event BufEnter *.cpt
.
Videos
License
MIT
This extension is created by create-coc-extension