From 9c1b272757de7bc201dda8720f44cb1ee1a7b48b Mon Sep 17 00:00:00 2001 From: "SLW\\ARNAUA" Date: Wed, 26 Apr 2023 10:41:40 +0200 Subject: [PATCH] cleaned --- Jenkinsfile | 201 +++++++++++++++++++++++++++------------------------- 1 file changed, 106 insertions(+), 95 deletions(-) diff --git a/Jenkinsfile b/Jenkinsfile index 967850c..8bbf95e 100644 --- a/Jenkinsfile +++ b/Jenkinsfile @@ -1,69 +1,64 @@ - //not required right now as CN is reachable from EMEA as well - def loopEnvironments(environments){ - print env.JENKINS_URL - - environments.each { key, val -> - - //Execute only if you are on the same environment - //not required right now as CN is reachable from EMEA as well - if (env.JENKINS_URL == environments."${key}"[3].'jenkins') - { +// not required right now as CN is reachable from EMEA as well +def loopEnvironments(environments) { + print env.JENKINS_URL + + environments.each { key, val -> + + // Execute only if you are on the same environment + // not required right now as CN is reachable from EMEA as well + if (env.JENKINS_URL == environments."${key}"[3].'jenkins') { envname = environments."${key}"[0].'name' envurl = environments."${key}"[1].'env-url' tokenname = environments."${key}"[2].'env-token-name' sh 'python createReport.py "${envname}"' } - - } - } + } +} + def installRetryCount = 0 def reportRetryCount = 0 pipeline { - options { - ansiColor('xterm') - } - //label libraryBuild is available in CN JAWS and ROW JAWS, therefore this one was used; no additional intents - // agent {label 'jaws-slaves'} - agent {label 'jaws-slaves'} + options { + ansiColor('xterm') + } + + // label libraryBuild is available in CN JAWS and ROW JAWS, therefore this one was used; no additional intents + // agent {label 'jaws-slaves'} + agent {label 'jaws-slaves'} + parameters { string(name: 'FROMDATE', defaultValue: '', description: 'Enter from date in format YYYY-MM-DD e.g. 2021-11-01') - string(name: 'TODATE', defaultValue: '', description: 'Enter to date in format YYYY-MM-DD e.g. 2021-11-30') - string(name: 'PRESELECT', defaultValue: 'week', description: 'Enter week | month (without |) - auto selects the last full week or last full month') - string(name: 'SLICES', defaultValue: 'tdhy', description: 'Enter h | d | t | y (without spaces or |) - writes the slices hourly, daily, total or year to date into ecxel. given in any order') } - //here comes the trigger according to crontabs - jenkins is in UTC - - // triggers { - // //every 1st of every month at 00:00 - // //cron('0 0 1 * *') + // here comes the trigger according to crontabs - jenkins is in UTC + triggers { + // every 1st of every month at 00:00 + // cron('0 0 1 * *') - // //every day at 08:00 - // //cron('0 8 * * *') + // every day at 08:00 + // cron('0 8 * * *') - // //every monday at 06:00 - cron('0 4 * * 1') + // every monday at 06:00 + cron('0 4 * * 1') + + // parameterizedCron('0 10 * * * %PRESELECT=week;SLICES=tdhy') + } - // //parameterizedCron('0 10 * * * %PRESELECT=week;SLICES=tdhy') - - // } - environment { - //ProxySettings + // ProxySettings AUTH = credentials('proxy') proxy_user = "${AUTH_USR}" proxy_pw = "${AUTH_PSW}" - //http_proxy="http://${proxy_user}:${proxy_pw}@proxy.muc:8080" - //https_proxy="http://${proxy_user}:${proxy_pw}@proxy.muc:8080" - //no_proxy="localhost,127.0.0.1,.muc,.bmwgroup.net" - //HTTP_PROXY="${http_proxy}" - //HTTPS_PROXY="${https_proxy}" - //NO_PROXY="${no_proxy}" - + // http_proxy="http://${proxy_user}:${proxy_pw}@proxy.muc:8080" + // https_proxy="http://${proxy_user}:${proxy_pw}@proxy.muc:8080" + // no_proxy="localhost,127.0.0.1,.muc,.bmwgroup.net" + // HTTP_PROXY="${http_proxy}" + // HTTPS_PROXY="${https_proxy}" + // NO_PROXY="${no_proxy}" EUPROD_TOKEN_VAR = credentials('EUPROD_TOKEN_VAR') EUPREPROD_TOKEN_VAR = credentials('EUPREPROD_TOKEN_VAR') NAPROD_TOKEN_VAR = credentials('NAPROD_TOKEN_VAR') @@ -72,103 +67,119 @@ def reportRetryCount = 0 CNPREPROD_TOKEN_VAR = credentials('CNPREPROD_TOKEN_VAR') FROM_DATE="${params.FROMDATE}" TO_DATE="${params.TODATE}" - - } - - stages { - stage('install required python packages') { - steps { - retry(3) { - sleep(300*installRetryCount) - script { - installRetryCount = installRetryCount+1 - } - sh ''' - pip3 install --user -r requirements.txt - ''' - } + } + stages { + stage('Fetch Repository') { + steps { + dir("/opt/workspace/qm_report/") { + git branch: "main", credentialsId: "jaws_dynatrace_bitbuket_user", url: "https://atc.bmwgroup.net/bitbucket/scm/opapm/qm_report.git" + } + } + } + + stage('Install Required Python Packages') { + steps { + dir("/opt/workspace/qm_report/") { + retry(3) { + sleep(300*installRetryCount) + script { + installRetryCount = installRetryCount+1 + } + sh ''' + pip3 install --user -r requirements.txt + ''' + } + } } } stage('Execute Reporting Script') { steps { + dir("/opt/workspace/qm_report/") { retry(3) { sleep(300*reportRetryCount) - script{ + + script { reportRetryCount = reportRetryCount+1 def SCRIPT_PARAMETER = '' + if(SLICES.isEmpty()) { currentBuild.result = 'ABORTED' - error('Aborting due to missing slice parameter') - return + error('Aborting due to missing slice parameter') + return + } else { + SCRIPT_PARAMETER = SCRIPT_PARAMETER + " -s " + SLICES.toString() } - else {SCRIPT_PARAMETER = SCRIPT_PARAMETER + " -s " + SLICES.toString()} if (PRESELECT.isEmpty()) { if (FROMDATE=='') { currentBuild.result = 'ABORTED' error('Aborting due to missing startdate parameter') return - + } else { + SCRIPT_PARAMETER = SCRIPT_PARAMETER + " -f " + FROMDATE.toString() } - else { SCRIPT_PARAMETER = SCRIPT_PARAMETER + " -f " + FROMDATE.toString() } + if (TODATE=='') { currentBuild.result = 'ABORTED' error('Aborting due to missing enddate parameter') return + } else { + SCRIPT_PARAMETER = SCRIPT_PARAMETER + " -t " + TODATE.toString() } - else {SCRIPT_PARAMETER = SCRIPT_PARAMETER + " -t " + TODATE.toString()} + } else { + SCRIPT_PARAMETER = SCRIPT_PARAMETER + " -p " + PRESELECT.toString() } - else { SCRIPT_PARAMETER = SCRIPT_PARAMETER + " -p " + PRESELECT.toString()} - echo "${SCRIPT_PARAMETER}" - sh "python3 createReport.py ${SCRIPT_PARAMETER}" + echo "${SCRIPT_PARAMETER}" + sh "python3 createReport.py ${SCRIPT_PARAMETER}" + sh "python3 summary.py" + summary = readFile('summary.txt').trim() } } - //Only required once CN is not reachable from EMEA //loopEnvironments(environments) - } - + } + } } + stage('Send report') { steps { script { try { emailext subject: env.JOB_NAME, - body: 'Please find the output of the weekly QM-Report attached', - //to: 'michaela.jaeger@bmw.de, OOC-Support@bmwgroup.com, Andreas.DA.Danzer@partner.bmw.de', - //to: 'rene.forstner@nttdata.com, Andreas.DA.Danzer@partner.bmw.de, linnea.bickeboeller@partner.bmwgroup.com', - //to: 'rene.forstner@nttdata.com, stephan.oertelt@bmw.de, Mohammed.Abadel@bmw.de, michaela.jaeger@bmw.de', - //to: 'rene.forstner@nttdata.com, ermis.wieger@nttdata.com, patryk.gudalewicz.bp@nttdata.com', - //to: 'patryk.gudalewicz.bp@nttdata.com', - //to: 'rene.forstner@nttdata.com, ermis.wieger@nttdata.com, arnel.arnautovic@nttdata.com, patryk.gudalewicz.bp@nttdata.com, stephan.oertelt@bmw.de, Mohammed.Abadel@bmw.de, michaela.jaeger@bmw.de, OOC-Support@bmwgroup.com, Andreas.DB.Danzer@bmwgroup.com', - to: 'Arnel.Arnautovic@nttdata.com', - replyTo: 'coco-apm@bmw.de', - attachmentsPattern: '*.xlsx' - - } - catch ( mailExc ){ - echo "Sending Email Failed: ${mailExc}" - } + mimeType: 'text/html', + body: "Please find the output of the weekly QM-Report attached

