forked from openshift-roadshow/nationalparks
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathJenkinsfile
144 lines (124 loc) · 5.31 KB
/
Jenkinsfile
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
#!/usr/bin/env groovy
// Application-specific Values
def mavenArgs="-Dcom.redhat.xpaas.repo.redhatga" // Global maven arguments
def mavenPackageArgs="package spring-boot:repackage" // Maven package arguments
def mavenOutputJar="nationalparks.jar" // Output jar from Maven
def appName="nationalparks" // Application name (for route, buildconfig, deploymentconfig)
def previewAppName="parksmap" // Application used for viewing/testing
// Pipeline variables
def isPR=false // true if the branch being tested belongs to a PR
def baseProject="" // name of base project - used when testing a PR
def project="" // project where build and deploy will occur
def projectCreated=false // true if a project was created by this build and needs to be cleaned up
def repoUrl="" // the URL of this project's repository
// uniqueName returns a name with a 16-character random character suffix
def uniqueName = { String prefix ->
sh "cat /dev/urandom | tr -dc 'a-z0-9' | fold -w 16 | head -n 1 > suffix"
suffix = readFile("suffix").trim()
return prefix + suffix
}
// setBuildStatus sets a status item on a GitHub commit
def setBuildStatus = { String url, String context, String message, String state, String backref ->
step([
$class: "GitHubCommitStatusSetter",
reposSource: [$class: "ManuallyEnteredRepositorySource", url: url ],
contextSource: [$class: "ManuallyEnteredCommitContextSource", context: context ],
errorHandlers: [[$class: "ChangingBuildStatusErrorHandler", result: "UNSTABLE"]],
statusBackrefSource: [ $class: "ManuallyEnteredBackrefSource", backref: backref ],
statusResultSource: [ $class: "ConditionalStatusResultSource", results: [
[$class: "AnyBuildResult", message: message, state: state]] ]
]);
}
// getRepoURL retrieves the origin URL of the current source repository
def getRepoURL = {
sh "git config --get remote.origin.url > originurl"
return readFile("originurl").trim()
}
// getRouteHostname retrieves the host name from the given route in an
// OpenShift namespace
def getRouteHostname = { String routeName, String projectName ->
sh "oc get route ${routeName} -n ${projectName} -o jsonpath='{ .spec.host }' > apphost"
return readFile("apphost").trim()
}
// Initialize variables in default node context
node {
isPR = env.BRANCH_NAME ? env.BRANCH_NAME.startsWith("PR") : false
baseProject = env.PROJECT_NAME
project = env.PROJECT_NAME
}
try { // Use a try block to perform cleanup in a finally block when the build fails
node ("maven") {
stage ('Checkout') {
checkout scm
repoUrl = getRepoURL()
stash includes: "ose3/pipeline-*.json", name: "artifact-template"
}
// When testing a PR, create a new project to perform the build
// and deploy artifacts.
if (isPR) {
stage ('Create PR Project') {
setBuildStatus(repoUrl, "ci/app-preview", "Building application", "PENDING", "")
setBuildStatus(repoUrl, "ci/approve", "Aprove after testing", "PENDING", "")
project = uniqueName("${appName}-")
sh "oc new-project ${project}"
projectCreated=true
sh "oc create serviceaccount jenkins -n ${project}"
sh "oc policy add-role-to-user view -z jenkins -n ${project}"
sh "oc policy add-role-to-group view system:authenticated -n ${project}"
}
}
stage ('Build') {
sh "mvn clean compile ${mavenArgs}"
}
stage ('Run Unit Tests') {
sh "mvn test ${mavenArgs}"
}
stage ('Package') {
sh "mvn ${mavenPackageArgs} ${mavenArgs}"
sh "mv target/${mavenOutputJar} docker"
stash includes: "docker/*", name: "dockerbuild"
//TODO: push built artifact to artifact repository
}
}
node {
unstash "artifact-template"
unstash "dockerbuild"
stage ('Apply object configurations') {
if (isPR) {
sh "oc process -f ose3/pipeline-pr-application-template.json -v BASE_NAMESPACE=${baseProject} -n ${project} | oc apply -f - -n ${project}"
} else {
sh "oc process -f ose3/pipeline-application-template.json -n ${project} | oc apply -f - -n ${project}"
}
// sleep a bit to allow the imagestreams to be populated before we move on to building
sh "sleep 30"
}
stage ('Build Image') {
sh "oc start-build ${appName}-docker --from-dir=./docker --follow -n ${project}"
}
stage ('Deploy') {
openshiftDeploy deploymentConfig: appName, namespace: project
}
if (isPR) {
stage ('Verify Service') {
openshiftVerifyService serviceName: previewAppName, namespace: project
}
def appHostName = getRouteHostname(previewAppName, project)
setBuildStatus(repoUrl, "ci/app-preview", "The application is available", "SUCCESS", "http://${appHostName}")
setBuildStatus(repoUrl, "ci/approve", "Approve after testing", "PENDING", "${env.BUILD_URL}input/")
stage ('Manual Test') {
input "Is everything OK?"
}
setBuildStatus(repoUrl, "ci/app-preview", "Application previewed", "SUCCESS", "")
setBuildStatus(repoUrl, "ci/approve", "Manually approved", "SUCCESS", "")
}
}
}
finally {
if (projectCreated) {
node {
stage('Delete PR Project') {
sh "oc delete project ${project}"
}
}
}
}