SpringBoot 集成JUnit5的详细操作过程

 更新时间:2024年10月15日 10:40:28   作者:冬天vs不冷  
JUnit5是最新的Java单元测试框架,提供了灵活的测试支持,它由JUnit Platform、JUnit Jupiter和JUnit Vintage组成,支持不同环境下的测试运行,SpringBoot从2.2版本开始默认支持JUnit5,本文介绍了SpringBoot 集成JUnit5的相关知识,感兴趣的朋友跟随小编一起看看吧

一、JUnit5介绍

  JUnit5是一个功能强大的单元测试框架,是JUnit系列的最新版本,它引入了多个改进和新特性,旨在为Java应用程序提供灵活且模块化的测试支持。

1、JUnit5组成结构

  • JUnit Platform:这个模块提供了测试的启动API和运行环境,是整个JUnit5框架的核心。它支持在不同的环境中运行测试,如命令行、IDE或构建工具(例如Maven、Gradle)
  • JUnit Jupiter:这个模块包含了JUnit5的新测试编写和扩展模型,提供了全新的注解、测试方法和扩展机制
  • JUnit Vintage:为了支持旧版本的JUnit测试(JUnit3和JUnit4),JUnit5提供了Vintage模块。这个模块允许开发者继续运行以前版本的测试,同时过渡到JUnit5

2、什么是单元测试

  • 单元测试是指对软件中的最小可测试单元进行检查和验证的过程叫单元测试
  • SpringBoot中,最小可测试单元就是指方法

二、SpringBoot整合JUnit5

1、快速入门

SpringBoot版本从2.2以后,默认支持JUnit5

<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-test</artifactId>
    <scope>test</scope>
</dependency>

测试类应放在src/test/java目录下

import org.junit.jupiter.api.Test;
import org.springframework.boot.test.context.SpringBootTest;
@SpringBootTest
class MySpringBootApplicationTests {
    @Test
    void contextLoads() {
        // 测试 Spring 应用上下文是否成功加载
    }
}

2、测试类和测试方法不需要声明为public

  • JUnit4中,测试类和测试方法必须是public的,因为JUnit4通过反射机制要求访问公共方法
  • JUnit5则没有这种要求,测试类和方法的可见性设为包级(默认)足够 JUnit 5 框架执行测试
    • 因为 JUnit 5 本质上是在测试框架内部执行这些测试
    • 包级别的可见性允许同一包内的类访问测试类,而不需要将其暴露为 public

3、@SpringBootTest工作原理

 它会启动整个Spring容器,加载应用程序的所有Bean,并创建一个完整的应用上下文。这是集成测试,因为它模拟了应用程序的真实运行环境。

查找主配置类的两种方式:

  包扫描:默认情况下,@SpringBootTest 会从测试类所在的包开始,向上查找同一包或父包中带有 @SpringBootApplication@SpringBootConfiguration注解的类,作为应用的配置类

  显式指定:如果 @SpringBootTest 无法自动找到 @SpringBootApplication 注解的配置类,或者你希望手动指定配置类,你可以在@SpringBootTest 注解中使用classes属性显式指定应用的配置类

4、生成单元测试类

在需要生成单元测试的类中按Alt +Ins,选择test(测试)

选择测试方法

生成的测试类放入与本类相同的包结构

在这里插入图片描述

三、常用注解

1、@BeforeAll

用于在所有测试方法之前执行的静态初始化代码

通常用于在执行所有测试之前进行一次性设置,例如建立数据库连接、初始化共享资源等

被注解的方法必须是static

@BeforeAll
static void setup() {
    System.out.println("Running setup before all tests...");
}

2、@AfterAll

  • 用于在所有测试方法执行完成后运行的静态清理代码
  • 通常用于释放资源、关闭连接等操作
  • 被注解的方法必须是static
@AfterAll
static void tearDown() {
    System.out.println("Running teardown after all tests...");
}

3、@BeforeEach

  • 用于在每个测试方法之前执行的初始化代码
  • 常用于在每个测试方法执行之前准备一些通用的数据或环境
@BeforeEach
void init() {
    System.out.println("Running setup before each test...");
}

4、@AfterEach

  • 用于在每个测试方法之后执行的清理代码
  • 常用于在每个测试方法之后恢复原状或清理一些资源
@AfterEach
void cleanup() {
    System.out.println("Running cleanup after each test...");
}

5、@DisplayName

用于为测试类或测试方法提供一个更具可读性或说明性的名称,便于在测试报告中展示

6、@Disabled

当执行所有测试方法时候,@Disabled注解的方法不会执行

7、@RepeatedTest

用于多次重复执行某个测试,可以指定重复次数

四、常用断言

  断言(Assertions)在单元测试中用于验证程序行为是否符合预期。JUnit 提供了一组用于编写断言的方法,断言的使用可以帮助判断测试是否通过。类名org.junit.jupiter.api.Assertions

1、assertEquals(expected, actual)

  • 验证两个对象是否相等
  • 可以用于各种数据类型,包括基本类型、对象等
assertEquals(5, 2 + 3);
assertEquals("Hello", greetingService.getGreeting());

2、assertNotEquals(expected, actual)

验证两个对象是否不相等

assertNotEquals(10, 2 + 3);

3、assertTrue(condition)

验证条件为true

assertTrue(5 > 3);

4、assertFalse(condition)

验证条件为false

assertFalse(3 > 5);

5、assertNull(actual)

验证对象是否为null

String str = null;
assertNull(str);

