2

我正在尝试使用此处介绍的 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)

有什么建议或帮助吗?

4

1 回答 1

3

您只是HashTable在测试用例数据中添加一个空白;您实际上需要在其中放入一些东西。你的代表应该是这样的:

...
.GetTestCases(delegate(string sheet, DataRow row, int rowNum)
{
    var testDataArgs = new Dictionary<string, object>();

    foreach (DataColumn column in row.Table.Columns)
    {
        testDataArgs[column.ColumnName] = row[column];
    }

    var testName = sheet + rowNum;
    return new TestCaseData(testDataArgs).SetName(testName);
}
于 2014-05-28T15:06:43.467 回答