TL; DR 两个gradle插件使用相同依赖项的不同版本,在调用其中一个插件时导致编译错误。
我有一个使用Gradle 4.x。
该项目依赖于两个插件:gradle-jaxb-plugin和serenity-gradle-plugin。
两个插件共享一个依赖项guice。
我需要升级其中一个插件(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
的类路径依赖项块来复制该问题答案 0 :(得分:3)
TL; DR:当Gradle插件共享依赖项但使用该依赖项的不同版本时,实际上只使用最高版本。您必须明确排除较高依赖性版本。
此处发生冲突是因为jaxb插件取决于guice:3.0
和guice-assistedinject:3.0
。
当宁静使用guice:4.0
时,guice:4.0
和guice-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
,但上述情况有效,所以我没有继续探索。