您好!欢迎来到源码码网

Spring Boot 工程中 maven-surefire-plugin 测试执行失败及解决方法

  • 源码教程
  • 来源:源码码网
  • 编辑:源码码网
  • 时间:2025-10-13 10:57
  • 阅读:583

Spring Boot 工程编译时遇到maven-surefire-plugin的测试执行失败错误(Failed to execute goal org.apache.maven.plugins:maven-surefire-plugin:3.5.3:test),通常与测试环节相关。以下是常见原因及解决方法:

1. 测试用例执行失败

• 原因:最常见的是测试用例(*Test.java)运行时抛出异常(如断言失败、空指针等),导致 Surefire 插件执行中断。

• 解决

◦ 查看错误日志中更详细的堆栈信息,找到具体失败的测试类和方法(通常在[ERROR] Tests run: X, Failures: Y, Errors: Z之后)。

◦ 修复对应测试用例的逻辑错误,确保测试能正常通过。

2. 测试依赖或环境问题

• 原因:测试代码依赖的类、配置或外部资源(如数据库、服务)缺失或异常,导致测试无法运行。

• 解决

◦ 检查测试类中是否引用了未正确初始化的资源(如@Autowired Bean 未加载)。

◦ 确保测试环境依赖(如数据库)已启动,或使用@Mock等注解模拟依赖。

◦ 若使用 Spring Boot 测试,确保测试类标注了@SpringBootTest,且上下文能正常加载。

3. Surefire 插件版本或配置冲突

• 原因:插件版本与 JDKSpring Boot 版本不兼容,或配置有误(如测试类路径、排除规则等)。

• 解决

◦ 检查版本兼容性Spring Boot 通常会管理 Surefire 插件版本,建议移除手动指定的版本,使用 Spring Boot 父工程的默认版本:

<build>
  <plugins>
    <plugin>
      <groupId>org.apache.maven.plugins</groupId>
      <artifactId>maven-surefire-plugin</artifactId>
      <!-- 移除version,使用spring-boot-starter-parent管理的版本 -->
    </plugin>
  </plugins>
</build>

◦ 排除特定测试:若某些测试暂时无需执行,可配置插件跳过:

<plugin>
  <groupId>org.apache.maven.plugins</groupId>
  <artifactId>maven-surefire-plugin</artifactId>
  <configuration>
    <!-- 排除单个测试类 -->
    <excludes>
      <exclude>**/ProblematicTest.java</exclude>
    </excludes>
  </configuration>
</plugin>

4. 临时跳过测试环节

• 若需紧急编译打包,可临时跳过测试(不推荐长期使用,需确保测试最终能通过):

◦ 命令行执行:mvn clean package -DskipTests(跳过测试执行,但编译测试代码)

◦ 或:mvn clean package -Dmaven.test.skip=true(完全跳过测试代码的编译和执行)

5. 其他常见问题

• JDK 版本问题:确保 JDK 版本与 Surefire 插件兼容(如 JDK 17 + 建议使用 Surefire 3.0+)。

测试类命名不符合规范:默认情况下,Surefire 只执行命名为*Test.java、Test*.java、*Tests.java的类,若测试类命名不符,会被忽略(但不会报错,需结合具体日志判断)。

关键步骤

1. 仔细查看错误日志中紧跟在错误提示后的具体测试失败信息(堆栈跟踪),定位问题根源。

2. 优先修复测试用例的逻辑或环境依赖问题,确保测试可正常运行。

3. 若涉及插件配置,尽量遵循 Spring Boot 的默认配置,避免版本冲突。


最终经过一系列的排查,原因是TlsSocketStrategy.class 文件的缺失导致,由于httpclient5:5.3版本及以下不存在该类文件。

所以将httpclient5的依赖版本直接升级到5.4或者更高版本问题即可街道解决。

<!-- 核心 HTTP 客户端功能 -->
    <dependency>
        <groupId>org.apache.httpcomponents.client5</groupId>
        <artifactId>httpclient5</artifactId>
        <version>5.4</version>
    </dependency>


