一尘不染

从脚本返回的值未分配给在jenkins声明式管道阶段中声明的变量

jenkins

我正在为自动化测试添加jenkins声明性管道。在测试运行阶段,我想从日志中提取失败的测试。我正在使用Groovy函数提取测试结果。此功能不是詹金斯管道的一部分。这是另一个脚本文件。该函数运行良好,并构建了一个包含故障详细信息的字符串。在管道阶段内,我正在调用此函数并将返回的字符串分配给另一个变量。但是,当我回显变量值时,它会打印出空字符串。

pipeline {
    agent {
        kubernetes {
            yamlFile 'kubernetesPod.yml'
        }
    }
    environment{
        failure_msg = ""
    }
    stages {
        stage('Run Test') {
            steps {
                container('ansible') {
                    script {
                        def notify = load('src/TestResult.groovy')
                        def result = notify.extractTestResult("${WORKSPACE}/testreport.xml")
                        sh "${result}"
                        if (result != "") {
                            failure_msg = failure_msg + result
                        }
                    }

                }  
            }
        }
    post {
        always {
            script {
                sh 'echo Failure message.............${failure_msg}'
                }
        }
    }
}

在这里’sh’echo $ {result}’‘打印空字符串。但是’extractTestResult()’返回一个非空字符串。

我也无法在帖子部分中使用环境变量’failure_msg’,它返回错误
‘groovy.lang.MissingPropertyException:无此类属性:class:groovy.lang.Binding的failure_msg’

有人可以帮我吗?

编辑:

即使我修复了字符串插值后,也遇到了相同的错误。那是因为jenkins不允许在docker容器中使用’sh’。在詹金斯发行板上有一张打开的bug票


阅读 332

收藏
2020-07-25

共1个答案

一尘不染

我建议使用全局变量来保存错误消息。我的猜测是该变量在您的范围中不存在。

def FAILURE_MSG // Global Variable

pipeline {
    ...
    stages {
        stage(...
            steps {
                container('ansible') {
                    script {
                        ...
                        if (result != "") {
                            FAILURE_MSG = FAILURE_MSG + result
                        }
                    }    
                }  
            }
        }
    post {
        always {
            script {
                sh "${FAILURE_MSG}" // Hint: Use correct String Interpolation
                }
        }
    }
}
2020-07-25