X-Git-Url: https://osm.etsi.org/gitweb/?a=blobdiff_plain;f=jenkins%2Fci-pipelines%2Fci_stage_1.groovy;h=53466f75c0b72c2bd22963ab32ffb70fb4b3a3b3;hb=097b8950fa022ba2a329fcc29997e703bd8c6aa0;hp=51a619fa57bc63688d68c0a751006802e3d31e24;hpb=9d25cf8975b90133a9c97343b73373eba5205bd7;p=osm%2Fdevops.git diff --git a/jenkins/ci-pipelines/ci_stage_1.groovy b/jenkins/ci-pipelines/ci_stage_1.groovy index 51a619fa..53466f75 100644 --- a/jenkins/ci-pipelines/ci_stage_1.groovy +++ b/jenkins/ci-pipelines/ci_stage_1.groovy @@ -15,8 +15,8 @@ * under the License. */ /* Change log: - * 1. Bug 699 : Jayant Madavi : JM00553988@techmahindra.com : 23-july-2019 : Improvement to the code, now using post syntax - * 2. + * 1. Bug 699 : Jayant Madavi, Mrityunjay Yadav : JM00553988@techmahindra.com : 23-july-2019 : Improvement to the code, now using post syntax + * 2. Jayant Madavi : 26-july-2019 : optimization to the previous check-in added currentBuild.result = 'SUCCESS'. TODO: code would be better * if we use pipeline declarative */ stage_3_merge_result = '' @@ -73,7 +73,9 @@ node("${params.NODE}") { string(name: 'GERRIT_REFSPEC', value: GERRIT_REFSPEC), string(name: 'GERRIT_PATCHSET_REVISION', value: GERRIT_PATCHSET_REVISION), string(name: 'PROJECT_URL_PREFIX', value: params.PROJECT_URL_PREFIX), + string(name: 'DOCKER_TAG', value: params.DOCKER_TAG), booleanParam(name: 'TEST_INSTALL', value: params.TEST_INSTALL), + booleanParam(name: 'DO_ROBOT', value: params.DO_ROBOT), booleanParam(name: 'DO_STAGE_4', value: do_stage_4), ] @@ -92,6 +94,7 @@ node("${params.NODE}") { downstream_job_name = "${mdg}-${stage_name}/${GERRIT_BRANCH}" println("TEST_INSTALL = ${params.TEST_INSTALL}, downstream job: ${downstream_job_name}") + currentBuild.result = 'SUCCESS' try { stage_3_merge_result = build job: "${downstream_job_name}", parameters: downstream_params, propagate: true if (stage_3_merge_result.getResult() != 'SUCCESS') { @@ -99,21 +102,27 @@ node("${params.NODE}") { build = stage_3_merge_result.getNumber() // Jayant if the build fails the below error will cause the pipeline to terminate. // error("${project} build ${build} failed") + currentBuild.result = stage_3_merge_result.getResult() } - } - catch (caughtError) { + } + catch(caughtError) { echo 'Exception in stage_1' currentBuild.result = 'FAILURE' } finally { - if((stage_3_merge_result.getResult() != 'SUCCESS') && (${env.JOB_NAME} == 'daily-stage_4')){ + try { + if((currentBuild.result != 'SUCCESS') && (env.JOB_NAME == 'daily-stage_4')){ emailext ( - subject: "[OSM-Jenkins] Job: ${env.JOB_NAME} Build: ${env.BUILD_NUMBER} Result: ${stage_3_merge_result.getResult()}", + subject: "[OSM-Jenkins] Job: ${env.JOB_NAME} Build: ${env.BUILD_NUMBER} Result: ${currentBuild.result}", body: """ Check console output at "${env.BUILD_URL}" """, to: 'OSM_MDL@list.etsi.org', recipientProviders: [culprits()] ) } + } + catch(caughtError) { + echo "Failure in executing email" + } } }