《JUnit实战(第2版)》—— 2.2 运行参数化测试

本节书摘来异步社区《JUnit实战(第2版)》一书中的第2章,第2.2节,作者:【美】Petar Tahchiev , Felipe Leme , Vincent Massol , Gary Gregory,更多章节内容可以访问云栖社区“异步社区”公众号查看。

2.2 运行参数化测试

JUnit实战(第2版)
Parameterized(参数化)的测试运行器允许你使用不同的参数多次运行同一个测试。代码2.2给出一个Parameterized运行器的实例(你可以在第1章的源代码示例中找到这个测试)。

代码2.2 参数化测试

《JUnit实战(第2版)》—— 2.2 运行参数化测试

要使用Parameterized的测试运行器来运行一个测试类,那就必须要满足以下要求。首先,测试类必须使用@RunWith注释,并且要将Parameterized类作为它的参数..Lucene实战1.tif。其次,你必须声明测试中所使用的实例变量..Lucene实战2.tif,同时提供一个用@Parameters注释的方法..Lucene实战3.tif,这里提供的是getTestParameters方法。此外,这个方法的签名必须是@Parameters public static java.util.Collection,无任何参数。Collection元素必须是相同长度的数组。这个数组的长度必须要和这个唯一的公共构造函数的参数数量相匹配。在我们的这个例子中,每个数组包含了3个元素,因为公共构造函数有3个参数。我们的示例使用这个方法来为测试提供输入值和预期的输出值。因为我们想要测试Calculator程序的add方法,所以我们提供了3个参数:expected值与两个待求和的值。在..Lucene实战4.tif处,我们为测试指定了需要的构造函数。注意,这次我们的测试用例没有无参数的构造函数,而有一个可以为测试接受参数的构造函数。在..Lucene实战5.tif处,我们最终实现了sum @Test方法,该方法实例化了Calculator程序..Lucene实战6.tif,并断言调用了我们所提供的参数..Lucene实战7.tif。

运行这个测试,将会根据@Parameters方法返回的Collection的大小,进行相同数量的循环。执行这个单独的测试用例的效果等同于执行以下具有不同参数的测试用例。

《JUnit实战(第2版)》—— 2.2 运行参数化测试

这里我们要逐步分析JUnit的运行过程,以充分理解这项强大的功能:JUnit调用了静态方法getTestParameters..Lucene实战3.tif。接下来,JUnit为getTestParameters集合中的每个数组进行循环..Lucene实战3.tif。然后,JUnit调用了唯一的公共构造函数..Lucene实战4.tif。如果存在多个公共构造函数,JUnit就会抛出一个断言错误。JUnit使用由数组元素构成的一系列参数来调用构造函数..Lucene实战4.tif。在这个示例中,JUnit使用数组中的第一个元素调用了有3个参数的构造函数..Lucene实战4.tif,而这个元素本身就是一个数组:{2,1,1}。然后JUnit会像平时一样调用@Test方法..Lucene实战5.tif。JUnit会为getTestParameters集合中的下一个数组重复以上过程..Lucene实战3.tif。

当你将这个测试结果与上一个示例进行比较时,你就会发现,参数化的JUnit测试运行器运行了同一个方法3次,为@Parameters集合中的每个值运行一次;而上一个示例只运行了一个测试。

JUnit的Parameterized类是JUnit众多测试运行器中的一个。测试运行器可以让你控制JUnit如何运行测试。接下来,我们来看一下其他的JUnit测试运行器。

上一篇:winform中textbox属性Multiline=true时全选


下一篇:《Redis官方文档》事件库