X-Git-Url: https://osm.etsi.org/gitweb/?a=blobdiff_plain;f=jenkins%2Fci-pipelines%2Fci_stage_1.groovy;h=17345ea849b49e8a44fa9189e3d7b427992552bd;hb=c9ea6ad7758f6d3517f58f8f9fac1f930781a70b;hp=07d4dfd102e765e7062d7db24013c49fc8586539;hpb=28a2ebbaef8cdd3f8bda0e92b1a916d87c89cf3a;p=osm%2Fdevops.git diff --git a/jenkins/ci-pipelines/ci_stage_1.groovy b/jenkins/ci-pipelines/ci_stage_1.groovy index 07d4dfd1..17345ea8 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 = '' @@ -59,12 +59,6 @@ node("${params.NODE}") { println("No gerrit event found") } - do_stage_4 = false - if (params.DO_STAGE_4) - { - do_stage_4 = params.DO_STAGE_4 - } - // pipeline running from gerrit trigger. // kickoff the downstream multibranch pipeline def downstream_params = [ @@ -72,11 +66,24 @@ node("${params.NODE}") { string(name: 'GERRIT_PROJECT', value: GERRIT_PROJECT), string(name: 'GERRIT_REFSPEC', value: GERRIT_REFSPEC), string(name: 'GERRIT_PATCHSET_REVISION', value: GERRIT_PATCHSET_REVISION), + string(name: 'INSTALLER', value: params.INSTALLER), + string(name: 'OPENSTACK_BASE_IMAGE', value: params.OPENSTACK_BASE_IMAGE), + string(name: 'OPENSTACK_OSM_FLAVOR', value: params.OPENSTACK_OSM_FLAVOR), 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_STAGE_4', value: do_stage_4), + booleanParam(name: 'TRY_JUJU_INSTALLATION', value: params.TRY_JUJU_INSTALLATION), + booleanParam(name: 'TRY_OLD_SERVICE_ASSURANCE', value: params.TRY_OLD_SERVICE_ASSURANCE), ] - + if ( params.DO_ROBOT ) + { + downstream_params.add(booleanParam(name: 'DO_ROBOT', value: params.DO_ROBOT)) + } + if ( params.ROBOT_TAG_NAME ) + { + downstream_params.add(string(name: 'ROBOT_TAG_NAME', value: params.ROBOT_TAG_NAME)) + } + if ( params.STAGE ) { // go directly to stage 3 (osm system) @@ -87,40 +94,44 @@ node("${params.NODE}") { println("disabling stage_3 invocation") return } + // in this case, since this is for daily jobs, the pass threshold for robot tests should be adapted + downstream_params.add(string(name: 'ROBOT_PASS_THRESHOLD', value: '99.0')) } // callout to stage_2. This is a multi-branch pipeline. downstream_job_name = "${mdg}-${stage_name}/${GERRIT_BRANCH}" - println("TEST_INSTALL = ${params.TEST_INSTALL}, downstream job: ${downstream_job_name}") - - stage_3_merge_result = build job: "${downstream_job_name}", parameters: downstream_params, propagate: true - if (stage_3_merge_result.getResult() != 'SUCCESS') { - project = stage_3_merge_result.getProjectName() - 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") + println("Downstream job: ${downstream_job_name}") + println("Downstream parameters: ${downstream_params}") + 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') { + project = stage_3_merge_result.getProjectName() + 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) { + echo 'Exception in stage_1' + currentBuild.result = 'FAILURE' } - } - post { - always { - if((stage_3_merge_result.getResult() != '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()}", - body: """ Check console output at "${env.BUILD_URL}" """, - to: 'OSM_MDL@list.etsi.org', - recipientProviders: [culprits()] - ) + finally { + try { + if ((currentBuild.result != 'SUCCESS') && (env.JOB_NAME.startsWith('daily-stage_4'))){ + emailext ( + 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()] + ) + } } - } - success { - echo 'Post For success' - } - failure { - echo 'Post For failure' - } - unstable { - echo 'Post for unstable' - } - } - + catch(caughtError) { + echo "Failure in executing email" + } + } + } } +