SpringBoot单元测试Maven打包时不运行的问题
问题
今天正常写代码,碰到一个问题,单元测试在Maven打包的时候死活不自动运行,明明我没有skip test,为什么会出现这种情况,于是我翻遍了百度、谷歌,将问题定位到了Maven插件版本太低。
可是公司用的Springboot版本还是挺高的呀?明明是2.6.11来着,对此我打开了一个以前的项目,对比了一下插件版本发现,坏了!真的是插件版本太低了!
可是我明明没有去设置Maven插件呀,因为一直是写业务,项目不是自己搭建的,就一直没深究 POM 文件,正好兴趣来了就仔细排查了一下,在父 POM 中发现了如下写法:
然后我将如上写法改成了继承 spring-boot-starter-parent 试了一下,发现就好了,真是要想事半功倍,必先利其器!
所以我们平常时开发springboot
项目时,pom文件中引入的依赖,总是少不了spring-boot-starter-parent
或spring-boot-dependencies
,今天我们就简单来探讨一些两者的区别。
官方文档:docs.spring.io/spring-boot…
spring-boot-starter-parent
spring-boot-starter-parent 是一个启动项目,它为基于 spring 的应用程序提供默认配置。它作为父级添加到 pom.xml 文件中。
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>x.x.x</version> <!-- spring boot version number -->
<relativePath/> <!-- lookup parent from repository -->
</parent>
spring-boot-starter-parent 将spring-boot-dependencies
定义为其父级,继承自spring-boot-dependencies
的依赖管理。每个 Spring Boot 版本都提供了一个依赖项列表和它支持的最新版本。
通过依赖管理特性允许公共依赖省略pom.xml
文件中的<version>
标签,案例如下:
<dependencies>
<dependency>
<groupId>org.springframework.data</groupId>
<artifactId>spring-data-jpa</artifactId>
</dependency>
<dependencies>
注:如果一个依赖项需要一个特定的版本,而不是启动父配置的版本,可以使用<version>
标签。
属性
我们知道 spring-boot-starter-parent 使用其内部定义的属性来配置 java 编译器版本、Maven 插件版本和 Dependencies 版本。我们可以在属性部分下的 pom.xml 文件中覆盖这些属性值。假设我们的项目需要不同版本的sl4j库和不同的java版本。
<properties>
<java.version>1.8</java.version>
<slf4j.version>1.7.30</slf4j.version>
</properties>
功能
Maven用户可以继承 spring-boot-starter-parent 项目,来获取最佳依赖。这个父项目提供了以下几个功能:
- Java 1.8 作为默认编译器级别。
- UTF-8 编码格式
- Java编译时加上了
-parameters
参数 - 依赖管理部分,可让你对公共依赖省略version标签,继承自spring-boot-dependencies POM。
- 默认的插件配置,将
spring-boot-maven-plugin
默认配置为打包可执行jar,为 maven-surefire-plugin、maven-jar-plugin 和 maven-failsafe-plugin 等 Maven 插件提供默认配置 - 针对特定配置文件的资源过滤(例如:application.properties 和 application.yml)
例如第1点、第6点配置如下:
Tips: 注意,由于 application.properties 和 application.yml 文件接受 spring 样式的占位符(${…}
),所以 maven filter 将更改为使用@…@
占位符。(可以通过设置名为 resource.delimiter 的 maven 属性来覆盖该属性。)
例如在 application.properties,如下
password=@jdbc.password@
ps:上次还莫名其妙看到过一个同事这种写法,当时还以为是Maven的什么特殊写法,原来是SpringBoot修改了占位符呀~
spring-boot-dependencies
如果我们想继承自定义父POM或者手动定义所有Maven配置,我们就不能继承 spring-boot-starter-parent。那怎么办呢?没错,我们我们仍然可以从 spring-boot-dependencies 提供的依赖管理功能(而不是插件管理)中受益,方法如下:
<dependencyManagement>
<dependencies>
<dependency>
<!-- 从 Spring Boot 引入依赖管理 -->
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-dependencies</artifactId>
<version>x.x.x</version> <!-- spring boot version number -->
<type>pom</type>
<scope>import</scope>
</dependency>
</dependencies>
</dependencyManagement>
注意:如果我们要覆盖单个依赖项的属性,我们需要在添加 spring-boot-dependencies 之前添加这些依赖项。例如,要使用不同版本的slf4j
库
<dependencyManagement>
<dependencies>
<!-- Override SLF4J provided by Spring Boot -->
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-api</artifactId>
<version>1.7.30</version>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-dependencies</artifactId>
<version>x.x.x</version>
<type>pom</type>
<scope>import</scope>
</dependency>
</dependencies>
</dependencyManagement>
打包可执行Jar
因为依赖 spring-boot-dependencies,那么就不具备 spring-boot-starter-parent 项目的插件管理功能了, 所以你就需要自己手动加入spring-boot-maven-plugin
插件并设置为打包可执行Jar,如以下示例所示:
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
<executions>
<execution>
<goals>
<goal>repackage</goal>
</goals>
</execution>
</executions>
</plugin>
</plugins>
</build>
注:如果您正在使用spring-boot-starter-parent
,则已经预先配置了repackage
,因此只需添加插件定义。
有时候你可能还会碰到Maven提示编译版本过低的问题,那还需要手动指定maven-compiler-plugin
插件
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<version>x.x.x</version> <!-- maven-compiler-plugin version number -->
<configuration>
<source>${java.version}</source>
<target>${java.version}</target>
<encoding>${project.build.sourceEncoding}</encoding>
</configuration>
</plugin>
</plugins>
转载自:https://juejin.cn/post/7166976755935215629