ReSharper 2019.2 Help

Unit Testing Assistance in C++

ReSharper helps discover, run, and debug unit tests of Google C++ Testing Framework, C++ test framework, Catch, Boost.Test framework (v. 1.59 and above), and doctest unit testing framework right in Visual Studio.

With ReSharper, you can execute a single unit test, all tests in a file, project or solution. You can also execute any number of tests combined in a test session.

Discovering tests in the current document

ReSharper discovers unit tests right in the editor and adds the corresponding action indicators next to each item in the editor:

ReSharper shows different indicators for unit tests in the editor
  • ThemedIcon UnitTestingOptionsPage Screen Gray - a unit test that you can run or debug

  • ThemedIcon TestMethodSuccess Screen Gray — the unit test passed during the last execution.

  • ThemedIcon TestMethodFail Screen Gray — the unit test failed during the last execution.

Executing tests in the current document

There are several ways to run or debug unit tests in the current document. You can use action indicators, main menu or shortcuts:

  • To run or debug a single test or all tests in a test class, click the action indicator next to it or set the caret at the test and press Alt+Enter. In the action list, choose Run / Debug for a test class.

  • Alternatively, you can use the Run Unit Tests / Debug Unit Tests commands, which are available in the main menu (ReSharper | Unit Tests ), in the context menu, or with Ctrl+T,R / Ctrl+T,D shortcuts correspondingly. These commands work differently depending on the caret position or selection in the editor:

    • To run or debug a single test, set the caret at the test name, or anywhere inside its declaration in the editor.

    • To run several tests, select the desired tests in the editor.

Whatever way you choose to run or debug tests, you will see the execution progress, results, and output in the Unit Test Sessions window. If there is an open unit test session, the executed tests are added in this session. If there are no test sessions or the existing ones are locked, then a new tests session is created.

If necessary, you can always re-run the tests that you executed last by pressing Ctrl+T,T or choosing ReSharper | Unit Tests | Repeat Previous Run in the menu.

Discovering unit tests in solution

ReSharper adds the Unit Test Explorer window to Visual Studio (ReSharper | Unit Tests | Unit Tests or ReSharper | Windows | Unit Tests, or Ctrl+Alt+T ). Using this window, you can explore and run or debug unit tests in the entire solution. Note that unit tests from a project only appear in the window after the project is built. Tests from currently opened files are updated automatically, new tests from the opened files appear in the unit test explorer as soon as you create them.

Unit test explorer allows you to do the following:

  • Explore tests in the solution: browse all unit tests in a list or tree view, search tests and filter by a substring, regroup unit tests by project, namespace, and so on.

  • Navigate to source code of any test by double-clicking it in the view.

  • run or debug selected tests.

  • Create unit tests sessions from selected tests and/or add selected items to the current test session.

  • Export all tests from solution to a text, XML, or HTML file.

Unit Test Explorer displays test from the entire solution

Executing unit tests in project or solution

You can run or debug tests from the Unit Test Explorer, Solution Explorer, or Class View. Unit Test Explorer gives you the advantage to see only tests, while using other windows you need to know, which projects, files, and classes contain tests.

  • To execute tests from Unit Test Explorer, select the desired tests and click Run Unit Tests ThemedIcon RunTest Screen Gray / Debug Unit Tests ThemedIcon Debug Screen Gray on the toolbar or use the corresponding shortcuts (Ctrl+T,R / Ctrl+T,D ).

  • To run or debug tests from Solution Explorer or Class View, select one or more items ( files, folders, projects) that contain tests, and use the Run Unit Tests / Debug Unit Tests commands, which are available in the main menu (ReSharper | Unit Tests ), in the context menu, or with Ctrl+T,R / Ctrl+T,D shortcuts correspondingly.

  • To run or debug all tests in solution, choose ReSharper | Unit Tests | Run All Tests from Solution in the main menu or press Ctrl+T,L.

Whatever way you choose to run or debug tests, you will see the execution progress, results, and output in the Unit Test Sessions window. If there is an open unit test session, the executed tests are added in this session. If there are no test sessions or the existing ones are locked, then a new tests session is created.

If necessary, you can always re-run the tests that you executed last by pressing Ctrl+T,T or choosing ReSharper | Unit Tests | Repeat Previous Run in the menu.

Using unit test sessions

