文章目录
-
JUnit&JMockit单元测试总结
-
1.JUnit简介
- 2.JMockit简介
- 3.Maven集成单元测试工具
- 4.单元测试的使用
JUnit&JMockit单元测试总结
1.JUnit简介
Java单元测试框架业内应用较多的是JUnit,它由Kent Beck和Erich Gamma建立,逐渐成为源于Kent Beck的sUnit的xUnit家族中最为成功的一个。 JUnit有它自己的JUnit扩展生态圈。多数Java的开发环境都已经集成了JUnit作为单元测试的工具。
目前JUnit主流版本有3.x,4.x和5.x,目前继续推荐使用4.x版本,各个IDE中也自动集成了它。
2.JMockit简介
基于Junit单元测试的框架有很多,包括EasyMock、JMock、mockito、JMockit等。Mock框架也能进行stub的测试方法。但通过各种测试框架的对比,JMockit对于目前流行的测试方法全部支持,功能强大。因此选择JMockit作为Junit单元测试的框架。
JMockit是帮助创建mock对象的工具,它基于Java开发,在Java测试与开发环境中有不可比拟的优势,更重要的是,它大大简化了虚拟对象的使用。
3.Maven集成单元测试工具
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22 1<!‐‐版本号‐‐>
2<properties>
3 <junit.versioin>4.12</junit.versioin>
4 <jmockit.version>1.34</jmockit.version>
5</properties>
6<!‐‐依赖‐‐>
7<dependencies>
8 <dependency>
9 <groupId>org.jmockit</groupId>
10 <artifactId>jmockit</artifactId>
11 <version>${jmockit.version}</version>
12 <scope>test</scope>
13 </dependency>
14 <dependency>
15 <groupId>junit</groupId>
16 <artifactId>junit</artifactId>
17 <version>${junit.versioin}</version>
18 <scope>test</scope>
19 </dependency>
20</dependencies>
21
22
4.单元测试的使用
- JUnit4基础语法
Junit4.x区别与之前的版本,无需显示的声明测试类继承于TestCase。通过使用Junit annotation进行编写单元测试用例。
-
@Test: 标识测试方法
-
@Ignore: 被忽略的测试方法或测试类
-
@Before: 初始化方法,在任何一个测试执行之前必须执行的代码
-
@After: 释放资源,在任何测试执行之后需要进行的收尾工作。在每个测试方法执行之后执行一次,该annotation只能修饰public void 方法;
-
@BeforeClass: 针对所有测试,只执行一次,且必须为public static void;一般用于初始化必要的消耗较大的
-
资源,例如数据库连接等
1
2
3
4 1* @AfterClass: 针对所有测试,将会在所有测试方法执行结束后执行一次,且必须为public static void;
2
3* @Parameters: 进行单元测试的时候,通常一个方法需要好几个case进行测试,Junit提供参数化便于我们对方法进行多种参数的组合测试
4
4.9之后引入@Rule和@ClassRule,本质上是对@BeforeClass, @AfterClass, @Before, @After等的另一种实现,只是功能上更灵活多变,易于扩展,且方便在类和项目之间共享。
两个注解使用时需要放在实现了TestRule接口的Rule变量或返回Rule的方法之上,且修饰符都必须为public。@Rule为变量或方法级注解,每个测试方法执行时都会调用被该注解修饰的Rule;@ClassRule为类级注解,执行单个测试类时只会调用一次被该注解修饰的Rule。
- JMockit基础语法
JMockit的测试更多是基于注解来实现的。Jmockit中常用的注解有:
- @Mocked:被修饰的对象将会被Mock,对应的类和实例都会受影响(同一个测试用例中)
@Mocked是针对类型的,可用于测试类成员mock field与参数用例参数mock parameter。对mock field的注解作用于整个测试类,而对mock parameter的注解只针对该测试用例。
1
2 1* @Injectable:仅Mock被修饰的对象
2
@Injectable是针对单个实例的,可用于测试类成员mock field与参数用例参数mock parameter。对mock field的注解作用于整个测试类,而对mock parameter的注解只针对该测试用例。
1
2 1* @Capturing:可以mock接口以及其所有的实现类
2
@Capturing 标识一个被Mock的对象,从该对象派生的子类也被Mock了。可以通过maxInstances方法来指定最大有多少层子类也被mock。当然和@Mocked以及@Injectable一样,均可用作class field和测试用例的参数的注解。同时,它是针对类型的。
1
2 1* @Tested:指定被测试的对象
2
@Tested标识一个被测对象的实例。通过@Tested标签标识的被测对象实例,将会在测试方法执行之前被初始化。
1
2 1* @Mock:MockUp模式中,指定被Fake的方法
2