XDocument没有返回预期的元素

时间:2014-09-09 13:20:07

标签: c# linq-to-xml

我完成了我的研究并尝试了很多试验,但这让我很难过。我可能很厚,但考虑到以下XML文档,我怎样才能最容易地找到UnitTestResult元素?

<?xml version="1.0" encoding="UTF-8"?> 
<TestReport> 
   <TestRun id="5cbd568d-02e4-4003-96c7-3d82cc0c2060" name="neil@HP6550BTS2 2014-09-08 15:23:16" runUser="AS\neil" xmlns="http://microsoft.com/schemas/VisualStudio/TeamTest/2006">   
      <Results>
         <UnitTestResult executionId="c3194ea8-adec-4e50-a4b6-45e244c50963" testId="8e220518-d603-0136-5937-819380dd4738" testName="NewRowMatrixResourceBookingTest" computerName="HP6550BTS2" duration="00:00:00.0204886" startTime="2014-09-08T15:23:32.3595341+01:00" endTime="2014-09-08T15:23:33.8396821+01:00" testType="13cdc9d9-ddb5-4fa4-a97d-d965ccfc6d4b" outcome="Passed" testListId="2fc4d891-506d-45de-8c61-cf6aa44e8eb2">
            <Output>
            </Output>
         </UnitTestResult>
         <UnitTestResult executionId="c20b289e-4af5-4827-a35d-39360dec984a" testId="d48055d1-0a28-af07-4490-2bfca70dbbcf" testName="MatrixScreen_Checkout_NewScreenVersionLockedReason1" computerName="HP6550BTS2" duration="00:00:07.1635460" startTime="2014-09-08T15:23:33.8466828+01:00" endTime="2014-09-08T15:23:41.0143995+01:00" testType="13cdc9d9-ddb5-4fa4-a97d-d965ccfc6d4b" outcome="Passed" testListId="2fc4d891-506d-45de-8c61-cf6aa44e8eb2">
            <Output>
            </Output>
         </UnitTestResult>   
      </Results> 
   </TestRun> 
</TestReport>

我已经尝试了

xdoc.Descendants("UnitTestResult")

xdoc.Elements("TestReport").Elements("TestRun").Elements("Results").Elements("UnitTestResult")

以及

var ns = "http://microsoft.com/schemas/VisualStudio/TeamTest/2006";
var x = from result in testReport.Elements("TestReport").Elements(XName.Get(ns, "TestRun")).Elements("Results").Elements("UnitTestResult")

以及其他各种变体,但它们都会产生空枚举。

我做错了什么?

5 个答案:

答案 0 :(得分:2)

如何

XNamespace ns = "http://microsoft.com/schemas/VisualStudio/TeamTest/2006";

yourXmlDocument.Descendants(ns + "UnitTestResult");

注意XNamespace的明确定义,否则编译器会将类型推断为string而不是XNamespace

答案 1 :(得分:1)

除非另有明确声明,否则声明默认名称空间的节点的后代将继承相同的名称空间。因此,您需要为<Results><UnitTestResult>使用相同的名称空间前缀:

XNamespace ns = "http://microsoft.com/schemas/VisualStudio/TeamTest/2006";
var x = from result in xdoc.Elements("TestReport")
                           .Elements(ns+"TestRun")
                           .Elements(ns+"Results")
                           .Elements(ns+"UnitTestResult");

答案 2 :(得分:0)

虽然使用XmlDocument类而不是XDocument类,但是在尝试操作.testsettings文件以确保启用代码覆盖率时,我之前遇到过类似的问题。我用来实现此功能的代码如下所示,您可以尝试使用该代码作为启动和运行的基础。我认为关键部分是使用ms命名空间后缀以及声明命名空间。

XmlDocument testSettings = new XmlDocument();
testSettings.Load(fullSettingsPath);

// Load the XML Namespace manager we need for reading the .testsettings file
XmlNamespaceManager xmlnsm = new XmlNamespaceManager(testSettings.NameTable);
xmlnsm.AddNamespace("ms", "http://microsoft.com/schemas/VisualStudio/TeamTest/2010");

XmlNodeList coverageNodes = testSettings.SelectNodes(
    @"ms:TestSettings/ms:Execution/ms:AgentRule/ms:DataCollectors/ms:DataCollector[@uri='datacollector://microsoft/CodeCoverage/1.0']/ms:Configuration/CodeCoverage",
    xmlnsm);

答案 3 :(得分:0)

所有其他答案都包括名称空间声明,这可能是正确的解决方案。您可能希望忽略名称空间无关的解决方案:

xdoc.Descendants()
    .Where(node => node.Name.LocalName == "UnitTestResult")

无论定义的命名空间如何都会产生结果

答案 4 :(得分:0)

private void AtribesAndInnerTexts(string pathToFile)
{

  var doc = new System.Xml.XmlDocument();
  doc.LoadXml(File.ReadAllText(pathToFile));
    // desired node in this case UnitTestResult
  var UnitTestResults = doc.GetElementsByTagName("UnitTestResult");
    foreach (var unitTestResult in UnitTestResults)
    {
        Console.WriteLine(((XmlElement) unitTestResult).GetAttribute("executionId"));
        Console.WriteLine(((XmlElement) unitTestResult).InnerText);
    }
}