当前位置: 首页 > news >正文

在Maven多模块项目中进行跨模块的SpringBoot单元测试

项目结构:

demo-root(父模块,pom.xml)
├── **demo-common**          -- 通用模块(核心工具类、常量、基础配置)
├── ...
├── **demo-system**          -- 系统模块(用户/角色/权限等核心业务)
└── **demo-app**             -- 启动模块(主应用,依赖其他模块)

demo-app模块下的RootApplication.java:

package org.example.app;import org.mybatis.spring.annotation.MapperScan;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;@SpringBootApplication
@MapperScan("org.example.*.mapper")
@ComponentScan("org.example")
public class RootApplication {public static void main(String[] args) {SpringApplication.run(RootApplication.class, args);}}

demo-system模块下的mapper层单元测试类:

package org.example.system.mapper;import org.example.system.domain.entity.User;
import org.junit.jupiter.api.Test;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;import java.util.List;import static org.junit.jupiter.api.Assertions.*;@SpringBootTest(classes = org.example.app.RootApplication.class) // 跨模块需指定启动类
class UserMapperTest {@Autowiredprivate UserMapper userMapper;@Testvoid test() {List<User> users = userMapper.selectList(null);System.out.println(users);}
}

demo-system模块的pom.xml:

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"><parent><artifactId>demo-root</artifactId><groupId>org.example</groupId><version>0.0.1-SNAPSHOT</version></parent><modelVersion>4.0.0</modelVersion><artifactId>demo-system</artifactId><properties><maven.compiler.source>11</maven.compiler.source><maven.compiler.target>11</maven.compiler.target></properties><dependencies><dependency><groupId>org.example</groupId><artifactId>demo-app</artifactId><version>0.0.1-SNAPSHOT</version></dependency><dependency><groupId>org.example</groupId><artifactId>demo-common</artifactId><version>0.0.1-SNAPSHOT</version></dependency></dependencies>
</project>

因为User实体继承自BaseEntity,所以为了获取到完整的User,打印继承字段和非继承字段,所以需要增加lombok配置。

@Data注解是可以继承基类的,所以在超类中可以不写,超类也会有非继承字段的getter/setter。

在实体类中添加两个注解。

package org.example.system.domain.entity;import com.baomidou.mybatisplus.annotation.TableName;
import lombok.Data;
import lombok.EqualsAndHashCode;
import lombok.ToString;
import org.example.common.model.BaseEntity;@TableName("users")
@EqualsAndHashCode  // lombok注解,自动处理继承字段。已在lombok.config配置callSuper=True
@ToString(callSuper = true) // lombok注解,自动处理继承字段
public class User extends BaseEntity {private String username;
}

在根目录下新建一个lombok.config文件:

# 自动为所有 @ToString 添加 callSuper=true
lombok.toString.callSuper=CALL# 自动为所有 @EqualsAndHashCode 添加 callSuper=true
lombok.equalsAndHashCode.callSuper=CALL

demo-system模块下的service层单元测试类:

package org.example.system.service;import org.example.system.domain.entity.User;
import org.junit.jupiter.api.Test;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;import java.util.List;import static org.junit.jupiter.api.Assertions.*;@SpringBootTest(classes = org.example.app.RootApplication.class)
public class IUserServiceTest {@Autowiredprivate IUserService userService;@Testvoid test() {List<User> list = userService.list();System.out.println(list);}
}

遇到的其他问题:在运行demo-system模块下的service层单元测试类时,demo-app模块下的启动类扫到了demo-common模块下的JWT工具类显示配置文件读取失败,使用@Value注解的字段无法读取正确的参数值。

Caused by: java.lang.IllegalArgumentException: Could not resolve placeholder 'jwt.secret' in value "${jwt.secret}"

原因分析:所有模块的配置文件都叫application.yml,在正式运行时,只会加载读取启动模块的配置文件,并且, 单元测试不会自动读取src/main/resources下的配置文件,而是优先从src/test/resources/加载。

解决方案:对多模块项目的配置文件,非启动模块的配置文件采用application-xxx.yml的命名方式,并在启动模块下的配置文件中激活,确保所有模块的配置文件都可以被正常加载读取。
application-common.yml:

jwt:secret: "" # 建议用Base64编码# JWT 的签名算法(如 HS256)要求密钥是 256 位(32 字节)。Base64 编码可以确保密钥长度正确,避免因密钥长度不足导致的安全问题。expiration: 86400 # Token有效期(秒),默认1天(JwtUtils 中的 expiration 单位是秒
spring:profiles: common

application.yml:

server:port: 8080
spring:profiles:include: common, system

为使单元测试正常,直接复制主配置文件到测试资源目录:src/test/resources/application.yml


总结:

在Maven多模块项目中进行跨模块的SpringBoot单元测试的几个要点。

第一,在启动类中指定组件扫描路径和mapper包路径,引入启动模块依赖,在单元测试类中指定启动类。

第二,使用实体基类需添加lombok配置。

第三,差异化命名各模块的配置文件,并在启动模块的配置文件中激活。最后复制主配置文件到测试资源目录。


补充:后为正常运行启动类,我把写了数据库连接配置的application-system.yml放到启动模块下。

http://www.dtcms.com/a/278575.html

相关文章:

  • 【橘子分布式】Thrift RPC(理论篇)
  • vscode 安装 esp ide环境
  • LeetCode-283. 移动零(Java)
  • 【STM32】什么在使能寄存器或外设之前必须先打开时钟?
  • Pandas-特征工程详解
  • 零基础入门Java虚拟机与单例模式:新手友好教程
  • Modbus 开发工具实战:ModScan32 与 Wireshark 抓包分析(二)
  • VSCODE 选中多行 需要同时按住alt键才可以
  • ShenYu实战、问题记录
  • 记字节前端面试一道简单的算法题
  • 注解@Autowired和@Resource的区别
  • CentOS7 OpenSSL升级1.1.1t;OpenSSH 升级 9.8p1 保姆级教程
  • jenkins 流水线比较简单直观的
  • 《每日AI-人工智能-编程日报》--2025年7月14日
  • Spring Boot - Spring Boot 集成 MyBatis 分页实现 PageHelper
  • 17.Python 中的相等性比较:== vs is
  • 具身智能零碎知识点(五):VAE中对使用KL散度的理解
  • 【Java EE初阶 --- 网络原理】初识网络
  • flink 和 spark 架构的对比
  • 如何在 Java 中使用 Redis 实现缓存优化?
  • 4G模块 A7670发送英文短信到手机
  • 11.设置 Python 3 和 pip 3 为默认版本
  • Google的Mediapipe开源框架介绍及使用说明
  • 基于浅切多道的晶圆切割 TTV 均匀性控制与应力释放技术
  • python学智能算法(十八)|SVM基础概念-向量点积
  • CentOS 安装jenkins笔记
  • windows在anaconda中下载安装fasttext
  • jenkins搭建笔记
  • .gitignore文件中的各种写法详解
  • JMeter 连接与配置 ClickHouse 数据库