Bandit-C++ Test Explorer for Visual Studio Code
Run your C++ Unit Tests written with the Bandit-Framework using the
Test Explorer UI.
Features
- Shows a Test Explorer in VS Code's sidebar with all detected tests and suites and their state.
- Opens a failed test's log when it is selected in the Test Explorer.
- Tests or groups of tests can be marked with auto run. They will be triggered automatically after watched test files have changed.
Requirements
You only need to configure your compiled test executables with the banditTestExplorer.testsuites
property in VS Code's settings (see below).
Progress Visualization
With the banditTestExplorer.progressVisualization
property you can specify how the the loading and running progress will be displayed.
By default it is shown as a popup dialog box:
But you can also use the more unobtrusive way in the status bar:
Configuration
Next to global settings the configuration contains test projects. A test project is a single executable containing tests.
Property |
Description |
banditTestExplorer.testsuites |
The configuration of your bandit test projects. Either a single configuration object or a path to the JSON configuration file (relative to the workspace folder or absolute path). A detailed structure follows in the table below. |
banditTestExplorer.parallelProcessLimit |
The limit of parallel processes started during a test run. |
banditTestExplorer.watchTimeoutSec |
A timeout in seconds that helps to prevent the auto run when watched files are compiled often. |
banditTestExplorer.allowKillProcess |
Allows to hard kill running processes when a test run is cancelled or aborted. |
banditTestExplorer.logpanel |
Enables the output of diagnostic logs to the integrated output panel. |
banditTestExplorer.logfile |
Enables the output of diagnostic logs to the specified file if provided. |
banditTestExplorer.loglevel |
The logging level used to filter notifications. All notifications of the same or higher level will be logged. Supported values are: debug , info , warning , error |
banditTestExplorer.progressVisualization |
Determines how the loading and running progress will be displayed. Either as an additional entry in the status bar (statusBar ) or as a popup dialog box (dialogBox , default). |
The JSON configuration to define tests. It contains multiple definitions that are structured as followed:
Property |
Description |
name |
The Name of the test project (Will be displayed as the top level node in the Test Explorer tree). |
cmd |
The location of your bandit test executable (relative to the workspace folder). |
options |
Optional: Arguments passed to the test executable when running the tests. |
cwd |
Optional: A working directory where bandit-cpp is run (relative to the workspace folder). |
watches |
Optional: Files that will be watched. Changes to those will cause an auto run. |
env |
Optional: Environment variables to be set when running the tests. |
disabled |
Optional: Set to true to disable the configured test project without having to remove it. |
parallelProcessLimit |
Optional: The limit of parallel processes started during a test run. |
allowKillProcess |
Optional: Allows to hard kill running processes when a test run is cancelled or aborted. |
linux |
Optional: A Linux specific configuration object that may have cmd ,options , cwd , watches , env , disabled , parallelProcessLimit and allowKillProcess to override the equivalent value from the test suite. |
osx |
Optional: A MacOS specific configuration object that may have cmd ,options , cwd , watches , env , disabled , parallelProcessLimit and allowKillProcess to override the equivalent value from the test suite. |
windows |
Optional: A windows specific configuration object that may have cmd ,options , cwd , watches , env , disabled , parallelProcessLimit and allowKillProcess to override the equivalent value from the test suite. |
All configuration elements can be modified with configuration symbols:
Symbol |
Description |
Example |
${workspaceFolder} |
The current working directory |
"cwd": "\${workspaceFolder}" |
${env:NAME} |
Uses an environment variable present to visual studio code |
"env": { "PATH": "${env:PATH}:My/Path" } |
${processNumber} |
The zero-based index of the spawned process, in the range of:
0 <= ${processNumber} < parallelProcessLimit . Useful for connection strings when using parallelized tests with databases. |
"options": [ "-database", "db_${processNumber}" ] |
Example configuration
"banditTestExplorer.testsuites": [
{
"name": "my-app",
"options": [
"-connection",
"Server=myServerAddress;Database=myDataBase${processNumber}"
],
"cwd": "${workspaceFolder}/build/bin",
"windows": {
"cmd": "test-my-app.exe",
"cwd": "${workspaceFolder}/build/bin/Debug",
"env": {
"Path": "${env:Path}:/additional/path"
},
"watches": ["apps/my-app/my-app.dll"]
},
"linux": {
"cmd": "test-my-app",
"env": {
"Path": "${env:Path}:/additional/path"
},
"watches": ["apps/my-app/libapp-my-app.so"]
},
"osx": {
"cmd": "test-my-app",
"env": {
"Path": "${env:Path}:/additional/path"
},
"watches": ["apps/my-app/libapp-my-app.dylib"]
},
"parallelProcessLimit": 10
},
{
"name": "my-other-app",
"disabled": true,
"cmd": "test-my-app.sh",
"cwd": "${workspaceFolder}/build/bin"
}
],
"banditTestExplorer.parallelProcessLimit": 1
Commands
The following commands are available in VS Code's command palette, use the ID to add them to your keyboard shortcuts:
ID |
Command |
test-explorer.reload |
Reload tests |
test-explorer.run-all |
Run all tests |
test-explorer.run-file |
Run tests in current file |
test-explorer.run-test-at-cursor |
Run the test at the current cursor position |
test-explorer.cancel |
Cancel running tests |
test-explorer.cancel |
Cancel running tests |
bandit-test-explorer.run |
Runs a specific tests that match a filter string. |
Known issues
Node.js on MacOS and DYLD-Paths:
As mentioned in this Issue Node.js is not allowed to define certain environment variables on MacOS.
Those are protected by the System Integrity Protection SIP.
If you're working with MacOS an you have to specify a DYLD-Path (like DYLD_FALLBACK_LIBRARY_PATH
) to run your test-executable,
- you either have to disable the SIP (see How to disable SIP),
- run with an intermediate test runner script (see below) or
- have to bypass these environment variables on a different way.
A possible workaround without disabling SIP is running a test runner script that defines the needed environment variables:
#!/bin/bash
# test-runner.sh that sets the DYLD path and calls something:
export DYLD_FALLBACK_LIBRARY_PATH=~/some/path:~/some/other/path:...
test-my-app "$@"
and use it like:
{
"name": "my-app",
"cmd": "test-runner.sh",
"cwd": "~/path/to/my-project/build/bin/Debug",
"env": {
"PATH": "~/path/to/my-app/build/bin/Debug/apps/my-app"
},
"watches": ["apps/my-app/libapp-my-app.dylib"]
}
What's next?
- Integrate custom vscode tasks to the execution process (e.g. triggered when a test run started or ended)
- Filtering the tree
- Enable Debugging (Set Breakpoint inside it or describe and start debugging session)
Acknowledgements
This extension based on the Example Test Adapter.
Bandit icon made by Freepik from www.flaticon.com is licensed by CC 3.0 BY
Contributors
Matthias Füg
Feel free to contribute...
License
MIT