解决gradle插件依赖冲突

时间:2018-03-04 22:15:09

标签: java gradle

  

TL; DR 两个gradle插件使用相同依赖项的不同版本,在调用其中一个插件时导致编译错误。

情况

  1. 我有一个使用Gradle 4.x。

  2. 编译的Java项目
  3. 该项目依赖于两个插件:gradle-jaxb-pluginserenity-gradle-plugin

  4. 两个插件共享一个依赖项guice

  5. 问题

    我需要升级其中一个插件(serenety)。升级会导致调用jaxb插件时发生冲突。

    ...
    Caused by: java.lang.NoClassDefFoundError: com/google/inject/internal/util/$Maps
            at com.google.inject.assistedinject.BindingCollector.<init>(BindingCollector.java:34)
            at com.google.inject.assistedinject.FactoryModuleBuilder.<init>(FactoryModuleBuilder.java:206)
            at org.openrepose.gradle.plugins.jaxb.schema.guice.DocSlurperModule.configure(DocSlurperModule.groovy:43)
    ...
    

    我做了一些调查和谷歌搜索,并且相当肯定这个问题的根源在于,当它过去使用guice 3.x时,serenity插件的版本使用guice 4.x. jaxb插件使用guice 3.x。

    问题

    如何将插件依赖项彼此分开?我想包括两个插件,但看起来gradle将采用最高的依赖集并在任何地方使用它。

    代码

    以下是build.gradle的相关部分

    buildscript {
        repositories {
            mavenCentral()
            maven { url 'https://plugins.gradle.org/m2/' }
        }
        dependencies {
            classpath 'gradle.plugin.org.openrepose:gradle-jaxb-plugin:2.4.1'
            classpath 'net.serenity-bdd:serenity-gradle-plugin:1.5.1'
        }
    }
    ...
    project(':integration-tests') {
        apply plugin: 'java'
        apply plugin: 'net.serenity-bdd.aggregator'
        ...
    }
    ...
    project(':cms-business-model') {
        apply plugin: 'org.openrepose.gradle.plugins.jaxb'
        apply plugin: 'java'
        ...
    }
    

    注意:您可以通过将serenity 1.5.1插件添加到the jaxb plugin examples

    的类路径依赖项块来复制该问题

1 个答案:

答案 0 :(得分:3)

  

TL; DR:当Gradle插件共享依赖项但使用该依赖项的不同版本时,实际上只使用最高版本。您必须明确排除较高依赖性版本。

此处发生冲突是因为jaxb插件取决于guice:3.0guice-assistedinject:3.0

当宁静使用guice:4.0时,guice:4.0guice-assistedinject:3.0

之间的版本不匹配

解决方案是将guice依赖性排除在宁静之外,从而回归guice:3.0

更新的代码

buildscript {
    repositories {
        mavenCentral()
        maven { url 'https://plugins.gradle.org/m2/' }
    }
    dependencies {
        classpath 'gradle.plugin.org.openrepose:gradle-jaxb-plugin:2.4.1'
        classpath ('net.serenity-bdd:serenity-gradle-plugin:1.5.1') {
            exclude group: 'com.google.inject', module:'guice'
        }
    }
}
...

替代解决方案

另一种可能性可能需要guice-assistedinject:4.0,但上述情况有效,所以我没有继续探索。