У меня есть метод, который, кажется, работает для обновления результатов теста TFS ТОЛЬКО для той конфигурации, в которой он работал. Но это кажется очень неэффективным. Может ли кто-нибудь помочь мне понять, что я делаю неправильно? - в частности, мне не нужно получать testSuites для заданного идентификатора теста, а затем перебирать все тесты для этих наборов, чтобы сравнить с идентификатором теста, который у меня уже есть.
В качестве примера я запускаю тест на Windows 8/Chrome. Итак, TestContext содержит соответствующие значения, которые сопоставляются с конфигурацией. Я хочу обновить результат теста для этой конфигурации в каждом наборе тестов, в котором она существует. Вот код:
public void UpdateResult(TestContext context, bool passed)
{
int testCaseID = Convert.ToInt32(context.Test.Properties["id"]);
TfsTeamProjectCollection projectCollection = TfsTeamProjectCollectionFactory.GetTeamProjectCollection(tfsUri);
ITestManagementService service = projectCollection.GetService<ITestManagementService>();
ITestManagementTeamProject teamProject = service.GetTeamProject(teamProjectName);
ITestCase testCase = teamProject.TestCases.Find(testCaseID);
ITestSuiteCollection testSuites = teamProject.TestSuites.ReferencingTestCase(testCaseID);
if (testCase != null)
{
// ---- Get Test Plan
int testPlanId = 20589;
ITestPlan testPlan = teamProject.TestPlans.Find(testPlanId);
// ---- Create Test Run
ITestRun testRun = teamProject.TestRuns.Create();
testRun = testPlan.CreateTestRun(true);
// ---- Get TestPoint
ITestPointCollection points = testPlan.QueryTestPoints("SELECT * FROM TestPoint WHERE TestCaseId =" + testCaseID);
foreach (ITestPoint tp in points)
{
//Get configuration, which contains configuration values
ITestConfiguration testConfiguration = teamProject.TestConfigurations.Query("Select * from TestConfiguration WHERE Name='" + tp.ConfigurationName + "'")[0];
IDictionary<string, string> testConfigValues = testConfiguration.Values;
if ((!testConfigValues.ContainsKey("Browser") ||
testConfigValues["Browser"].ToLower() == context.Test.Properties["Browser"].ToString().ToLower())
&& (!testConfigValues.ContainsKey("Operating System") ||
testConfigValues["Operating System"].ToLower() == context.Test.Properties["Operating System"].ToString().ToLower())
)
{
testRun.AddTestPoint(tp, testPlan.Owner);
}
}
testRun.State = TestRunState.Completed;
testRun.Save();
foreach (ITestSuiteBase testSuite in testSuites)
{
foreach (ITestSuiteEntry testCse in testSuite.TestCases)
{
ITestCaseResultCollection results = testRun.QueryResults();
if (testCse.TestCase.Id == testCaseID)
{
foreach (IdAndName config in testCse.Configurations)
{
IEnumerable<ITestCaseResult> testCaseResults = from tr in results
where
tr.TestConfigurationId == config.Id &&
tr.TestCaseId == testCase.Id
select tr;
foreach (ITestCaseResult result in testCaseResults)
{
result.Outcome = passed ? TestOutcome.Passed : TestOutcome.Failed;
result.State = TestResultState.Completed;
result.Save(true);
}
}
}
}
}
testRun.Save();
testRun.Refresh();
}
}