您好,登录后才能下订单哦!
Springboot集成JUnit5优雅进行单元测试?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。
为什么使用JUnit5
简介

如图,JUnit5结构如下:
依赖引入
我们以SpringBoot2.3.1为例,引入如下依赖,防止使用旧的junit4相关接口我们将其依赖排除。
    <dependency>
      <groupId>org.springframework.boot</groupId>
      <artifactId>spring-boot-starter-test</artifactId>
      <scope>test</scope>
      <exclusions>
        <exclusion>
          <groupId>org.junit.vintage</groupId>
          <artifactId>junit-vintage-engine</artifactId>
        </exclusion>
      </exclusions>
    </dependency>常用注解
断言
JUnit Jupiter提供了强大的断言方法用以验证结果,在使用时需要借助java8的新特性lambda表达式,均是来自org.junit.jupiter.api.Assertions包的static方法。
assertTrue与assertFalse用来判断条件是否为true或false
  @Test
  @DisplayName("测试断言equals")
  void testEquals() {
    assertTrue(3 < 4);
  }assertNull与assertNotNull用来判断条件是否为·null
  @Test
  @DisplayName("测试断言NotNull")
  void testNotNull() {
    assertNotNull(new Object());
  }assertThrows用来判断执行抛出的异常是否符合预期,并可以使用异常类型接收返回值进行其他操作
  @Test
  @DisplayName("测试断言抛异常")
  void testThrows() {
    ArithmeticException arithExcep = assertThrows(ArithmeticException.class, () -> {
      int m = 5/0;
    });
    assertEquals("/ by zero", arithExcep.getMessage());
  }assertTimeout用来判断执行过程是否超时
  @Test
  @DisplayName("测试断言超时")
  void testTimeOut() {
    String actualResult = assertTimeout(ofSeconds(2), () -> {
      Thread.sleep(1000);
      return "a result";
    });
    System.out.println(actualResult);
  }assertAll是组合断言,当它内部所有断言正确执行完才算通过
  @Test
  @DisplayName("测试组合断言")
  void testAll() {
    assertAll("测试item商品下单",
        () -> {
          //模拟用户余额扣减
          assertTrue(1 < 2, "余额不足");
        },
        () -> {
          //模拟item数据库扣减库存
          assertTrue(3 < 4);
        },
        () -> {
          //模拟交易流水落库
          assertNotNull(new Object());
        }
    );
  }重复性测试
在许多场景中我们需要对同一个接口方法进行重复测试,例如对幂等性接口的测试。
JUnit Jupiter通过使用@RepeatedTest(n)指定需要重复的次数
  @RepeatedTest(3)
  @DisplayName("重复测试")
  void repeatedTest() {
    System.out.println("调用");
  }
参数化测试
参数化测试可以按照多个参数分别运行多次单元测试这里有点类似于重复性测试,只不过每次运行传入的参数不用。需要使用到@ParameterizedTest,同时也需要@ValueSource提供一组数据,它支持八种基本类型以及String和自定义对象类型,使用极其方便。
  @ParameterizedTest
  @ValueSource(ints = {1, 2, 3})
  @DisplayName("参数化测试")
  void paramTest(int a) {
    assertTrue(a > 0 && a < 4);
  }内嵌测试
JUnit5提供了嵌套单元测试的功能,可以更好展示测试类之间的业务逻辑关系,我们通常是一个业务对应一个测试类,有业务关系的类其实可以写在一起。这样有利于进行测试。而且内联的写法可以大大减少不必要的类,精简项目,防止类爆炸等一系列问题。
@SpringBootTest
@AutoConfigureMockMvc
@DisplayName("Junit5单元测试")
public class MockTest {
  //....
  @Nested
  @DisplayName("内嵌订单测试")
  class OrderTestClas {
    @Test
    @DisplayName("取消订单")
    void cancelOrder() {
      int status = -1;
      System.out.println("取消订单成功,订单状态为:"+status);
    }
  }
}看完上述内容是否对您有帮助呢?如果还想对相关知识有进一步的了解或阅读更多相关文章,请关注亿速云行业资讯频道,感谢您对亿速云的支持。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。