diff --git a/Jenkinsfile b/Jenkinsfile new file mode 100644 index 0000000..ee22e06 --- /dev/null +++ b/Jenkinsfile @@ -0,0 +1,105 @@ +pipeline { + agent any + environment { + maintainer = "t" + maintainer_credential_ref = 'dockerhub-tier' + imagename = 'g' + tag = 'l' + version='1.1.1' + } + stages { + stage('Setting build context') { + steps { + script { + maintainer = maintain() + imagename = imagename() + version= matchversion() + if(env.BRANCH_NAME == "main") { + tag = "latest" + } else { + tag = env.BRANCH_NAME + } + if(!imagename){ + echo "You must define an imagename in common.bash" + currentBuild.result = 'FAILURE' + } + } + } + } + stage('Build and Push') { + steps { + script { + docker.withRegistry('https://registry.hub.docker.com/', "$maintainer_credential_ref") { + def image_to_build + def image_dir + def build_arg + + image_to_build = "comanage-match-base:$version-1" + image_dir = 'comanage-match-base' + build_arg = '--no-cache ' + + "--build-arg COMANAGE_MATCH_VERSION=$version " + + "-f ./$image_dir/Dockerfile ./$image_dir" + def base_image = docker.build("$image_to_build", "$build_arg") + + image_to_build = 'comanage-match-internet2-tap-base:1' + image_dir = 'comanage-match-internet2-tap-base' + build_arg = '--no-cache ' + + "-f ./$image_dir/Dockerfile ./$image_dir" + def tap_base_image = docker.build("$image_to_build", "$build_arg") + + image_to_build = "$maintainer/$imagename" + image_dir = 'comanage-match-internet2-tap' + build_arg = '--no-cache ' + + "--build-arg COMANAGE_MATCH_VERSION=$version " + + "--build-arg COMANAGE_MATCH_BASE_IMAGE_VERSION=1 " + + "--build-arg COMANAGE_MATCH_I2_BASE_IMAGE_VERSION=1 " + + "-f ./$image_dir/Dockerfile ./$image_dir" + def tap_image = docker.build("$image_to_build", "$build_arg") + tap_image.push("$tag") + + } + } + } + } + stage('Notify') { + steps{ + echo "$maintainer" + slackSend color: 'good', message: "$maintainer/$imagename:$tag pushed to DockerHub" + } + } + } + post { + always { + echo 'In post.' + } + failure { + // slackSend color: 'good', message: "Build failed" + handleError("BUILD ERROR: There was a problem building ${maintainer}/${imagename}:${tag}.") + } + } +} + + +def maintain() { + 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 matchversion() { + def matcher = readFile('common.bash') =~ 'COMANAGE_MATCH_VERSION="(.+)"' + matcher ? matcher[0][1] : null +} + + +def handleError(String message){ + echo "${message}" + currentBuild.setResult("FAILED") + slackSend color: 'danger', message: "${message}" + //step([$class: 'Mailer', notifyEveryUnstableBuild: true, recipients: 'chubing@internet2.edu', sendToIndividuals: true]) + sh 'exit 1' +} diff --git a/common.bash b/common.bash new file mode 100644 index 0000000..5b533f4 --- /dev/null +++ b/common.bash @@ -0,0 +1,3 @@ +maintainer="i2incommon" +imagename="comanage-match" +COMANAGE_MATCH_VERSION="1.1.1"