Boost.Test Run/Debug
This extension allows you to run your Boost.Test tests
from the Testing sidebar of VS Code.
Screenshot

Features
- Tests will appear in the Testing sidebar of VS Code.
- Automatically locate test executables using glob.
- Tests should end in _test, or_test.exefor windows.
 
- runor- debugtests- 
- from the Testingsidebar
- from inside test source code
 
- Output
- Test output appears in the Test OutputTerminal of the Testing sidebar.
- During debugging the test output appears in the corresponding Terminal.
- Diagnostic info appears in the Boost.Test Run/DebugOutput channel.
 
Configurations
A configuration will automatically be created in the workspace settings using glob.
    "boost-test-adapter-robaho.tests": [
        {
            // testExecutables must be provided
            "testExecutables": [
              {
                // either path or glob must be provided
				// path to a test executable. May be absolute or relative path.
                "path": "build/Debug/main_test_1",
                // Optional: Show this label in the Testing sidebar instead of the Boost Test module name.
                "label": "Test 1 (debug)"
              },
              {
                "path": "build/Release/main_test_1",
                "label": "Test 1 (release)"
              },
              {
                "path": "build/Debug/main_test_2"
              },
			  {
				// a glob can match multiple test executables
				"glob": "**/*{_test,_test.exe}",
			  }
            ],
            // Optional: The working directory for the test executables.
            "cwd": "${workspaceFolder}",
            // Mandatory: The name of a launch configuration that should be used
            // when debugging the tests.
            // The 'program' and 'args' options of the given launch config will
            // be overwritten by this extension.
            "debugConfig": "Test config",
            // Optional: A simple key=value file with environment variables for running and debugging the tests.
            "envFile": "${workspaceFolder}/.env",
            // Optional: Environment variables for running and debugging the tests.
            // These env vars are merged with the ones from envFile (if present).
            // These env vars take precedence over the ones from envFile.
            "env": [
              {
                "name": "MY_VAR",
                "value": "my var value"
              }
            ],
            // Optional: Used to convert relative source file paths to absolute paths.
            // It's needed only if the test-case file paths are broken in the Test Explorer UI.
            "sourcePrefix": "${workspaceFolder}"
        },
        {
            "testExecutables": [ "build/Debug/other_test_2" ],
            "cwd": "${workspaceFolder}",
            "debugConfig": "Test config"
        }
    ]
FAQ
- I don't see any tests in the Testing sidebar. Why?
- Make sure you have configured your settings.jsonandlaunch.jsonproperly.
- Take a look at the Boost.Test Run/DebugOutput channel for potential issues.
- The automatic configuration looks for test executables ending in _testor_test.exe
 
- Press the reload button at the top of the Testing sidebar.
- Restart VS Code.
 
- What is this weird root node in the test tree?
- That is your workspace name.
 
- Why does the path of the tests change when I open them?
- Tests are not loaded from the test execuatbles immediately. They are loaded only
when requested (i.e. when you open them). At that point the Test Module name is fetched
from the test executable and it replaces the test exe path.
The test exe path is still available from the context menu's Copy Pathcommand.
 
- Why is the file system path of my Test Suite point to the wrong source file?
- Probably because you have the same Test Suite declared in multiple source files.
 
- Why is my test-root called "Hello World" (or some other nonsense) in the Testing sidebar?
Features not implemented yet
- When debugging a test, the red/green status of the test is not updated in the UI.
Credits
This extension is based on code from these extensions:
Changelog
- Update 3.6.7
- Use workspace folder as default source prefix.
 
- Update 3.6.6
- Do not add default configuration to workspace unless C++ source/header files are found.
 
- Update 3.6.5
- Ability to use glob to specify tests
- Automatically create configuration if needed.
- Update log file name to Boost.Test Run/Debugfor output channel.
 
- Updates 3.4 - 3.6.4
- Update icon.
- Update marketplace metadata.
 
- Update 3.3.0
- Fix handling of boost run errors that don't have parenthesis around the line number.
- Fix handling of source paths.
 
- Update 3.2.3
- Add Copy PathandCopy Relative Pathcommands to the context menu.
- Add Copy Boost.Test IDcommand to the conext menu. It allows to copy the Boost test ID (test path) of a
test case or test suite to the clipboard for test unit filtering.
- Bug fixes.
 
- Update 3.2.0
- Use the built-in Test Explorer of VS Code. No need to install the external Test Explorer UI extension any more.
 
- Update 3.0.0
- Add support for deeply nested test suites (multiple levels of test suites)
- Add support for multiple test executables
- Add support for cancelling tests