jenkinsjenkins-pipelinejenkins-shared-libraries

Handle timeout failure in Jenkins pipeline library custom step


We use Jenkins Pipeline shared library custom steps in our build files.

We have a use case where the custom step will perform a potentially long-running operation; one that we want to ensure has 'cleanup' logic in case of failure. However, we are unsure how to perform the cleanup logic in the case that the top level build is aborted (manually, via timeout, etc).

Custom step:

// myTask.groovy
void call(Map config = [:]) {
    // long running task that needs cleanup at the end
}

Build file:

@Library('my-library') _

pipeline {
    agent { label 'build' }
    options {
        timeout(time: 1, unit: 'HOURS')
    }

    stages {
        stage('Long running task') {
            steps {
                myTask()
            }
        }
    }
}

We are aware of post conditions (e.g. unsuccessful) that can be used to handle logic on failure, but we are hoping there is a way to handle this from within the custom step so that all logic for such can be encapsulated in a single place. Otherwise, the logic for cleanup needs to be handled separately in the post condition.

Is this possible?


Solution

  • Thanks to @marco's comment, this is a simple answer!

    A try block can be used in the custom step and it allows catching even top-level Jenkins exceptions:

    // myTask.groovy
    void call(Map config = [:]) {
        try {
            // long running task
        } finally {
            // perform cleanup
        }
    }
    

    In our case, this even catches the exception thrown from our use of the Build Timeout plugin.