问题排查
近日在使用过程中,发现在将Jar包上传到Maven仓库中时,遇到了一些问题。
错误日志大概为生成的Maven Pom文件中有重复的标签:dependencyManagement。
在看到错误信息后,感到很奇怪,为什么会有重复的标签生成,以及这个生成的POM文件又是在哪?
一番排查以后,确定了问题的来源。
由于使用的是 maven-publish 插件,可以看到该插件下可执行的任务。
执行publish这个任务,我们可以在日志中看到执行顺序依次为
generateMetadataFileForMavenPublication
generatePomFileForMavenPublication
publishMavenPublicationToMavenRepository
publish
复制代码
结合上面的错误信息,我们可以确定是在生成POM文件时出错的,就是在执行 generatePomFileForMavenPublication 这个任务中出错的。
接着再到build目录下查找生成的POM文件
可以看到生成了一个pom-default.xml 文件,打开这个文件,可以看到确实是生成了两个dependencyManagement标签 。
在看到两个dependencyManagement 标签中的内容分别对应着
自定义BOM 、 io.spring.dependency-management
version.gradle
复制代码
至此,可以确定是在执行 generatePomFileForMavenPublication 中,显式使用的 dependcyManagement和插件生成的标签重复了
解决方式
既然确定了是在哪个task中生成的,又不想改动之前的依赖版本控制方式,那我们就改动该task生成的POM文件,将该标签合并
task fixPom {
doLast {
File file = new File("$buildDir/publications/maven/pom-default.xml")
def text = file.text
def pattern = "(?s)(<dependencyManagement>.+?<dependencies>)(.+?)(</dependencies>.+?</dependencyManagement>)"
Matcher matcher = text =~ pattern
if (matcher.find()) {
text = text.replaceFirst(pattern, "")
def firstDeps = matcher.group(2)
text = text.replaceFirst(pattern, '$1$2' + firstDeps + '$3')
}
file.write(text)
}
}
generatePomFileForMavenPublication.finalizedBy fixPom
复制代码
在执行 publish 时就可以看到publish成功了
作者:肆格张
链接:https://juejin.cn/post/7225432788043595831