当jenkins管道节点内部时,Sonarqube质量门卡在待处理状态

时间:2018-02-11 15:38:49

标签: jenkins sonarqube jenkins-pipeline sonarqube-scan

我们正在尝试添加Sonarqube扫描作为Jenkins管道脚本的一部分。 我们有一个多模块maven项目,我们正在使用Maven Sonarqube插件来运行聚合扫描。要启动扫描,我们按照Sonarqube的文档中的说明进行了显示here(向下滚动到页面末尾)。

所以管道脚本看起来像这样:

node {
    stage('SonarQube analysis') {
        withSonarQubeEnv('My SonarQube Server') {
            sh 'mvn clean package sonar:sonar'
        }
    }
}
stage("Quality Gate") {
    timeout(time: 1, unit: 'HOURS') { 
        def qg = waitForQualityGate() 
        if (qg.status != 'OK') {
            error "Pipeline aborted due to quality gate failure: ${qg.status}"
        }
    }
}

它按预期工作。但由于我们在多个文件中使用它,我们希望尽可能减少重复代码,因此我们希望将它放在节点中,如下所示:

node {
    stage('SonarQube analysis') {
        withSonarQubeEnv('My SonarQube Server') {
            sh 'mvn clean package sonar:sonar'
        }
    }
    stage("Quality Gate") {
        timeout(time: 1, unit: 'HOURS') { 
            def qg = waitForQualityGate() 
            if (qg.status != 'OK') {
                error "Pipeline aborted due to quality gate failure: ${qg.status}"
            }
        }
    }
}

但由于某种原因,这会使质量门卡在PENDING状态,直到达到超时。 我试图理解为什么会发生这种情况,以及如何避免在节点外移动质量检查。

非常感谢任何帮助!

3 个答案:

答案 0 :(得分:1)

waitForQualityGate对SonarQube服务器执行HTTP call

确保您的构建节点具有对SonarQube实例的HTTP访问权限(可以访问它的Jenkins主机并不意味着构建节点也具有它)。

无论如何,正如我在评论中所说,在node中使用等待步骤一般不是一个好主意。

答案 1 :(得分:0)

我也面临着同样的问题,因此我在waitForQualityGate阶段之前通过添加睡眠来解决了该问题

sleep 10
stage("Quality Gate") {
        timeout(time: 1, unit: 'HOURS') { 
            def qg = waitForQualityGate() 
            if (qg.status != 'OK') {
                error "Pipeline aborted due to quality gate failure: ${qg.status}"
            }
        }
    }

答案 2 :(得分:0)

这可能是重试的更好方法。

def retryForTimeoutExceeded(count = 3, Closure closure) {
    for (int i = 1; i <= count; i++) {
        try {
            closure()
            break
        } catch (FlowInterruptedException error) {
            int retriesLeft = count - i
            def hasTimeoutExceeded = error.causes[0].getClass().toString() == 'class org.jenkinsci.plugins.workflow.steps.TimeoutStepExecution$ExceededTimeout'
            println "Timeout Exceeded for clousre.\nRetries left: $retriesLeft"
            if (retriesLeft == 0 || !hasTimeoutExceeded) {
                throw error
            }
        }
    }
}

stage("Quality Gate") {
        retryForTimeoutExceeded {
            timeout(time: 5, unit: 'MINUTES') {
                // Just in case something goes wrong, pipeline will be killed after a timeout
                def qg = waitForQualityGate() // Reuse taskId previously collected by withSonarQubeEnv
                if (qg.status != 'OK') {
                    error "Pipeline aborted due to sonar quality gate failure: ${qg.status}"
                }
            }
        }
    }

可以相应配置超时

相关问题