6、assertNotNull(actual)

验证对象是否不为null

String str = "Hello";
assertNotNull(str);

7、assertArrayEquals(expected, actual)

验证两个数组是否相等

数组的长度和元素的顺序都必须相同

int[] expected = {1, 2, 3};
int[] actual = {1, 2, 3};
assertArrayEquals(expected, actual);

8、assertSame(expected, actual)

验证两个对象引用是否指向同一个对象(即是同一个对象的引用)

Object obj = new Object();
assertSame(obj, obj);

9、assertNotSame(expected, actual)

验证两个对象引用是否不指向同一个对象

Object obj1 = new Object();
Object obj2 = new Object();
assertNotSame(obj1, obj2);

10、fail(message)

强制使测试失败

通常用于标记不应该被执行的代码路径

if (someCondition) {
    fail("Unexpected condition occurred");
}

11、带有消息参数的断言

  JUnit的断言方法通常有一个变体,可以带有一个额外的字符串参数,用于在测试失败时提供错误消息,帮助更快找到问题。

五、@MockBean注入

1、@MockBean的主要作用

@MockBean会将应用上下文中的某个Bean替换为模拟的Bean(Mock 对象)

@MockBean自动与Spring上下文集成,允许模拟的Bean被注入到需要它的其他Bean中

2、@MockBean的典型用法(模拟数据层)

  假设我们有一个UserService依赖于UserRepository,而我们在测试中不想使用真实的UserRepository,而是使用模拟对象

@Service
public class UserService {
    private final UserRepository userRepository;
    public UserService(UserRepository userRepository) {
        this.userRepository = userRepository;
    }
    public User getUserById(Long id) {
        return userRepository.findById(id);
    }
}
  • 使用@MockBean来模拟UserRepository
  • given方法模拟了userRepository.findById(1L) 方法的调用,并定义了当该方法被调用时,willReturn表示返回一个mockUser对象
import org.junit.jupiter.api.Test;
import org.mockito.BDDMockito;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.boot.test.mock.mockito.MockBean;
import static org.junit.jupiter.api.Assertions.assertEquals;
import static org.mockito.BDDMockito.given;
@SpringBootTest
public class UserServiceTest {
    @Autowired
    private UserService userService;
    // 模拟 UserRepository,替换掉应用上下文中的实际 Bean
    @MockBean
    private UserRepository userRepository;
    @Test
    void testGetUserById() {
        // 创建模拟数据
        User mockUser = new User(1L, "John Doe");
        // 使用 Mockito 的 BDD 风格方法设置模拟行为
        given(userRepository.findById(1L)).willReturn(mockUser);
        // 调用服务层方法,验证返回值是否符合预期
        User result = userService.getUserById(1L);
        assertEquals("John Doe", result.getName());
    }
}

到此这篇关于SpringBoot 集成JUnit5的文章就介绍到这了,更多相关SpringBoot 集成JUnit5内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Java Scala之面向对象

    Java Scala之面向对象

    Scala是一门面向对象的语言。在Scala中,一切皆为对象函数是对象,数字也是对象,本文详细介绍了Scala面向对象的原理和介绍,感兴趣的小伙伴可以参考一下
    2023-04-04
  • Java反射及性能详细

    Java反射及性能详细

    这篇文章主要介绍了Java反射及性能,现如今的java工程中,反射的使用无处无在。无论是设计模式中的代理模式,还是红透半边天的Spring框架中的IOC,AOP等等,都存在大量反射的影子。下面我们就对该话题进行详细介绍,感兴趣的小伙伴可以参考一下
    2021-10-10
  • drools中query的用法小结

    drools中query的用法小结

    这篇文章主要介绍了drools中query的使用,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-05-05
  • spring boot实现验证码功能

    spring boot实现验证码功能

    这篇文章主要为大家详细介绍了spring boot实现验证码功能,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-07-07
  • Java基础知识总结之继承

    Java基础知识总结之继承

    这一篇我们来学习面向对象的第二个特征——继承,文中有非常详细的基础知识总结,对正在学习java的小伙伴们很有帮助,需要的朋友可以参考下
    2021-06-06
  • java实现多人聊天室可视化

    java实现多人聊天室可视化

    这篇文章主要为大家详细介绍了java实现多人聊天室可视化,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-06-06
  • MyBatis源码分析之日志logging详解

    MyBatis源码分析之日志logging详解

    这篇文章主要给大家介绍了关于MyBatis源码分析之日志logging的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2019-03-03
  • Java内存划分:运行时数据区域

    Java内存划分:运行时数据区域

    听说Java运行时环境的内存划分是挺进BAT的必经之路,这篇文章主要给大家介绍了关于Java运行时数据区域(内存划分)的相关资料,需要的朋友可以参考下
    2021-07-07
  • springboot+mybatis+redis 二级缓存问题实例详解

    springboot+mybatis+redis 二级缓存问题实例详解

    Mybatis默认没有开启二级缓存,需要在全局配置(mybatis-config.xml)中开启二级缓存。本文讲述的是使用Redis作为缓存,与springboot、mybatis进行集成的方法。需要的朋友参考下吧
    2017-12-12
  • Java List排序4种写法整理

    Java List排序4种写法整理

    这篇文章主要给大家介绍了关于Java List排序4种写法整理的相关资料,在有的时候我们会需要对List进行排序,在Java中如何实现呢,本文记录一下Java中对List的几种排序方式,需要的朋友可以参考下
    2023-08-08

最新评论