如何在Jenkinsfile中为失败的构建执行操作

时间:2016-04-25 10:15:08

标签: groovy jenkins-workflow jenkinsfile

如果Jenkinsfile中的构建失败,是否有办法执行清理(或回滚)?

我想通知我们的Atlassian Stash实例构建失败(通过在正确的URL处执行curl)。

基本上,当构建状态设置为失败时,这将是一个后续步骤。

我应该使用try {} catch ()吗?如果是这样,我应该抓住什么样的异常类型?

3 个答案:

答案 0 :(得分:19)

我目前还在寻找这个问题的解决方案。到目前为止,我能想到的最好的方法是创建一个在try catch块中运行管道代码的包装函数。如果您还想通知成功,可以将Exception存储在变量中,并将通知代码移动到finally块。另请注意,您必须重新抛出异常,以便Jenkins认为构建失败。也许有些读者会找到更优雅的方法解决这个问题。

pipeline('linux') {
    stage 'Pull'
    stage 'Deploy'
    echo "Deploying"
    throw new FileNotFoundException("Nothing to pull")
    // ... 
}

 def pipeline(String label, Closure body) {
     node(label) {
        wrap([$class: 'TimestamperBuildWrapper']) {
            try {
                body.call()
            } catch (Exception e) {
                emailext subject: "${env.JOB_NAME} - Build # ${env.BUILD_NUMBER} - FAILURE (${e.message})!", to: "me@me.com",body: "..."
                throw e; // rethrow so the build is considered failed                        
            } 
        }
    }
}

答案 1 :(得分:19)

自2017-02-03以来,Declarative Pipeline Syntax 1.0可用于实现此构建后步骤功能。

这是一种用于构建管道的新语法,它使用预定义的结构扩展了Pipeline,并使用了一些新步骤,使用户能够定义代理,发布操作,环境设置,凭据和阶段。

以下是带有声明性语法的示例Jenkins文件:

pipeline {
  agent  label:'has-docker', dockerfile: true
  environment {
    GIT_COMMITTER_NAME = "jenkins"
    GIT_COMMITTER_EMAIL = "jenkins@jenkins.io"
  }
  stages {
    stage("Build") {
      steps {
        sh 'mvn clean install -Dmaven.test.failure.ignore=true'
      }
    }
    stage("Archive"){
      steps {
        archive "*/target/**/*"
        junit '*/target/surefire-reports/*.xml'
      }
    }
  }
  post {
    always {
      deleteDir()
    }
    success {
      mail to:"me@example.com", subject:"SUCCESS: ${currentBuild.fullDisplayName}", body: "Yay, we passed."
    }
    failure {
      mail to:"me@example.com", subject:"FAILURE: ${currentBuild.fullDisplayName}", body: "Boo, we failed."
    }
  }
}

帖子代码块处理后步骤操作

声明性管道语法参考是here

答案 2 :(得分:0)

我设法通过使用try:finally解决了它。如果此阶段出现错误,则该阶段将变为红色并最终运行代码,但如果该阶段正常,则该阶段将变为绿色并最终也运行。

stage('Tests'){
    script{
        try{
            sh """#!/bin/bash -ex
                docker stop \$(docker ps -a -q)
                docker rm \$(docker ps -a -q)
                export DOCKER_TAG=${DOCKER_TAG}
                docker-compose -p ${VISUAL_TESTING_PROJECT_TAG} build test
                docker-compose -p ${VISUAL_TESTING_PROJECT_TAG} up --abort-on-container-exit --exit-code-from test
        """     
        }
        finally{
            sh """#!/bin/bash -ex
            export DOCKER_TAG=${DOCKER_TAG}
            docker-compose -p ${VISUAL_TESTING_PROJECT_TAG} down
            """
        }
    }

}