我目前正在使用.NET 3.5 for Windows CE。 XmlReader实现是自定义的,属于设备制造商。考虑到这一点,XmlReader可能很简单。
我有以下测试代码:
[TestFixture]
public class XmlUtilsTest
{
private const string EXAMPLE_XML =
"<Level1>"
+ "<Level2>"
+ "</Level2>"
+ "<Level2>"
+ "<Level3>Some text</Level3>"
+ "</Level2>"
+ "</Level1>";
[Test]
public void GetElementsAtPathTest()
{
IEnumerable<XmlReader> results = XmlUtils.GetElementsAtPath(EXAMPLE_XML, "Level1", "Level2");
XmlReader[] readers = results.ToArray();
Assert.AreEqual(2, readers.Length);
Assert.AreEqual("Level2", readers[0].Name);
Assert.AreEqual("Level2", readers[1].Name);
}
}
对于以下方法:
public static IEnumerable<XmlReader> GetElementsAtPath(string xml, params string[] path)
{
using (XmlReader reader = new XmlReader(xml))
{
if (!MoveToElementAtPath(reader, path))
yield break;
string siblingName = path[path.Length - 1];
do
{
XmlReader output = reader.ReadSubtree();
output.Read();
PrintLine(output.Name + " " + output.NodeType);
yield return output;
}
while (reader.ReadToNextSibling(siblingName));
}
}
在我的do-while循环中打印为我提供了我期望的输出:
Level2 Element
Level2 Element
然而测试失败了:
Failed : GetElementsAtPathTest
Expected string length 6 but was 0. Strings differ at index 0.
Expected: "Level2"
But was: <string.Empty>
不知何故,在运行方法和断言结果之间,XmlReader.Name的状态已经改变。
我认为我在这里犯了一些愚蠢的错误,但我一直盯着这几个小时看不到任何明显的东西。有线索吗?
答案 0 :(得分:0)
另外30分钟对抗这件事情,结果是ReadSubtree()没有返回一个新对象。通过在IEnumerable上调用ToArray,测试无意中读到了文档的末尾。
//XmlReader output = reader.ReadSubtree();
XmlReader output = new XmlReader(reader.ReadOuterXml());