ReSharper allows you to group unit tests that target specific part of your application into unit test sessions. A unit test session can contain tests from different projects. You can have multiple test sessions and run them separately as needed. A single test can be included into several different test sessions.

For detailed instructions related to unit test sessions, see Using Unit Test Sessions.

Execution process

ReSharper provides several ways to execute unit tests. Whichever way you choose, execution progress, test results, and output are displayed in the Unit Test Sessions window, coverage results are shown in the Unit Test Coverage window.

As tests are running in a unit test session, the execution progress is shown in the status bar under the toolbar of the Unit Test Sessions window and the Stop Execution ThemedIcon StopTest Screen Gray button becomes active. You can click this button to abort execution of the tests. You can run multiple unit test sessions simultaneously. However, when you debug tests, only one test session can be executed at a time.

If necessary, you can enable the Track Running Test ThemedIcon TrackRun Screen Gray option on the toolbar. If it is on, the selection in the test tree switches automatically to the test that is currently running and the output panel always shows output of the current test during the execution.

You can also enable the Auto Scroll Output When Running Test ThemedIcon ScrollToBottom Screen Gray option to follow output of tests as they are running.

When you run or debug unit tests, ReSharper uses the Command and Working Directory configuration parameters specified in the project properties. To access these properties, right-click the project and choose Project Properties | Configuration Properties | Debugging.

The Command Arguments property (Debugging | Local Windows Debugger | Command Arguments) is not used by default. To use it in test execution, select the corresponding checkbox on the Tools | Unit Testing | Test Frameworks | C++ Tests page of ReSharper options (Alt+R,,O).

If execution settings are not specified in project properties (for example, in a library project, in an 'Open Folder' or CMake project), you can define them in the Tools | Unit Testing | Test Frameworks | C++ Tests page of ReSharper options.

ReSharper: Unit test sessions for C++ tests

Analysing execution results and output

When the execution is over, the results are visualized in the Unit Test Sessions window.

The output pane (which you can place on the right or on the bottom using the Show Output ThemedIcon PreviewToggle Screen Gray button on the toolbar) displays output of the selected test.

By default, ReSharper wraps long lines in the output according to the current width of the output area. If necessary, you choose not to wrap long lines by clearing the Wrap long lines in Unit Test Session output checkbox on the Tools | Unit Testing page of ReSharper options.

On the status bar, you can see the total number of tests in the session as well as number of tests in different states:

Unit test filters
By default, tests in all states are shown, but you can click the corresponding icons to filter tests by their state. You can also Ctrl-click several icons to display tests in several different states. Status of each test in the Unit Test Sessions window is displayed with one of the following icons:

ThemedIcon RunningTest Screen Gray

Unit test is currently executing

ThemedIcon TestPending Screen Gray

Unit test is scheduled for execution in the current run

ThemedIcon StatusUnknown Screen Gray

Unit test was not executed

ThemedIcon Success Screen Gray

Unit test passed in the lats test run

ThemedIcon Error Screen Gray

Unit test failed in the lats test run

ThemedIcon Ignore Screen Gray

Unit test was ignored in the last test run

ThemedIcon StatusAborted Screen Gray

Unit test was aborted in the last test run

ThemedIcon StatusInconclusive Screen Gray

Unit test was started but ReSharper could not read the test runner output. This could be a sign of an error occurring in the test runner.

The same icons are used to display status of grouping items

The icons are also used on each session's tab to display the overall execution result of the sessions.

The corresponding icons above the test session tree show how many tests are in each of the states. The ThemedIcon UnitSession Screen Gray icon shows the total number of tests in the session.
Using these icons, you can filter the tree so that only tests in the corresponding status are displayed.

Configuring test runner

Unit test execution variables, such as command, its arguments, working directory, and environment variables are normally specified in project properties (Project Properties | Configuration Properties | Debugging) and ReSharper will take them from there.
However, if these properties are not specified there (for example, in a library project, in an 'Open Folder' or CMake project), you can define execution settings on the Tools | Unit Testing | Test Frameworks | C++ Tests page of ReSharper options (Alt+R,,O).

You can also use the Merge environment flag on that page. If it is selected, ReSharper will add environment variables specified in the Environment field to the environment variables from Visual Studio. If it is not selected, only environment variables from Visual Studio will be used.

Last modified: 18 November 2019