Skip to content

Commit

Permalink
Slack developer on pipeline failure (#116)
Browse files Browse the repository at this point in the history
Albrja/Mic-5240/Slack developer on pipeline failure

Slack developer on Jenkins pipeline failure
- *Category*: Feature
- *JIRA issue*: [MIC-5240](https://jira.ihme.washington.edu/browse/MIC-5240)

Changes and notes
-slack developer if pipeline fails
  • Loading branch information
albrja authored Oct 15, 2024
1 parent b1ae54e commit c18d9d1
Showing 1 changed file with 55 additions and 29 deletions.
84 changes: 55 additions & 29 deletions Jenkinsfile
Original file line number Diff line number Diff line change
@@ -1,3 +1,15 @@
def githubUsernameToSlackName(github_author) {
// Add team members as necessary
def mapping = [
"Jim Albright": "albrja",
"Steve Bachmeier": "sbachmei",
"Hussain Jafari": "hjafari",
"Patrick Nast": "pnast",
"Rajan Mudambi": "rmudambi",
]
return mapping.get(github_author, "channel")
}

pipeline_name="gbd_mapping"
conda_env_name="${pipeline_name}-${BUILD_NUMBER}"
conda_env_path="/tmp/${conda_env_name}"
Expand Down Expand Up @@ -190,40 +202,54 @@ pipeline {
} // build and deploy stage
} // stages bracket within Python matrix
post {
always {
sh "${ACTIVATE} && make clean"
sh "rm -rf ${CONDA_ENV_PATH}"
// Delete the workspace directory.
deleteDir()
}
failure {
script {
if (env.BRANCH == "main") {
channelName = "simsci-ci-status"
} else {
channelName = "simsci-ci-status-test"
}
always {
sh "${ACTIVATE} && make clean"
sh "rm -rf ${CONDA_ENV_PATH}"
// Generate a message to send to Slack.
script {
if (env.BRANCH == "main") {
channelName = "simsci-ci-status"
} else {
channelName = "simsci-ci-status-test"
}
// TODO: DM the developer instead of the slack channel
echo "This build failed on ${GIT_BRANCH}. Sending a failure message to Slack."
slackSend channel: "#${channelName}",
message: ":x: JOB FAILURE: $JOB_NAME - $BUILD_ID\n\n${BUILD_URL}console\n\n<!channel>",
// Run git command to get the author of the last commit
developerID = sh(
script: "git log -1 --pretty=format:'%an'",
returnStdout: true
).trim()
slackID = githubUsernameToSlackName(developerID)
slackMessage = """
Job: *${env.JOB_NAME}*
Build number: #${env.BUILD_NUMBER}
Build status: *${currentBuild.result}*
Author: @${slackID}
Build details: <${env.BUILD_URL}/console|See in web console>
""".stripIndent()
}

// Delete the workspace directory.
deleteDir()
}
failure {
echo "This build triggered by ${developerID} failed on ${GIT_BRANCH}. Sending a failure message to Slack."
slackSend channel: "#${channelName}",
message: slackMessage,
teamDomain: "ihme",
tokenCredentialId: "slack"
}
success {
script {
if (params.DEBUG) {
echo 'Debug is enabled. Sending a success message to Slack.'
slackSend channel: "#${channelName}",
message: slackMessage,
teamDomain: "ihme",
tokenCredentialId: "slack"
}
success {
script {
if (params.DEBUG) {
echo 'Debug is enabled. Sending a success message to Slack.'
slackSend channel: "#${params.SLACK_TO}",
message: ":white_check_mark: (debugging) JOB SUCCESS: $JOB_NAME - $BUILD_ID\n\n${BUILD_URL}console",
teamDomain: "ihme",
tokenCredentialId: "slack"
} else {
echo 'Debug is not enabled. No success message will be sent to Slack.'
}
} else {
echo 'Debug is not enabled. No success message will be sent to Slack.'
}
}
}
} // post bracket
} // Python matrix bracket
} // Python matrix stage bracket
Expand Down

0 comments on commit c18d9d1

Please sign in to comment.