Artifactory / JFrog在生成的POM中生成错误的父artifactId

时间:2017-08-29 19:00:51

标签: java maven pom.xml artifactory

我在尝试将新发布版本部署到我公司的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.jarberry-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.nb​​yrd:berries:jar:1.0的POM无效,传递依赖(如果有)将无法使用,启用调试日志记录以获取更多详细信息

此功能过去在上传到Artifactory时过去正常工作,所以我不确定工具的工作方式是否发生了变化,或者我是否做错了。有什么想法吗?

1 个答案:

答案 0 :(得分:1)

当您使用mvn deploy maven时,将pom.xml文件部署为单独的工件。但是当你使用artifactory的web ui上传jar文件并询问artifactory以生成pom文件时,我猜它会从jar中的数据生成它。因此,神器不知道父项目的存在。