我在尝试将新发布版本部署到我公司的JFrog.io(fka:ArtifactoryOnline.com)存储库时遇到了一个奇怪的错误。我正在开发的项目有多个maven模块,所有这些模块都在一个单独的父项下。当我将maven构建的JAR文件上载到JFrog时,生成的POM文件将填充不正确的父artifactId。
我花了很多时间,发现我公司的项目代码库没有任何问题,所以我决定是否可以从头开始重现错误。因此我做了this throwaway project来证明这个bug。对于那些对下载完整项目不感兴趣的人,以下是相关的POM文件:
父母POM,"蓝莓":
<?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">
<modelVersion>4.0.0</modelVersion>
<groupId>org.nbyrd</groupId>
<artifactId>blueberry</artifactId>
<packaging>pom</packaging>
<version>1.0</version>
<modules>
<module>blueberryjam</module>
<module>berries</module>
</modules>
</project>
依赖POM 1:&#34;浆果&#34;:
<?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>blueberry</artifactId>
<groupId>org.nbyrd</groupId>
<version>1.0</version>
</parent>
<modelVersion>4.0.0</modelVersion>
<artifactId>berries</artifactId>
<build>
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<configuration>
<source>1.7</source>
<target>1.7</target>
</configuration>
</plugin>
</plugins>
</build>
</project>
依赖POM 2,&#34;浆果果酱&#34;:
<?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>blueberry</artifactId>
<groupId>org.nbyrd</groupId>
<version>1.0</version>
</parent>
<modelVersion>4.0.0</modelVersion>
<artifactId>blueberry-jam</artifactId>
<dependencies>
<dependency>
<groupId>org.nbyrd</groupId>
<artifactId>berries</artifactId>
<version>1.0</version>
</dependency>
</dependencies>
</project>
(对于它的价值,所有这些POM文件都是由JetBrains IntelliJ完全生成的。)
此时非常直接:我有两个Maven模块 - &#34;浆果&#34;和#34; berry-jam&#34; - 位于中央母模块下,&#34;蓝莓&#34;。 berry-jam使用浆果作为依赖,虽然我不确定这是否与问题相关。
当我构建项目时,我得到两个JAR文件:berries-1.0.jar
和berry-jam-1.0.jar
。这是预期的。此时,我会将这些工件上传到Artifactory,以便其他项目可以引用它们。这就是麻烦开始的地方。
当我上传berries-1.0.jar
时,Artifactory会生成以下POM文件:
<?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>berries</artifactId>
<groupId>org.nbyrd</groupId>
<version>1.0</version>
</parent>
<modelVersion>4.0.0</modelVersion>
<artifactId>berries</artifactId>
<build>
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<configuration>
<source>1.7</source>
<target>1.7</target>
</configuration>
</plugin>
</plugins>
</build>
</project>
如您所见,生成的POM将父artifactId定义为&#34; berries&#34;,这是错误的。
上传berry-jam-1.0.jar
时会出现同样的问题:
<?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>blueberry-jam</artifactId>
<groupId>org.nbyrd</groupId>
<version>1.0</version>
</parent>
<modelVersion>4.0.0</modelVersion>
<artifactId>blueberry-jam</artifactId>
<dependencies>
<dependency>
<groupId>org.nbyrd</groupId>
<artifactId>berries</artifactId>
<version>1.0</version>
</dependency>
</dependencies>
</project>
在这两种情况下,我都希望parentId是&#34; blueberry&#34;,因为它在两个子模块中都有明确说明。 POM文件。这些不正确的artifactIds使得无法使用这些库。如果第三方应用程序尝试使用这些库,maven将在下载依赖项时产生以下警告,并且构建将失败:
[警告] org.nbyrd:berries:jar:1.0的POM无效,传递依赖(如果有)将无法使用,启用调试日志记录以获取更多详细信息
此功能过去在上传到Artifactory时过去正常工作,所以我不确定工具的工作方式是否发生了变化,或者我是否做错了。有什么想法吗?
答案 0 :(得分:1)
当您使用mvn deploy
maven时,将pom.xml
文件部署为单独的工件。但是当你使用artifactory的web ui上传jar文件并询问artifactory以生成pom文件时,我猜它会从jar中的数据生成它。因此,神器不知道父项目的存在。