Whatever the way catchError is configured, a timeout block ends the build as ABORTED if the timeout fires.
Here is a test case job to reproduce this :
@Library("EvlinkCiLib@EVL-1262-ci-install-kw-and-cross-compilation-build-chain-for-lms") _pipeline {
agent { label 'buster' }
environment {
pipeName="TimedOut Job"
projectDir='timeout'
}
stages {
stage('timedOut node NOK'){
steps {
timeout(time: 10, unit: 'SECONDS') {
catchError(catchInterruptions: false,message: 'Cannot contact slave',buildResult: 'SUCCESS', stageResult: 'UNSTABLE') {
// This node exists but is not connected
node(label: 'rpi') {
sh('uname -a')
}
}
}
}
}
stage('timedOut node OK'){
// The node 'buster' is OK
steps {
catchError(catchInterruptions: false,message: 'Cannot contact slave',buildResult: 'SUCCESS', stageResult: 'UNSTABLE') {
timeout(time: 10, unit: 'SECONDS') {
node(label: 'buster') {
sh('uname -a')
}
}
}
}
}
}
}
Originally reported by jielpe_fr38, imported from: catchError with timeout : the build result is always ABORTED whatever the configured buildResult
- status: Open
- priority: Major
- component(s): workflow-basic-steps-plugin
- resolution: Unresolved
- votes: 2
- watchers: 4
- imported: 20251215-220547
Raw content of original issue
Whatever the way catchError is configured, a timeout block ends the build as ABORTED if the timeout fires.
Here is a test case job to reproduce this :
@Library("EvlinkCiLib@EVL-1262-ci-install-kw-and-cross-compilation-build-chain-for-lms") _pipeline {
agent { label 'buster' }
environment {
pipeName="TimedOut Job"
projectDir='timeout'
}
stages {
stage('timedOut node NOK'){
steps {
timeout(time: 10, unit: 'SECONDS') {
catchError(catchInterruptions: false,message: 'Cannot contact slave',buildResult: 'SUCCESS', stageResult: 'UNSTABLE') {
// This node exists but is not connected
node(label: 'rpi') {
sh('uname -a')
}
}
}
}
}
stage('timedOut node OK'){
// The node 'buster' is OK
steps {
catchError(catchInterruptions: false,message: 'Cannot contact slave',buildResult: 'SUCCESS', stageResult: 'UNSTABLE') {
timeout(time: 10, unit: 'SECONDS') {
node(label: 'buster') {
sh('uname -a')
}
}
}
}
}
}
}
environment
Jenkins 2.263.3 on Debian Buster and opnJdk8<br/>
pipeline-basic-steps 2.23<br/>
pipeline-model-definition 1.8.3
Whatever the way catchError is configured, a timeout block ends the build as ABORTED if the timeout fires.
Here is a test case job to reproduce this :
Originally reported by jielpe_fr38, imported from: catchError with timeout : the build result is always ABORTED whatever the configured buildResult
Raw content of original issue
environment