JUnit 4是2005年推出的,它基于Java 5的注释、反射等特性开发,因此JUnit 5的运行条件是Java 5以上的环境。
JUnit 5完全使用当前的Java 8重写了所有代码,因此JUnit 5的运行条件是Java 8环境。
Junit4使用注意事项和规范:
- 新建一个source folder目录来存放测试代码
- 测试类使用Test作为类名后缀
- 测试方法上必须使用@Test进行修饰
- 测试方法必须为public无参无返方法
- 测试方法使用test作为前缀
- 测试类的包名与被测试类一致
- 测试单元中的每个方法必须可以独立测试,测试方法间不能有任何依赖
Junit Errors 和 Failures的差别:
- Errors是由代码异常引起的,表明代码中有错误或bug
- Failures是断言方法判断失败引起的,代表实际值和期望值不一致
一个JUnit4的单元测试用例(只包含一个@Test)执行顺序为: @BeforeClass -> @Before -> @Test -> @After -> @AfterClass:
一个JUnit4的单元测试用例(包含两个@Test)执行顺序为: @BeforeClass -> @Before -> @Test1 -> @After -> @Before -> @Test2 -> @After -> @AfterClass:
- @BeforeClass修饰的方法会在所有方法被调用前被执行 而且该方法是静态的,所以当测试类被加载后接着就会运行它 而且在内存中它只会存在一份实例,比较适合加载配置文件
- @Before和@After会在每个测试方法的前后各执行一次
- @AfterClass所修饰的方法通常用来对资源的管理,如关闭数据库的连接
其他注解:
@Ignore("说明") 忽略某个@Test的测试方法
@Test(expected=XX.class) 检查被测方法是否抛出XX异常,只有抛出该异常时才算成功,其他所有情况都是失败或错误
@Test(timeout=毫秒) 检查被测方法是否在指定时间内运行结束,如果超时则错误
@RunWith 可以更改测试运行器,默认为org.junit.runner.Runner
测试套件@RunWith(Suite.class):用来组织测试类一起运行,当你有很多测试类需要运行的时候,总不能一个一个去运行吧,这时就可以用到测试套件
Junit参数化设置@RunWith(Parameterized.class):提高代码复用率
package com.imooc.util; import 略; @RunWith(Parameterized.class) public class ParameterTest { /* * 1.更改默认的测试运行器为RunWith(Parameterized.class) * 2.声明变量来存放预期值 和结果值 * 3.声明一个返回值 为Collection的公共静态方法,并使用@Parameters进行修饰 * 4.为测试类声明一个带有参数的公共构造函数,并在其中为之声明变量赋值 */ int expected; int input1; int input2; @Parameters public static Collection<Object[]> t() { return Arrays.asList(new Object[][]{ {3,1,2}, {4,2,2} }) ; } public ParameterTest(int expected,int input1,int input2) { this.expected = expected; this.input1 = input1; this.input2 = input2; } @Test public void testAdd() { assertEquals(expected, new Calculate().add(input1, input2)); } }
运行过程:根据返回的Collection,在堆内存中创建Collection.size个实例,每个实例由不同的参数调用构造函数生成,所以每个实例都不一样,object中的数据顺序与构造函数的参数顺序对应,每个实例建好后各自运行@Test,实现了不同参数测试的目的
在web app开发中,junit主要用于测试业务层和数据交互层