This repository has been archived by the owner on Dec 18, 2018. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 6
/
Copy pathJenkinsfile
106 lines (93 loc) · 3.06 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
#!groovy
node {
def deployable_branches = ["master", "next_release"]
def testResults = []
def artifacts = []
stage('Checkout') {
checkout scm
}
dockerStage('Dev build') {
echo "Branch is: ${env.BRANCH_NAME}"
echo "Build is: ${env.BUILD_NUMBER}"
sh('''
./develop.sh build base
./develop.sh build builder
./develop.sh build dev
./develop.sh check-migrations-1.8
''')
}
testResults = ['**/data/tests/*.xml']
dockerStage('Unit tests', [], testResults) {
sh('./develop.sh unittests teststack')
}
artifacts = ['**/data/selenium/dev/log/*.log',
'lettuce-teststack.log',
'lettuce-selenium.log']
testResults = ['**/data/selenium/dev/*.xml']
dockerStage('Dev lettuce tests', artifacts, testResults) {
sh('''
./develop.sh lettuce teststack
''')
}
if (deployable_branches.contains(env.BRANCH_NAME)) {
dockerStage('Prod build') {
sh('''
./develop.sh run-builder
./develop.sh build prod
''')
}
artifacts = ['**/data/selenium/prod/log/*.log',
'lettuce-prod.log',
'lettuce-selenium.log']
testResults = ['**/data/selenium/prod/*.xml']
dockerStage('Prod lettuce tests', artifacts, testResults) {
sh('''
./develop.sh lettuce prod
''')
}
dockerStage('Publish docker image') {
withCredentials([[$class: 'UsernamePasswordMultiBinding', credentialsId: 'dockerbot',
usernameVariable: 'DOCKER_USERNAME',
passwordVariable: 'DOCKER_PASSWORD']]) {
sh("""
docker login -u "${env.DOCKER_USERNAME}" --password="${env.DOCKER_PASSWORD}"
./develop.sh push prod
""")
}
}
}
}
/*
* dockerStage
*
* Custom stage that wraps the stage in timestamps and AnsiColorBuildWrapper
* Prior to exit wrfy is used to kill all running containers and cleanup.
*/
def dockerStage(String label,
List<String> artifacts=[],
List<String> testResults=[],
Closure body) {
stage(label) {
try {
timestamps {
wrap([$class: 'AnsiColorBuildWrapper', 'colorMapName': 'XTerm']) {
body.call()
}
}
} catch (Exception e) {
currentBuild.result = 'FAILURE'
throw e
} finally {
for (artifact in artifacts) {
step([$class: 'ArtifactArchiver', artifacts: artifact, fingerprint: false, excludes: null])
}
for (testResult in testResults) {
step([$class: 'JUnitResultArchiver', testResults: testResult])
}
sh('''
/env/bin/wrfy kill-all --force
/env/bin/wrfy scrub --force
''')
}
}
}