有时,我们会对同一条测试用例根据不同的输入数据运行多次测试。为了不重复写单元测试代码,VS允许我们的每一条单元测试函数都可以连接自己的数据源,数据源的文件格式可以是CSV、XML、SQL Server数据库或者Oracle数据库等。
下面我继续使用上次进行单元测试的函数,该函数体如下:
public double CalculateTotalPrice(double quantity)
{
double totalPrice;
double unitPrice;
unitPrice = 16.0;
totalPrice = unitPrice * quantity;
return totalPrice;
}
然后按照平常那样创建一个单元测试之后,修改测试代码如下:
[TestMethod()]
public void CalculateTotalPriceTest()
{
Class1 target = new Class1();
double quantity = 10F;
double expected = 160F;
double actual;
actual = target.CalculateTotalPrice(quantity);
Assert.AreEqual(expected, actual);
}
现在来开始创建测试用例的数据源,我直接就用一个CSV文件就行了。打开Excel,输入数据如下,然后保存为.csv文件。
创建好数据源之后,我们重新转到测试工程,然后打开Test View或者Test List Editor窗口,选中我们要连接数据源的测试用例,右键属性,然后点击Data Connection String属性,它会弹出一个连接向导,选择CSV文件,然后选择刚刚保存的csv文件。选择完成之后,该测试用例的属性如下图所示:
然后会注意到我们之前的测试函数上多加了几个Attribute。现在我们重新修改一下单元测试代码:
[DataSource("Microsoft.VisualStudio.TestTools.DataSource.CSV",
"|DataDirectory|\\test.csv", "test#csv",
DataAccessMethod.Sequential),
DeploymentItem("TestProject1\\test.csv"),
TestMethod()]
public void CalculateTotalPriceTest()
{
Class1 target = new Class1();
double quantity = Convert.ToDouble
(this.testContextInstance.DataRow["Quantity"]);
double expected = Convert.ToDouble
(this.testContextInstance.DataRow["ExpectedPrice"]);
double actual;
actual = target.CalculateTotalPrice(quantity);
Assert.AreEqual(expected, actual);
}
最后我们运行一下这个测试用例,结果如下所示,我们可以看到在它的运行结果里面还有每一行数据的运行结果,如果其中有一行数据Fail,那我们的整体结果就是Fail的。我们双击其中一行的结果还能进一步查看它运行的详情。
相关文章: