【问题标题】:Maven - Different Dependency Version in TestMaven - 测试中的不同依赖版本
【发布时间】:2022-05-22 09:31:39
【问题描述】:

我遇到了类似于Maven 2 - different dependency versions in test and compile 的问题,但那里的指定答案不起作用。

在我的项目中,我需要依赖 Hadoop 的 Cloudera 发行版和用于 JUnit 测试的“香草”版本,因为前者仅适用于 *nix。

当我尝试执行我的应用程序时,我得到Exception in thread "main" java.lang.NoClassDefFoundError: org/apache/hadoop/conf/Configuration。当我从 Maven 或 Eclipse 运行 JUnit 测试时,一切正常。如果我注释掉 test 依赖项,应用程序运行成功。

test 依赖项未注释时,为什么 compile 依赖项会被忽略?

    <dependency>
        <groupId>org.apache.hadoop</groupId>
        <artifactId>hadoop-core</artifactId>
        <version>0.20.2-cdh3u2</version>
        <scope>compile</scope>
    </dependency>

    <dependency>
        <groupId>org.apache.hadoop</groupId>
        <artifactId>hadoop-core</artifactId>
        <version>1.0.0</version>
        <scope>test</scope>
    </dependency>

    <dependency>
        <groupId>org.apache.hadoop</groupId>
        <artifactId>hadoop-test</artifactId>
        <version>1.0.0</version>
        <scope>test</scope>
    </dependency>

mvn dependency:list 如下所示。 compile 作用域版本根本不显示:

[INFO] The following files have been resolved:
[INFO]    ant:ant:jar:1.6.5:test
[INFO]    aopalliance:aopalliance:jar:1.0:compile
[INFO]    asm:asm:jar:3.3.1:compile
[INFO]    cglib:cglib:jar:2.2.2:compile
[INFO]    ch.qos.logback:logback-classic:jar:1.0.0:compile
[INFO]    ch.qos.logback:logback-core:jar:1.0.0:compile
[INFO]    com.google.guava:guava:jar:r08:compile
[INFO]    com.h2database:h2:jar:1.3.164:test
[INFO]    com.jolbox:bonecp:jar:0.7.1.RELEASE:compile
[INFO]    com.sun.jersey:jersey-core:jar:1.11:test
[INFO]    commons-beanutils:commons-beanutils:jar:1.7.0:test
[INFO]    commons-beanutils:commons-beanutils-core:jar:1.8.0:test
[INFO]    commons-cli:commons-cli:jar:1.2:test
[INFO]    commons-codec:commons-codec:jar:1.4:test
[INFO]    commons-collections:commons-collections:jar:3.2.1:test
[INFO]    commons-configuration:commons-configuration:jar:1.6:test
[INFO]    commons-digester:commons-digester:jar:1.8:test
[INFO]    commons-el:commons-el:jar:1.0:test
[INFO]    commons-httpclient:commons-httpclient:jar:3.0.1:test
[INFO]    commons-lang:commons-lang:jar:2.4:test
[INFO]    commons-logging:commons-logging:jar:1.1.1:compile
[INFO]    commons-net:commons-net:jar:1.4.1:test
[INFO]    hsqldb:hsqldb:jar:1.8.0.10:test
[INFO]    junit:junit:jar:4.10:test
[INFO]    mysql:mysql-connector-java:jar:5.1.18:compile
[INFO]    net.java.dev.jets3t:jets3t:jar:0.7.1:test
[INFO]    net.sf.kosmosfs:kfs:jar:0.3:test
[INFO]    org.apache.commons:commons-math:jar:2.1:test
[INFO]    org.apache.ftpserver:ftplet-api:jar:1.0.0:test
[INFO]    org.apache.ftpserver:ftpserver-core:jar:1.0.0:test
[INFO]    org.apache.ftpserver:ftpserver-deprecated:jar:1.0.0-M2:test
[INFO]    org.apache.hadoop:hadoop-core:jar:1.0.0:test
[INFO]    org.apache.hadoop:hadoop-test:jar:1.0.0:test
[INFO]    org.apache.mina:mina-core:jar:2.0.0-M5:test
[INFO]    org.codehaus.jackson:jackson-core-asl:jar:1.0.1:test
[INFO]    org.codehaus.jackson:jackson-mapper-asl:jar:1.0.1:test
[INFO]    org.eclipse.jdt:core:jar:3.1.1:test
[INFO]    org.hamcrest:hamcrest-core:jar:1.1:test
[INFO]    org.liquibase:liquibase-core:jar:2.0.3:test
[INFO]    org.liquibase.ext:liquibase-slf4j:jar:0.0.1:test
[INFO]    org.mortbay.jetty:jetty:jar:6.1.26:test
[INFO]    org.mortbay.jetty:jetty-util:jar:6.1.26:test
[INFO]    org.mortbay.jetty:jsp-2.1:jar:6.1.14:test
[INFO]    org.mortbay.jetty:jsp-api-2.1:jar:6.1.14:test
[INFO]    org.mortbay.jetty:servlet-api:jar:2.5-20081211:test
[INFO]    org.mortbay.jetty:servlet-api-2.5:jar:6.1.14:test
[INFO]    org.slf4j:jcl-over-slf4j:jar:1.6.4:compile
[INFO]    org.slf4j:log4j-over-slf4j:jar:1.6.4:compile
[INFO]    org.slf4j:slf4j-api:jar:1.6.4:compile
[INFO]    org.springframework:spring-aop:jar:3.1.1.RELEASE:compile
[INFO]    org.springframework:spring-asm:jar:3.1.1.RELEASE:compile
[INFO]    org.springframework:spring-beans:jar:3.1.1.RELEASE:compile
[INFO]    org.springframework:spring-context:jar:3.1.1.RELEASE:compile
[INFO]    org.springframework:spring-context-support:jar:3.1.1.RELEASE:compile
[INFO]    org.springframework:spring-core:jar:3.1.1.RELEASE:compile
[INFO]    org.springframework:spring-expression:jar:3.1.1.RELEASE:compile
[INFO]    org.springframework:spring-jdbc:jar:3.1.1.RELEASE:compile
[INFO]    org.springframework:spring-test:jar:3.1.1.RELEASE:test
[INFO]    org.springframework:spring-tx:jar:3.1.1.RELEASE:compile
[INFO]    org.springframework.data:spring-data-hadoop:jar:1.0.0.BUILD-SNAPSHOT:c
ompile
[INFO]    oro:oro:jar:2.0.8:test
[INFO]    tomcat:jasper-compiler:jar:5.5.12:test
[INFO]    tomcat:jasper-runtime:jar:5.5.12:test
[INFO]    xmlenc:xmlenc:jar:0.52:test

