背景资料:
项目结构为:xxx-parent(父pom),xxx-client(子pom,jar包),xxx-web(子pom,war包,依赖xxx-client)
我们的maven项目打包时,在根目录下,使用
mvn clean -U package -pl xxx-web -am -P $PROFILE -Dmaven.test.skip=$SKIP_TEST
进行打包。基于资料可知,此时应该将xxx-web包,及其依赖的module(xxx-client)一起进行build。(资料:按需构建多模块,玩转Maven反应堆,maven guide: multiple modules,maven cli references)
但是实际使用时,xxx-client没有被build,导致无法在打包的同时,进行client包的编译(主要目的是进行代码检查、client文档上传)。
几经尝试后,发现是pom.xml中的version设置问题。
在项目中出于方(偷)便(懒)考虑,父pom的dependencyManagement的版本限制,和子pom的version定义,都使用了变量定义在父pom里。如下。
父pom:
<properties>
<project-parent.version>1.0-SNAPSHOT</project-parent.version>
<project-client.version>1.2</project-client.version>
<project-web.version>1.0-SNAPSHOT</project-web.version>
</properties>
子pom:
<parent>
<groupId>com.abc.ddd</groupId>
<artifactId>xxx</artifactId>
<version>1.0-SNAPSHOT</version>
</parent>
<modelVersion>4.0.0</modelVersion>
<artifactId>xxx-client</artifactId>
<version>${project-client.version}</version>
<packaging>jar</packaging>
<name>${project.artifactId}</name>
<url>http://maven.apache.org</url>
pom 使用变量作为自身的version声明 一直不被maven团队支持,编译时会高亮WARNING提示。此次使用-pl -am,却没有按预期进行依赖编译,算是忽视它的代价。
将version独立声明后,再次打包,能够顺利触发xxx-client的编译,问题得到解决。如下。
子pom改:
<parent>
<groupId>com.abc.ddd</groupId>
<artifactId>xxx</artifactId>
<version>1.0-SNAPSHOT</version>
</parent>
<modelVersion>4.0.0</modelVersion>
<artifactId>xxx-client</artifactId>
<version>1.2</version>
<packaging>jar</packaging>
<name>${project.artifactId}</name>
<url>http://maven.apache.org</url>