X-Git-Url: https://osm.etsi.org/gitweb/?a=blobdiff_plain;f=jenkins%2Fci-pipelines%2Fci_stage_1.groovy;h=07d4dfd102e765e7062d7db24013c49fc8586539;hb=28a2ebbaef8cdd3f8bda0e92b1a916d87c89cf3a;hp=117265aebaa8d7c7d017d30d06f033809023b3f1;hpb=f94dd8ac7841b04e51bb50924b9ef369a6752b5e;p=osm%2Fdevops.git diff --git a/jenkins/ci-pipelines/ci_stage_1.groovy b/jenkins/ci-pipelines/ci_stage_1.groovy index 117265ae..07d4dfd1 100644 --- a/jenkins/ci-pipelines/ci_stage_1.groovy +++ b/jenkins/ci-pipelines/ci_stage_1.groovy @@ -14,7 +14,12 @@ * License for the specific language governing permissions and limitations * 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. + */ + +stage_3_merge_result = '' def Get_MDG(project) { // split the project. def values = project.split('/') @@ -36,18 +41,24 @@ node("${params.NODE}") { } stage('downstream') { - // initially use stage_name as the event_type - def stage_name = GERRIT_EVENT_TYPE + // default to stage_2 (patchset) + def stage_name = "stage_2" - switch(GERRIT_EVENT_TYPE) { - case "change-merged": - stage_name = "stage_2-merge" - break + try { + switch(GERRIT_EVENT_TYPE) { + case "change-merged": + stage_name = "stage_2-merge" + break - case "patchset-created": - stage_name = "stage_2" - break + case "patchset-created": + stage_name = "stage_2" + break + } + } + catch(caughtError) { + println("No gerrit event found") } + do_stage_4 = false if (params.DO_STAGE_4) { @@ -69,7 +80,7 @@ node("${params.NODE}") { if ( params.STAGE ) { // go directly to stage 3 (osm system) - stage_name = "stage_3" + stage_name = params.STAGE mdg = "osm" if ( ! params.TEST_INSTALL ) { @@ -82,11 +93,34 @@ node("${params.NODE}") { println("TEST_INSTALL = ${params.TEST_INSTALL}, downstream job: ${downstream_job_name}") - stage_2_result = build job: "${downstream_job_name}", parameters: downstream_params, propagate: true - if (stage_2_result.getResult() != 'SUCCESS') { - project = stage_2_result.getProjectName() - build = stage_2_result.getNumber() - error("${project} build ${build} failed") + 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") } - } + } + 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()] + ) + } + } + success { + echo 'Post For success' + } + failure { + echo 'Post For failure' + } + unstable { + echo 'Post for unstable' + } + } + }