首先来复习一下几个重要知识点,然后接着进行一些介绍。在上一篇文章中,我曾经贴过下面这张图片:
在Which method stubs would you like to create?这里,现在结合4个标注的含义来说明一下:
@BeforeClass 标注的方法会在类加载的时候执行一次,且仅此一次,该方法必须是public和static的
@AfterClass 标注的方法会在类销毁的时候执行一次,且仅此一次,该方法必须是public和static的
@Before 标注的方法会在每个测试方法执行前先执行一次
@After 标注的方法会在每个测试方法执行结束后执行一次
以上四个标注,对应了那个勾选列表中的四个方法,可以在创建测试类时根据具体情况进行勾选。
在测试过程中,可能需要针对一个方法的不同临界值进行多组数据的测试。下面给出这种情况下的测试方法:
在上一遍文章中的例子 中,Calculator类的square方法需要针对正数、负数、零3种情况进行测试。所以我们如下进行,首先在Calculator类上右键new一 个JUint Test Case,起名为CalculatorSquareTest,然后该类的代码修改如下:
1 package org.logback.test; 2 3 import static org.junit.Assert.*; 4 5 import java.util.Arrays; 6 import java.util.Collection; 7 8 import org.junit.Before; 9 import org.junit.Test; 10 import org.junit.runner.RunWith; 11 import org.junit.runners.Parameterized; 12 import org.junit.runners.Parameterized.Parameters; 13 14 @RunWith(Parameterized. class ) 15 public class CalculatorSquareTest { 16 17 private static Calculator example = new Calculator(); 18 19 private int param; 20 21 private int result; 22 23 @Parameters//定义测试数据集合,前者param后者result 24 public static Collection data(){ 25 return Arrays.asList(new Object[][]{ 26 {2,4}, 27 {0,0}, 28 {-3,9}, 29 }); 30 } 31 32 @Before 33 public void setUp() throws Exception { 34 example.clear(); 35 } 36 37 @Test 38 public void testSquare() { 39 example.square(param); 40 assertEquals(result, example.getResult()); 41 } 42 43 //构造函数,对变量进行初始化,注意参数顺序应与定义的测试集合的参数顺序一致 44 public CalculatorSquareTest(int param,int result){ 45 this.param = param; 46 this.result = result; 47 } 48 49 }
14行设置了本测试类的运行器为Parameterized.class,因为此类需要多组数据,所以不能采用默认的运行器。
23-30行是定义测试数据集合,此处的2元组数据的顺序要统一,并且与构造函数的参数顺序要一致。
44-47行是构造函数,通过定义的数据集合和构造函数,将要测试的情况传递给测试类,然后进行测试。
也就是说,执行了3次该测试类,依次采用了数据集合中的数据。此例中数据集合的顺序顺序为{处理值,预期处理结果}。
结果如下:
可以看到runs那里是3/3。
OK,此时我们的测试类数量就已经上升为2个了,如果分别运行2个测试类再观察结果可能比较麻烦。或者有人觉得这还不算什么,那要是有10个测试类呢?所以就引出了打包测试的概念,我们可以通过JUnit提供的机制,一次性把之前的2个测试类都执行了。
在Calculator类上右键new一个JUnit Test Case,方法处什么都不勾选,然后点击Finish。将代码改为如下:
1 package org.logback.test; 2 3 import static org.junit.Assert.*; 4 5 import org.junit.Test; 6 import org.junit.runner.RunWith; 7 import org.junit.runners.Suite; 8 9 @RunWith(Suite.class) 10 @Suite.SuiteClasses({ 11 CalculatorSquareTest.class, 12 CalculatorTest.class 13 }) 14 public class CalculatorAllTest { 15 }
9行指定了此测试类的运行器
10-13行指定了要同时运行哪些测试类
该测试类并无实际实现
下面只要将此类run as JUnit Test即可,得到结果如图所示:
可以发现,我们上一遍文章的测试类,和这篇文章的测试类都同时执行了,并且列出了详细结果。以上就是我对于JUnit的研究结果,我感觉一般的工作这些技巧就可以应付了,当然如果哪位Geek有更高级方便的用法也欢迎分享。