${summary}", + //to: 'michaela.jaeger@bmw.de, OOC-Support@bmwgroup.com, Andreas.DA.Danzer@partner.bmw.de', + //to: 'rene.forstner@nttdata.com, Andreas.DA.Danzer@partner.bmw.de, linnea.bickeboeller@partner.bmwgroup.com', + //to: 'rene.forstner@nttdata.com, stephan.oertelt@bmw.de, Mohammed.Abadel@bmw.de, michaela.jaeger@bmw.de', + //to: 'rene.forstner@nttdata.com, ermis.wieger@nttdata.com, patryk.gudalewicz.bp@nttdata.com', + //to: 'patryk.gudalewicz.bp@nttdata.com', + //to: 'rene.forstner@nttdata.com, ermis.wieger@nttdata.com, arnel.arnautovic@nttdata.com, patryk.gudalewicz.bp@nttdata.com, stephan.oertelt@bmw.de, Mohammed.Abadel@bmw.de, michaela.jaeger@bmw.de, OOC-Support@bmwgroup.com, Andreas.DB.Danzer@bmwgroup.com', + to: 'Arnel.Arnautovic@nttdata.com', + replyTo: 'coco-apm@bmw.de', + attachmentsPattern: '*.xlsx' + } catch ( mailExc ) { + echo "Sending Email Failed: ${mailExc}" + } } } } - } - + } + post { failure { emailext subject: "${env.JOB_NAME} build ${env.BUILD_ID} failed", - body: "QM report failed, see logs for details: ${env.BUILD_URL}", - to: 'Arnel.Arnautovic@nttdata.com' -// to post to the teams channel "0 - APM Service Desk" just uncomment the following command: -// office365ConnectorSend webhookUrl: "https://bmwgroup.webhook.office.com/webhookb2/483edc00-c925-4672-8088-8299a0139fca@ce849bab-cc1c-465b-b62e-18f07c9ac198/JenkinsCI/9aca6923685b40f794134853fcbe88f1/ff31bcee-96b3-4481-9bd8-4f74180b263b", -// message: "QM report failed, see logs for details: ${env.BUILD_URL}", -// status: 'Failure', -// color: "d00000" + body: "QM report failed, see logs for details: ${env.BUILD_URL}", + to: 'Arnel.Arnautovic@nttdata.com' + // to post to the teams channel "0 - APM Service Desk" just uncomment the following command: + // office365ConnectorSend webhookUrl: "https://bmwgroup.webhook.office.com/webhookb2/483edc00-c925-4672-8088-8299a0139fca@ce849bab-cc1c-465b-b62e-18f07c9ac198/JenkinsCI/9aca6923685b40f794134853fcbe88f1/ff31bcee-96b3-4481-9bd8-4f74180b263b", + // message: "QM report failed, see logs for details: ${env.BUILD_URL}", + // status: 'Failure', + // color: "d00000" } always { cleanWs()