JUnit & JMockit单元测试

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集成单元测试工具



    4.12
    1.34



   
     org.jmockit
             jmockit
             ${jmockit.version}
             test
      
         
     junit
             junit
             ${junit.versioin}
             test
         

4.单元测试的使用

  • JUnit4基础语法

    Junit4.x区别与之前的版本,无需显示的声明测试类继承于TestCase。通过使用Junit annotation进行编写单元测试用例。

    • @Test: 标识测试方法
    • @Ignore: 被忽略的测试方法或测试类
    • @Before: 初始化方法,在任何一个测试执行之前必须执行的代码
    • @After: 释放资源,在任何测试执行之后需要进行的收尾工作。在每个测试方法执行之后执行一次,该annotation只能修饰public void 方法;

    • @BeforeClass: 针对所有测试,只执行一次,且必须为public static void;一般用于初始化必要的消耗较大的
      资源,例如数据库连接等
    • @AfterClass: 针对所有测试,将会在所有测试方法执行结束后执行一次,且必须为public static void;
    • @Parameters: 进行单元测试的时候,通常一个方法需要好几个case进行测试,Junit提供参数化便于我们对方法进行多种参数的组合测试
      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的注解只针对该测试用例。

    • @Injectable:仅Mock被修饰的对象
      @Injectable是针对单个实例的,可用于测试类成员mock field与参数用例参数mock parameter。对mock field的注解作用于整个测试类,而对mock parameter的注解只针对该测试用例。

    • @Capturing:可以mock接口以及其所有的实现类
      @Capturing 标识一个被Mock的对象,从该对象派生的子类也被Mock了。可以通过maxInstances方法来指定最大有多少层子类也被mock。当然和@Mocked以及@Injectable一样,均可用作class field和测试用例的参数的注解。同时,它是针对类型的。

    • @Tested:指定被测试的对象
      @Tested标识一个被测对象的实例。通过@Tested标签标识的被测对象实例,将会在测试方法执行之前被初始化。

    • @Mock:MockUp模式中,指定被Fake的方法

你可能感兴趣的:(JUnit & JMockit单元测试)