我正在尝试使用此处介绍的 Excel 数据阅读器http://fabiouechi.blogspot.fi/2010/07/excel-data-driven-tests-with-nunit.html来读取我的 NUnit 测试的数据。
我的测试数据有几列——比如状态、运行、压力、p_prev、温度——以及 excel 文件中的 200 多行。
我正在使用以下代码来阅读测试用例。
public static IEnumerable<TestCaseData> TestCaseData_T3003
{
get
{
var testcases = ExcelTestCaseDataReader.New()
.FromFileSystem(@"C:\Tests\Test data.xlsx")
.AddSheet("T3003")
.GetTestCases(delegate(string sheet, DataRow row, int rowNum)
{
var testName = sheet + rowNum;
//var category = Convert.ToString(row["col1"]);
IDictionary testDataArgs = new Hashtable();
var testData = new TestCaseData(testDataArgs).SetName(testName);
return testData;
}
);
foreach (TestCaseData testCaseData in testcases)
{
yield return testCaseData;
}
}
}
public List<TestCaseData> GetTestCases(Func<string, DataRow, int, TestCaseData> testCaseDataCreator)
{
var testDataList = new List<TestCaseData>();
IExcelDataReader excelReader = GetExcelReader(ExcelFile);
excelReader.IsFirstRowAsColumnNames = true;
DataSet result = excelReader.AsDataSet();
foreach (var sheet in Sheets)
{
var sheetTable = result.Tables[sheet];
var i = 0;
foreach (DataRow dr in sheetTable.Rows)
{
testDataList.Add(testCaseDataCreator(sheet, dr, i));
i = i + 1;
}
}
excelReader.Close();
return testDataList;
}
而实际的测试,使用来自 excel 的数据,仍然非常原始。
[Test]
[TestCaseSource("TestCaseData_T3003")]
public void T3003_Excel(IDictionary testData)
{
//do the assertions here
}
问题是,我如何在我的测试过程中访问测试数据?如何引用“状态”或“压力”列中的值?
Nunit 在我的测试数据中找到所有行,因为它运行了 214 次测试。但是,当我在 T3003_Excel 中调试我的代码和面包时,属性 testData.Count 为零。哈希表 testData.Keys 的密钥集合的长度也是如此。(testData.Keys.Count = 0)
有什么建议或帮助吗?