• VS2010中的自动化测试(3)——数据驱动的单元测试


    有时,我们会对同一条测试用例根据不同的输入数据运行多次测试。为了不重复写单元测试代码,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文件。

    Capture

    创建好数据源之后,我们重新转到测试工程,然后打开Test View或者Test List Editor窗口,选中我们要连接数据源的测试用例,右键属性,然后点击Data Connection String属性,它会弹出一个连接向导,选择CSV文件,然后选择刚刚保存的csv文件。选择完成之后,该测试用例的属性如下图所示:

    Capture2

    然后会注意到我们之前的测试函数上多加了几个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的。我们双击其中一行的结果还能进一步查看它运行的详情。

    Capture3

    相关文章:

    VS2010中的自动化测试(5)——Web性能测试(2)

    VS2010中的自动化测试(4)——Web性能测试(1)

    VS2010中的自动化测试(2)——单元测试

    VS2010中的自动化测试(1)——VS2010中的测试管理工具

  • 相关阅读:
    laravel blog 一
    dede:channelartlist currentstyle高亮显示
    dede调用导航/幻灯
    rmp 安装LNMP环境
    无极分类之子孙树、父辈树
    创始人 密码
    mysql报错显示法文解决办法
    渐变色背景
    laravel sendmail
    工作流系统webservice服务
  • 原文地址:https://www.cnblogs.com/heqichang/p/2202441.html
Copyright © 2020-2023  润新知