Skip to content
Permalink
Newer
Older
100644 117 lines (112 sloc) 4.56 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") {
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 -l'
28
sh 'ls -l ../bin'
29
sh 'mv -f bin/* ../bin/.'
31
// Build and test scripts expect that 'tag' is present in common.bash. This is necessary for both Jenkins and standalone testing.
32
// We don't care if there are more 'tag' assignments there. The latest one wins.
Oct 5, 2018
33
sh "echo >> common.bash ; echo \"tag=\\\"${tag}\\\"\" >> common.bash ; echo common.bash ; cat common.bash"
34
}
35
}
37
stage ('Build') {
38
steps {
39
script {
40
try {
41
// using custom ./build.sh instead of bin/rebuild.sh because the bin/ version does not support building specific tag yet
42
sh './build.sh -r 2>&1 | tee -a debug ; test ${PIPESTATUS[0]} -eq 0'
43
} catch (error) {
44
def error_details = readFile('./debug')
45
def message = "BUILD ERROR: There was a problem building ${imagename}:${tag}. \n\n ${error_details}"
46
sh "rm -f ./debug"
47
handleError(message)
48
}
49
}
50
}
51
}
52
stage ('Test') {
53
steps {
54
script {
55
try {
56
sh 'echo Docker containers before root tests ; docker ps -a' // temporary
57
sh 'bin/test.sh 2>&1 | tee debug ; test ${PIPESTATUS[0]} -eq 0'
58
sh 'echo Docker containers before compositions tests ; docker ps -a' // temporary
59
60
sh '(cd demo/simple ; bats tests ) 2>&1 | tee -a debug ; test ${PIPESTATUS[0]} -eq 0'
61
sh '(cd demo/shibboleth ; bats tests ) 2>&1 | tee -a debug ; test ${PIPESTATUS[0]} -eq 0'
62
sh '(cd demo/postgresql ; bats tests ) 2>&1 | tee -a debug ; test ${PIPESTATUS[0]} -eq 0'
63
sh '(cd demo/complex ; bats tests ) 2>&1 | tee -a debug ; test ${PIPESTATUS[0]} -eq 0'
64
} catch (error) {
65
def error_details = readFile('./debug')
66
def message = "BUILD ERROR: There was a problem testing ${imagename}:${tag}. \n\n ${error_details}"
67
sh "rm -f ./debug"
68
handleError(message)
69
}
70
}
71
}
72
}
74
steps {
75
script {
76
docker.withRegistry('https://registry.hub.docker.com/', "dockerhub-$maintainer") {
77
def baseImg = docker.build("$maintainer/$imagename")
78
baseImg.push("$tag")
79
}
80
}
81
}
82
}
83
stage ('Notify') {
84
steps {
85
echo "$maintainer"
86
slackSend color: 'good', message: "$maintainer/$imagename:$tag pushed to DockerHub"
87
}
88
}
89
}
90
post {
91
always {
92
echo 'Done Building.'
93
}
94
failure {
95
// slackSend color: 'good', message: "Build failed"
96
handleError("BUILD ERROR: There was a problem building ${maintainer}/${imagename}:${tag}.")
97
}
98
}
99
}
100
101
102
def maintain() {
103
def matcher = readFile('common.bash') =~ 'maintainer="(.+)"'
104
matcher ? matcher[0][1] : 'tier'
105
}
106
107
def imagename() {
108
def matcher = readFile('common.bash') =~ 'imagename="(.+)"'
109
matcher ? matcher[0][1] : null
110
}
111
112
def handleError(String message) {
113
echo "${message}"
114
currentBuild.setResult("FAILED")
115
slackSend color: 'danger', message: "${message}"
116
sh 'exit 1'
You can’t perform that action at this time.