我需要编写一个由包含数据集合的数据文件驱动的单元测试。出于显而易见的原因,csv 文件不合适,但 XML 建议自己。但是我似乎无法让它工作。
这是数据文件的片段(仅显示一个测试记录):
<?xml version="1.0" encoding="utf-8" ?>
<testData>
<testRecord>
<displayColumnNames>
<name>Include</name>
<name>SampleInt1</name>
<name>SampleInt2</name>
<name>SampleInt3</name>
<name>SampleInt4</name>
<name>SampleInt5</name>
</displayColumnNames>
<valueColIDs>
<valueColID>1</valueColID>
<valueColID>3</valueColID>
<valueColID>5</valueColID>
</valueColIDs>
<calculations>
<calculation colID ="2"><![CDATA[500 * [:5]]></calculation>
<calculation colID ="5"><![CDATA[500 * [:2]]></calculation>
</calculations>
<expected>
<item>5</item>
</expected>
</testRecord>
</testData>
基本上,我希望能够从每个测试记录(例如“displayColumnNames”)中读取多个数据集合并迭代我的测试中的值。每个此类集合中的元素数量将因测试用例而异。
然而,直接的绊脚石是我的代码行:
var displayColumnNames = TestContext.DataRow["displayColumnNames"];
这会引发测试时错误“列'displayColumnNames'不属于表testRecord。”。
我可以让它与简单的“平面”xml 数据文件一起很好地工作,但这对我没有帮助。我是在尝试 VS2008(即 MSTest)无法处理的事情,还是在做一些愚蠢的事情?