首页 > 其他 > 详细

单元测试JUnit5上手

时间:2020-08-17 08:25:35      阅读:235      评论:0      收藏:0      [点我收藏+]

1. JUnit5的架构

JUnit 5 与以前版本的 JUnit 不同,拆分成由三个不同子项目的几个不同模块组成。

JUnit 5 = JUnit Platform + JUnit Jupiter + JUnit Vintage
  • JUnit Platform: 用于JVM上启动测试框架的基础服务,提供命令行,IDE和构建工具等方式执行测试的支持。
  • JUnit Jupiter:包含 JUnit 5 新的编程模型和扩展模型,主要就是用于编写测试代码和扩展代码。
  • JUnit Vintage:用于在JUnit 5 中兼容运行 JUnit3.x 和 JUnit4.x 的测试用例。

技术分享图片

2. JUnit Jupiter API 的使用

该API的基本特性 - 注解、断言等在平时的单元测试是常用的。与JUnit4相比,部分注解的名称有改变。

2.1 JUnit Jupiter注解

技术分享图片

 示例代码如下:

import lombok.extern.slf4j.Slf4j;
import org.junit.jupiter.api.AfterAll;
import org.junit.jupiter.api.AfterEach;
import org.junit.jupiter.api.BeforeAll;
import org.junit.jupiter.api.BeforeEach;
import org.junit.jupiter.api.Disabled;
import org.junit.jupiter.api.DisplayName;
import org.junit.jupiter.api.Test;
import org.springframework.boot.test.context.SpringBootTest;

import static org.junit.jupiter.api.Assertions.assertEquals;

@Slf4j
@SpringBootTest
class Junit5demoApplicationTests {

    @Test
    void contextLoads() {
        log.info("default contextLoads running");
    }

    @BeforeAll
    public static void init() {
        log.info("Before All, only run once on the start ");
    }

    @AfterAll
    public static void done() {
        log.info("After All, only run once on the end ");
    }

    @BeforeEach
    public void setUp() throws Exception {
        log.info("Before Each, run once on the every start ");
    }

    @AfterEach
    public void tearDown() throws Exception {
        log.info("After Each, run once on the every end ");
    }

    @Test
    @DisplayName("Dummy test")
    void aTest() {
        log.info("As written, this test will always pass!");
        assertEquals(4, (2 + 2));
    }

    @Test
    @Disabled
    @DisplayName("A disabled test")
    void testNotRun() {
        log.info("This test will not run (it is disabled, silly).");
    }
}

执行结果:

技术分享图片

 主要注解解释:

  • @RunWith 连同它的参数 JUnitPlatform.class (一个基于 JUnit 4 且理解 JUnit Platform 的 Runner )让您可以在 IDE 内运行 JUnit Jupiter 单元测试。
  • @DisplayName 告诉 JUnit 在报告测试结果时显示 String“Testing using JUnit 5”,而不是测试类的名称。
  • @BeforeAll 告诉 JUnit 在运行这个类中的所有 @Test 方法 之前 运行 init()方法 一次 。
  • @AfterAll 告诉 JUnit 在运行这个类中的所有 @Test 方法 之后 运行 done()方法 一次 。
  • @BeforeEach 告诉 JUnit 在此类中的 每个@Test 方法 之前 运行 setUp() 方法。
  • @AfterEach 告诉 JUnit 在此类中的 每个@Test 方法 之后 运行 tearDown()方法。
  • @Test 告诉 JUnit, aTest() 方法是一个 JUnit Jupiter 测试方法。
  • @Disabled 告诉 JUnit 不运行此 @Test 方法,因为它已被禁用。

2.2 JUnit Jupiter断言

断言 (assertion) 是 org.junit.jupiter.api.Assertions 类上的众多静态方法之一。断言用于测试一个条件,该条件必须计算为 true ,测试才能继续执行。
如果断言失败,测试会在断言所在的代码行上停止,并生成断言失败报告。如果断言成功,测试会继续执行下一行代码。

技术分享图片

使用如下:

技术分享图片

如果不正确,会打印如下信息:

技术分享图片

通过上面发现一个问题,一些断言顺序执行,如果中途出现一个断言失败,那么接下去的断言就会中止,所以引入另一个断言 assetAll() 来保证所有断言能够顺利执行。使用如下:

技术分享图片

 Junit5中新添加了对方法抛出异常的断言Assertions类中的assertThrows()和assertDoesNotThrow(),使用此方法可以对被测试方法抛出的异常进行断言测试,使用如下:

技术分享图片

  • assertThrows()主要对被测试方法的抛出异常进行测试,测试所抛出的异常是否满足预期。
  • assertDoesNotThrow()主要用来判定被测试方法是否抛出了异常,如果抛出异常则断言失败,无异常抛出则断言成功。

 

 

 

 

 

 

参考:

https://v.youku.com/v_show/id_XMjk1NTY4MTkxNg==.html

 

单元测试JUnit5上手

原文:https://www.cnblogs.com/zjfjava/p/13515283.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!