Permalink
Cannot retrieve contributors at this time
Name already in use
A tag already exists with the provided branch name. Many Git commands accept both tag and branch names, so creating this branch may cause unexpected behavior. Are you sure you want to create this branch?
grouper-appliance/Jenkinsfile
Go to fileThis commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
122 lines (100 sloc)
3.15 KB
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
node('docker') { | |
stage 'Checkout' | |
checkout scm | |
stage 'Acquire util' | |
sh 'mkdir -p tmp && mkdir -p bin' | |
dir('tmp'){ | |
git([ url: "https://github.internet2.edu/docker/util.git", | |
credentialsId: "jenkins-github-access-token" ]) | |
sh 'mv ./bin/* ../bin/.' | |
} | |
sh 'rm -rf tmp' | |
stage 'Setting build context' | |
def maintainer = maintainer() | |
def imagename = imagename() | |
def tag | |
// Tag images created on master branch with 'latest' | |
if(env.BRANCH_NAME == "master"){ | |
tag = "latest" | |
}else{ | |
tag = env.BRANCH_NAME | |
} | |
if(!imagename){ | |
echo "You must define an imagename in common.bash" | |
currentBuild.result = 'FAILURE' | |
} | |
if(maintainer){ | |
echo "Building ${imagename}:${tag} for ${maintainer}" | |
} | |
stage 'Build' | |
try{ | |
sh 'bin/rebuild.sh &> debug' | |
} catch(error) { | |
def error_details = readFile('./debug'); | |
def message = "BUILD ERROR: There was a problem building ${imagename}:${tag}. \n\n ${error_details}" | |
sh "rm -f ./debug" | |
handleError(message, tag) | |
} | |
stage 'Compose' | |
try{ | |
sh 'bin/recompose.sh &> debug' | |
} catch(error) { | |
def error_details = readFile('./debug'); | |
def message = "BUILD ERROR: There was a problem composing Grouper appliance (${tag}). \n\n ${error_details}" | |
sh "rm -f ./debug" | |
handleError(message, tag) | |
} | |
stage 'Tests' | |
try{ | |
sh 'sleep 300' | |
sh 'bin/test.sh &> debug' | |
} catch(error) { | |
def error_details = readFile('./debug'); | |
def message = "BUILD ERROR: There was a problem building ${imagename}:${tag}. \n\n ${error_details}" | |
sh "rm -f ./debug" | |
handleError(message, tag) | |
} | |
stage 'Decompose' | |
try{ | |
sh 'bin/decompose.sh &> debug' | |
} catch(error) { | |
def error_details = readFile('./debug'); | |
def message = "BUILD ERROR: There was a problem decomposing Grouper appliance (${tag}). \n\n ${error_details}" | |
sh "rm -f ./debug" | |
handleError(message, tag) | |
} | |
stage 'Clean Up' | |
cleanup(tag) | |
stage 'Notify' | |
slackSend color: 'good', message: "grouper-appliance (${tag}) passes test battery" | |
} | |
def maintainer() { | |
def matcher = readFile('common.bash') =~ 'maintainer="(.+)"' | |
matcher ? matcher[0][1] : 'tier' | |
} | |
def imagename() { | |
def matcher = readFile('common.bash') =~ 'imagename="(.+)"' | |
matcher ? matcher[0][1] : null | |
} | |
def handleError(String message, String tag, Boolean doCleanup = true){ | |
echo "${message}" | |
currentBuild.setResult("FAILED") | |
slackSend color: 'danger', message: "${message}" | |
//step([$class: 'Mailer', notifyEveryUnstableBuild: true, recipients: 'chris.bynum@levvel.io', sendToIndividuals: true]) | |
if (doCleanup) { | |
cleanup(tag) | |
} | |
sh 'exit 1' | |
} | |
def cleanup(String tag) { | |
try{ | |
sh 'bin/decompose.sh &> debug' | |
sh 'bin/prune.sh &> debug' | |
sh 'sudo rm -rf logs' | |
} catch(error) { | |
def error_details = readFile('./debug'); | |
def message = "BUILD ERROR: There was a problem cleaning up Grouper appliance :${tag}. \n\n ${error_details}" | |
sh "rm -f ./debug" | |
handleError(message, tag, false) | |
} | |
} |