Visual Studio Tests
The Visual Studio Tests build runner integrates functionality of the MSTest framework and VSTest console runner. Support for both frameworks enables TeamCity to execute tests and automatically import their test results.
The Visual Studio Test runner requires Visual Studio Test Agent or Microsoft Visual Studio installed on the build agent.
Visual Studio Tests runner settings
Option | Description |
---|---|
Test engine type | Select the tool used to run tests: VSTest or MSTest. |
Test engine version | Select the version of the tool from the drop-down menu. By default, the available VSTest and MSTest installations are autodetected by TeamCity:
You can specify a custom path to the test runner here as well. TeamCity parameters are supported. |
Test file names | This field is mandatory for VSTest and optional for MSTest. |
Run configuration file | (Optional) Specify the typical |
Additional command line parameters | Enter additional command line parameters for the selected test engine. |
The rest of settings will vary depending on the engine to run tests with:
VSTest Settings
Option | Description |
---|---|
Target platform | Select the platform bitness. Note that specifying x64 target platform will force the |
Framework | If the default is specified, vstest.console will select the target framework automatically. You can also choose the .NET platform manually using the drop-down. |
Test names | (optional) Of all tests discovered in the included assemblies, only the tests with the names matching the provided values will be run. For multiple values, use new line. If the field is empty, all tests will be run. See details in the Microsoft documentation. Cannot be used with the option below. |
Test case filter | Run tests that match the given expression. See details in the Microsoft documentation. Cannot be used with the option above. |
Run in isolation | Run the tests in an isolated process |
Use real-time test reporting |
|
Custom test logger
VSTest.Console
supports custom loggers, that is libraries that can handle events that occur when tests are being executed.
TeamCity has a custom logger that provides real-time test reporting. The logger must be installed manually on the agent machine, as it requires dlls to be copied to the Extensions
directory of the VSTest.Console. No agent restart is needed when the custom logger is installed.
To install the custom logger:
1. Download the custom logger.
2. Extract the contents of the downloaded archive on the agent machine to the following path:
for VisualStudio 2019 update:
for VisualStudio 2017 update 5 onwards:
for VisualStudio 2017 up to update 4:
for VisualStudio 2015:
for VisualStudio 2013:
for VisualStudio 2012:
3. Check that the custom logger was installed correctly by executing vstest.console.exe /ListLoggers
in the console on the agent machine. If the logger was installed correctly, you will see the logger with FriendlyName TeamCity
listed:
MSTest settings
Option | Description |
---|---|
MSTest metadata | Enter a value for |
Testlist from metadata to run | Edit the Testlist. Every line will be translated into |
Test | Names of individual tests to run. This option will be translated into the series of |
Unique | Run the test only if one unique match is found for any specified test in test section. |
Results file | Enter a value for the To save the test run results to a named non-default file, enter a value for the
|