Примечание.
Для доступа к этой странице требуется авторизация. Вы можете попробовать войти или изменить каталоги.
Для доступа к этой странице требуется авторизация. Вы можете попробовать изменить каталоги.
Подсказка
Перед выбором конфигурации раннера см. Обзор тестовых платформ.
Существует несколько способов выполнения тестов MSTest в зависимости от ваших потребностей. Вы можете выполнять тесты из интегрированной среды разработки (например, Visual Studio, Visual Studio код или JetBrains Rider), либо из командной строки или из службы CI (например, GitHub Actions или Azure DevOps).
Исторически MSTest опиралась на VSTest для выполнения тестов во всех контекстах, но начиная с версии 3.2.0, MSTest имеет собственный модуль тестирования. Этот новый раннер более легковесный и быстрый, чем VSTest, и рекомендуется для запуска тестов MSTest.
VSTest и MTP
MSTest поддерживает выполнение тестов с помощью VSTest и Microsoft.Testing.Platform (MTP). Поддержка MTP обеспечивается с помощью средства запуска MSTest, который может выполнять тесты в любых контекстах (например, конвейеры непрерывной интеграции (CI), CLI, Обозреватель тестов Visual Studio и текстовый обозреватель VS Code). Средство выполнения MSTest встроено прямо в ваши тестовые проекты MSTest, и для запуска тестов не требуются другие зависимости приложений, такие как vstest.console или dotnet test. Однако вы по-прежнему можете выполнять тесты с помощью dotnet test.
Средство выполнения MSTest — это с открытым исходным кодом и основано на библиотеке MTP. Код Microsoft.Testing.Platform можно найти в репозитории microsoft/testfx GitHub. Раннер MSTest поставляется вместе с MSTest in 3.2.0 или более поздней версией.
Включение MTP в проекте MSTest
Рекомендуется использовать пакет SDK MSTest , так как он значительно упрощает конфигурацию проекта и обновляет проект, и обеспечивает правильное выравнивание версий платформы (MTP) и его расширений.
При использовании MSTest SDKпо умолчанию вы решили использовать MTP.
<Project Sdk="MSTest.Sdk/4.1.0">
<PropertyGroup>
<TargetFramework>net10.0</TargetFramework>
<ImplicitUsings>enable</ImplicitUsings>
<Nullable>enable</Nullable>
</PropertyGroup>
</Project>
Кроме того, можно включить средство выполнения MSTest, добавив свойство EnableMSTestRunner и установив для параметра OutputType значение Exe в вашем файле проекта. Также убедитесь, что вы используете MSTest 3.2.0 или более позднюю версию. Настоятельно рекомендуется обновить последнюю версию MSTest.
Рассмотрим следующий пример project файла:
<Project Sdk="Microsoft.NET.Sdk">
<PropertyGroup>
<!-- Enable Microsoft.Testing.Platform, this is an opt-in feature -->
<EnableMSTestRunner>true</EnableMSTestRunner>
<TestingPlatformDotnetTestSupport>true</TestingPlatformDotnetTestSupport>
<!--
Displays error on console in addition to the log file. Note that this feature comes with a performance impact.
For more information, visit https://learn.microsoft.com/dotnet/core/testing/unit-testing-with-dotnet-test#show-failure-per-test
-->
<TestingPlatformShowTestsFailure>true</TestingPlatformShowTestsFailure>
<OutputType>Exe</OutputType>
<TargetFramework>net10.0</TargetFramework>
<ImplicitUsings>enable</ImplicitUsings>
<Nullable>enable</Nullable>
</PropertyGroup>
<ItemGroup>
<!--
MSTest meta package is the recommended way to reference MSTest.
It's equivalent to referencing:
Microsoft.NET.Test.Sdk
MSTest.TestAdapter
MSTest.TestFramework
MSTest.Analyzers
Starting with 3.8, it also includes:
Microsoft.Testing.Extensions.TrxReport
Microsoft.Testing.Extensions.CodeCoverage
-->
<PackageReference Include="MSTest" Version="4.1.0" />
</ItemGroup>
</Project>
Подсказка
Чтобы убедиться, что все тестовые проекты в решении используют фреймворк запуска MSTest, задайте свойства EnableMSTestRunner и TestingPlatformDotnetTestSupport в файле Directory.Build.props вместо отдельных файлов проектов.
Конфигурации и фильтры
.runsettings
MTP поддерживает параметры запуска с помощью параметра --settings командной строки. Для получения полного списка поддерживаемых записей MSTest ознакомьтесь с разделом "Настройка MSTest: Runsettings". В следующих командах показаны различные примеры использования.
Использование dotnet run:
dotnet run --project Contoso.MyTests -- --settings config.runsettings
Использование dotnet exec:
dotnet exec Contoso.MyTests.dll --settings config.runsettings
–или–
dotnet Contoso.MyTests.dll --settings config.runsettings
Использование исполняемого файла:
Contoso.MyTests.exe --settings config.runsettings
Фильтр тестов
Вы можете легко предоставить фильтр тестов с помощью параметра --filterкомандной строки. В следующих командах показаны некоторые примеры.
Использование dotnet run:
dotnet run --project Contoso.MyTests -- --filter "FullyQualifiedName~UnitTest1|TestCategory=CategoryA"
Использование dotnet exec:
dotnet exec Contoso.MyTests.dll --filter "FullyQualifiedName~UnitTest1|TestCategory=CategoryA"
–или–
dotnet Contoso.MyTests.dll --filter "FullyQualifiedName~UnitTest1|TestCategory=CategoryA"
Использование исполняемого файла:
Contoso.MyTests.exe --filter "FullyQualifiedName~UnitTest1|TestCategory=CategoryA"