Skip to content
Permalink
Newer
Older
100644 115 lines (110 sloc) 4.35 KB
1
pipeline {
2
agent any
3
environment {
4
maintainer = "t"
5
imagename = 'm'
6
tag = 'l'
7
}
8
stages {
9
stage ('Setting build context') {
10
steps {
11
script {
12
maintainer = maintain()
13
imagename = imagename()
14
if (env.BRANCH_NAME == "master" || env.BRANCH_NAME == "bats") { // temporary
15
tag = "latest"
16
} else {
17
tag = env.BRANCH_NAME
18
}
19
if (!imagename) {
20
echo "You must define imagename in common.bash"
21
currentBuild.result = 'FAILURE'
23
sh 'mkdir -p bin'
24
sh 'mkdir -p tmp'
25
dir ('tmp') {
26
git([ url: "https://github.internet2.edu/docker/util.git", credentialsId: "jenkins-github-access-token" ])
27
sh 'ls'
28
sh 'mv bin/* ../bin/.'
29
}
30
}
31
}
33
stage ('Build') {
34
steps {
35
script {
36
try {
37
sh '(ls -l ; docker ps -a ; docker image ls ; echo Destroying ; bin/destroy.sh ; docker image ls) 2>&1 | tee debug' // temporary
38
sh './download-midpoint 2>&1 | tee -a debug ; test ${PIPESTATUS[0]} -eq 0'
39
sh 'bin/rebuild.sh 2>&1 | tee -a debug ; test ${PIPESTATUS[0]} -eq 0'
Sep 28, 2018
40
//sh 'echo Build output ; cat debug'
41
} catch (error) {
42
def error_details = readFile('./debug')
43
def message = "BUILD ERROR: There was a problem building ${imagename}:${tag}. \n\n ${error_details}"
44
sh "rm -f ./debug"
45
handleError(message)
46
}
47
}
48
}
49
}
50
stage ('Test') {
51
steps {
52
script {
53
try {
54
sh 'echo Docker containers before root tests ; docker ps -a' // temporary
55
sh 'bin/test.sh 2>&1 | tee debug ; test ${PIPESTATUS[0]} -eq 0'
56
sh 'echo Docker containers before compositions tests ; docker ps -a' // temporary
57
58
sh '(cd demo/simple ; bats tests ) 2>&1 | tee -a debug ; test ${PIPESTATUS[0]} -eq 0'
59
sh '(cd demo/shibboleth ; bats tests ) 2>&1 | tee -a debug ; test ${PIPESTATUS[0]} -eq 0'
60
sh '(cd demo/postgresql ; bats tests ) 2>&1 | tee -a debug ; test ${PIPESTATUS[0]} -eq 0'
61
sh '(cd demo/complex ; bats tests ) 2>&1 | tee -a debug ; test ${PIPESTATUS[0]} -eq 0'
62
} catch (error) {
63
def error_details = readFile('./debug')
64
def message = "BUILD ERROR: There was a problem testing ${imagename}:${tag}. \n\n ${error_details}"
65
sh "rm -f ./debug"
66
handleError(message)
67
}
68
}
69
}
70
}
72
steps {
73
script {
74
docker.withRegistry('https://registry.hub.docker.com/', "dockerhub-$maintainer") {
75
def baseImg = docker.build("$maintainer/$imagename")
76
baseImg.push("$tag")
77
}
78
}
79
}
80
}
81
stage ('Notify') {
82
steps {
83
echo "$maintainer"
84
slackSend color: 'good', message: "$maintainer/$imagename:$tag pushed to DockerHub"
85
}
86
}
87
}
88
post {
89
always {
90
echo 'Done Building.'
91
}
92
failure {
93
// slackSend color: 'good', message: "Build failed"
94
handleError("BUILD ERROR: There was a problem building ${maintainer}/${imagename}:${tag}.")
95
}
96
}
97
}
98
99
100
def maintain() {
101
def matcher = readFile('common.bash') =~ 'maintainer="(.+)"'
102
matcher ? matcher[0][1] : 'tier'
103
}
104
105
def imagename() {
106
def matcher = readFile('common.bash') =~ 'imagename="(.+)"'
107
matcher ? matcher[0][1] : null
108
}
109
110
def handleError(String message) {
111
echo "${message}"
112
currentBuild.setResult("FAILED")
113
slackSend color: 'danger', message: "${message}"
114
sh 'exit 1'
You can’t perform that action at this time.