【问题讨论】:

  • mvn dependency:listhadoop-core 显示什么?
  • @Raghuram 我已经编辑了问题以显示这一点。谢谢!

标签: maven hadoop cloudera


【解决方案1】:

你想要的,对 Maven 3 不再有效(这曾经对 Maven 2 有效)。 Maven 3 将尝试获取最近的依赖项,有效地确保在编译和测试阶段只使用一个编译或测试范围的依赖项。

在您的情况下,org.apache.hadoop:hadoop-core:1.0.0:test 覆盖 org.apache.hadoop:hadoop-core:0.20.2-cdh3u2:compile,因此成为最近的依赖项。在运行mvn dependency:list 目标时,您可能会看到 Maven 显示以下警告,这暗示这是您的项目模型中的问题:

[警告] 'dependencies.dependency.(groupId:artifactId:type:classifier)' 必须是 独特的:org.apache.hadoop:hadoop-core:jar -> 版本 0.20.2-cdh3u2 vs 1.0.0 @ line xyz, column xyz

要“解决”这个问题,最好将测试拆分到一个单独的项目中,其项目模型可以定义一组单独的测试依赖项。

【讨论】:

    【解决方案2】:

    看起来像一个 maven 错误 - 或者如果不是,那是足够可疑的东西,如果有的话,我不会相信文档。

    在你的情况下,我可能会:

    1. 升级 maven 看看问题是否在最新的 m3 中得到修复
    2. 尝试使用另一个工件 ID 或组名重新打包其中一个 hadoop 版本。 maven-shade-plugin,不用改包名,只需要介绍一些maven不知道的东西和org.apache.hadoop:hadoop-core没有什么区别
    3. 尝试将测试移至下游的单独项目
    4. 开始调试 maven 并准确了解发生了什么(然后退回到 1 或 2...)

    【讨论】:

    • 感谢您的帮助!我尝试了选项 2,但奇怪的是它仍然表现出相同的行为。我想知道其中一个 .jar 中是否存在导致问题的东西?
    • 尝试 2 时,请确保您已完全着色 - 如果您仍然过渡依赖于原始工件,它将无法正常工作。
    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 2011-12-22
    • 1970-01-01
    • 2016-09-18
    • 1970-01-01
    • 2012-04-05
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多