【问题标题】:Jenkins + Gradle + Artifactory: Couldn't read generated build infoJenkins + Gradle + Artifactory:无法读取生成的构建信息
【发布时间】:2017-04-12 11:51:33
【问题描述】:

我正在尝试使用调用 Gradle 工具的 Jenkins Pipeline 将我的工件推送到 Artifactory。

我正在关注 GitHub 上发布的示例:

我的 Jenkins 流水线脚本:

stage('Perform Gradle Release') {

    //ssh-agent required to perform GIT push (when tagging the branch on release)
    sshagent([git_credential]) {
        sh "./gradlew clean release unSnapshotVersion -Prelease.useAutomaticVersion=true -Prelease.releaseVersion=${release_version} -Prelease.newVersion=${development_version}"
    }

    // Create an Artifactory server instance
    def server = Artifactory.server('my-artifactory')

    // Create and set an Artifactory Gradle Build instance:
    def rtGradle = Artifactory.newGradleBuild()
    rtGradle.resolver server: server, repo: 'libs-release'
    rtGradle.deployer server: server, repo: 'libs-release-local'

    //Use Gradle Wrapper
    rtGradle.useWrapper = true

    //Creates buildinfo
    def buildInfo = Artifactory.newBuildInfo()
    buildInfo.env.capture = true
    buildInfo.env.filter.addInclude("*")

    // Run Gradle:
    rtGradle.run rootDir: "./", buildFile: 'build.gradle', tasks: 'clean artifactoryPublish', buildInfo: buildInfo

    // Publish the build-info to Artifactory:
    server.publishBuildInfo buildInfo

}

我的Gradle文件很轻,我只是使用插件Gradle Release Plugin来进行gradle发布。

执行管道时,它失败并显示以下消息:

:artifactoryPublish

BUILD SUCCESSFUL

Total time: 17.451 secs
ERROR: Couldn't read generated build info at : /tmp/generated.build.info4898776990575217114.json
[Pipeline] }
[Pipeline] // stage
[Pipeline] }
[Pipeline] // node
[Pipeline] End of Pipeline
hudson.model.Run$RunnerAbortedException
    at org.jfrog.hudson.pipeline.Utils.getGeneratedBuildInfo(Utils.java:188)
    at org.jfrog.hudson.pipeline.steps.ArtifactoryGradleBuild$Execution.run(ArtifactoryGradleBuild.java:127)
    at org.jfrog.hudson.pipeline.steps.ArtifactoryGradleBuild$Execution.run(ArtifactoryGradleBuild.java:96)
    at org.jenkinsci.plugins.workflow.steps.AbstractSynchronousStepExecution.start(AbstractSynchronousStepExecution.java:40)
...
Finished: FAILURE

当我检查服务器时,没有这样的文件/tmp/generated.build.info4898776990575217114.json(用户当然有写入/tmp的权限)。

感谢您的帮助。

[编辑] 这很奇怪,但我发现了一些名为“buildInfo2408849984051060030.properties”的文件,其中包含这些信息。名称不一样,格式也不一样,而且这些文件存储在我的 Jenkins 机器上,而不是我执行管道的奴隶。

【问题讨论】:

  • Jenkins Artifactory Plugin 版本 2.8.2 对您的问题进行了一些改进。我们更改了保存生成文件的方式,此外,我们添加了更多信息日志。相关的提交可以在github.com/JFrogDev/build-info/commit/…找到。

标签: jenkins gradle release artifactory jenkins-pipeline


【解决方案1】:

感谢@tamir-hadad,它确实已在 2.8.2 上修复。

【讨论】:

    猜你喜欢
    • 2017-04-30
    • 1970-01-01
    • 1970-01-01
    • 2017-05-07
    • 2021-02-02
    • 2016-12-26
    • 2020-02-14
    • 2021-11-28
    • 2020-04-13
    相关资源
    最近更新 更多