特别声明:
1、如无特殊说明,内容均为本站原创发布,转载请注明出处;
2、部分转载文章已注明出处,转载目的为学习和交流,如有侵犯,请联系客服删除;
3、编辑非《源码码网》的文章均由用户编辑发布,不代表本站立场,如涉及侵犯,请联系删除;
全部评论(0)
推荐阅读
  • 原生小程序和封装的小程序有什么区别
  • 原生小程序和封装的小程序有什么区别
  • 原生小程序和封装的小程序是两种不同的开发模式,主要区别在于开发方式、性能表现、代码维护以及跨平台能力。为了让你更清晰地理解,我们可以把“原生”比作用钢筋水泥直接盖楼,而“封装”则是用预制板或套件来组装楼。以下是详细的对比分析:1.定义与本质原生小程序:定义: 直接使用微信官方提供的开发工具、语法和API进行开发。语言: 使用微信自己定义的一套技术栈(WXML(微信标记语言)做结构、WXSS(微信样式表)做样式、JS
  • 行业资讯
  • 来源:源码码网
  • 编辑:源码码网
  • 时间:2026-03-06 11:54
  • 阅读:179
  • 深度解读:一颗“感知”气息的MEMS传感器,如何定义雾化设备的交互未来?
  • 深度解读:一颗“感知”气息的MEMS传感器,如何定义雾化设备的交互未来?
  • 消费电子与物联网设备智能化普及,人与机器之间的交互方式早已不再局限于按键的“咔哒”声。从智能手机的触控滑动,到智能音箱的语音唤醒,交互正朝着更自然、更无感的方向演进。而在电子雾化设备(如雾化器、电子烟)这一细分领域,一种看似微小却至关重要的交互变革正在发生:如何精准、可靠地识别用户的“吸气”动作?答案,藏在了一颗不足3毫米见方的微型芯片里——MEMS气流压力开关传感器。我们不谈晦涩的术语,而是以一颗具体的产品——MS2202AA-M05
  • 源码教程
  • 来源:源码码网
  • 编辑:源码码网
  • 时间:2026-03-06 11:41
  • 阅读:40
  • 基于NetCore(Razor Page)开发的Cms建站系统MIT协议
  • 基于NetCore(Razor Page)开发的Cms建站系统MIT协议
  • FytSoaCms一款基于NetCore2.2/3.1(RazorPage)功能强大的Cms建站系统,支持前后端分离。简介:模块化:全新的架构和模块化的开发机制,便于灵活扩展和二次开发。模型/栏目/分类信息体系:通过栏目和模型绑定,以及不同的模型类型,不同栏目可以实现差异化的功能,轻松实现诸如资讯、下载、讨论和图片等功能。通过分类信息和栏目绑定,可以自动建立索引表,轻松实现复杂的信息检索。FytSoa是一套基于NetCore+SqlS
  • 开发工具
  • 来源:gitee
  • 编辑:源码码网
  • 时间:2026-01-24 22:21
  • 阅读:278
  • 基于JAVA开发的企业级平台微信公众号管理系统SmartWx
  • 基于JAVA开发的企业级平台微信公众号管理系统SmartWx
  • SmartWx微信公众号管理系统是一个完整的微信公众号web操作版,直接编译即可运行。让用户不再用关心微信的底层接口,直接使用页面进行操作,简单方便。包括服务器绑定、文本管理、图文管理、菜单管理、粉丝管理、群发消息等。技术框架开发语言:JAVA数据库:MYSQLJAVA开发框架:SpringMVC+Spring+Mybatis缓存框架:j2cache前端开发框架:Layui+JQuery+html前台模板引擎:art-templat
  • 源码教程
  • 来源:gitee
  • 编辑:源码码网
  • 时间:2026-01-24 21:53
  • 阅读:272
  • 前后端分离的Java快速开发平台renren-security可免费商用
  • 前后端分离的Java快速开发平台renren-security可免费商用
  • renren-security是一个轻量级的,前后端分离的Java快速开发平台,能快速开发项目并交付【接私活利器】采用SpringBoot3.x、Shiro、MyBatis-Plus、Vue3、TypeScript、ElementPlus、VueRouter、Pinia、Axios、Vite框架,开发的一套权限系统,极低门槛,拿来即用。设计之初,就非常注重安全性,为企业系统保驾护航,让一切都变得如此简单。提供了代码生成器,只
  • 源码教程
  • 来源:gitee
  • 编辑:源码码网
  • 时间:2026-01-23 13:03
  • 阅读:174
联系客服
源码代售 源码咨询 技术开发 联系客服
029-84538663
手机版

扫一扫进手机版
返回顶部