У меня есть небольшой проект .NET Core, где весь процесс сборки / тестирования / развертывания обрабатывается в скрипте Cake.
У меня есть скрипт powershell, который запускает скрипт торт.
При локальном запуске сценария я получаю результаты каждого неудачного теста xUnit, но при запуске того же сценария через запуск PowerShell в TeamCity я не получаю результат каждого теста, а просто сводку количества неудачных тестов.
Задача Cake:
Task("Test")
.IsDependentOn("Clean")
.Does(() =>
{
GetFiles("./tests/**/*.csproj")
.ToList()
.ForEach(file => DotNetCoreTest(file.FullPath));
});
Этот код Cake запускает «тест dotnet» под капотом.
При запуске сценария вручную в PowerShell на сервере сборки я получаюэти выходные данные:
Test run for c:\project\myproject\tests\Web.Tests\bin\Debug\netcoreapp2.0\Web.Tests.dll(.NETCoreApp,Version=v2.0)
Microsoft (R) Test Execution Command Line Tool Version 15.7.0
Starting test execution, please wait...
[xUnit.net 00:00:00.7397647] Web.Tests.UnitTest1.Test1[FAIL]
Error Message:
Assert.False() Failure
Expected: False
Actual: True
Test Run Failed.
Total tests: 2. Passed: 1. Failed: 1. Skipped: 0.
Test Run Failed.
При запуске того же сценария с помощью TeamCity PowerShell Runner я получаю следующее:
[14:27:45] [Step 1/1] Test run for D:\TeamCity\buildAgent\work\7ff27c4721bc4a68\tests\Web.Tests\bin\Release\netcoreapp2.0\Web.Tests.dll(.NETCoreApp,Version=v2.0)
[14:27:45] [Step 1/1] Microsoft (R) Test Execution Command Line Tool Version 15.7.0
[14:27:45] [Step 1/1] Starting test execution, please wait...
[14:27:48] [Step 1/1] Failed Web.Tests.UnitTest1.Test1
[14:27:48] [Step 1/1] Error Message:
[14:27:48] [Step 1/1] Assert.False() Failure
[14:27:48] [Step 1/1] Expected: False
[14:27:48] [Step 1/1] Actual: True
[14:27:48] [Step 1/1] Test Run Failed.
[14:27:48] [Step 1/1] Total tests: 2. Passed: 1. Failed: 1. Skipped: 0.
Как видите, отсутствует одна строка, содержащая имяпровальный тест.
Есть идеи, почему это может быть?