-
Notifications
You must be signed in to change notification settings - Fork 41
/
Jenkinsfile
108 lines (100 loc) · 2.9 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
#!/usr/bin/env groovy
pipeline {
agent { label 'master' }
environment {
DEVELOPER_DIR = '/Xcode/9.4.1/Xcode.app/Contents/Developer'
XCPRETTY=0
SLACK_COLOR_DANGER = '#E01563'
SLACK_COLOR_INFO = '#6ECADC'
SLACK_COLOR_WARNING = '#FFC300'
SLACK_COLOR_GOOD = '#3EB991'
PROJECT_NAME = 'run_loop'
}
options {
disableConcurrentBuilds()
buildDiscarder(logRotator(numToKeepStr: '10'))
timeout(time: 60, unit: 'MINUTES')
}
stages {
stage('announce') {
steps {
slackSend(color: "${env.SLACK_COLOR_INFO}",
message: "${env.PROJECT_NAME} [${env.GIT_BRANCH}] #${env.BUILD_NUMBER} *Started* (<${env.BUILD_URL}|Open>)")
}
}
stage('clean') {
parallel {
stage('ruby') {
steps {
sh 'rm -rf .ruby-version'
sh 'gem uninstall -Vax --force --no-abort-on-dependent run_loop'
}
}
stage('device_agent:uninstall') {
steps {
sh 'rake device_agent:uninstall'
}
}
stage('reports') {
steps {
sh 'rm -rf spec/reports'
}
}
}
}
stage('prepare') {
parallel {
stage('ensure coresim') {
steps {
sh 'scripts/ci/jenkins/simctl.sh'
}
}
stage('bundle update') {
steps {
sh 'rbenv exec bundle update'
}
}
}
}
stage('unit') {
steps {
sh 'rbenv exec bundle exec run-loop simctl manage-processes'
sh 'rbenv exec bundle exec rspec spec/lib'
}
}
stage('integration + cli') {
parallel {
stage('integration') {
steps {
sh 'gtimeout --foreground --signal SIGKILL 30m scripts/ci/jenkins/test/integration.sh'
}
}
stage('cli') {
steps {
sh 'scripts/ci/jenkins/test/cli.sh'
}
}
}
}
}
post {
always {
junit 'spec/reports/*.xml'
}
aborted {
echo "Sending 'aborted' message to Slack"
slackSend (color: "${env.SLACK_COLOR_WARNING}",
message: "${env.PROJECT_NAME} [${env.GIT_BRANCH}] #${env.BUILD_NUMBER} *Aborted* after ${currentBuild.durationString.replace('and counting', '')}(<${env.BUILD_URL}|Open>)")
}
failure {
echo "Sending 'failed' message to Slack"
slackSend (color: "${env.SLACK_COLOR_DANGER}",
message: "${env.PROJECT_NAME} [${env.GIT_BRANCH}] #${env.BUILD_NUMBER} *Failed* after ${currentBuild.durationString.replace('and counting', '')}(<${env.BUILD_URL}|Open>)")
}
success {
echo "Sending 'success' message to Slack"
slackSend (color: "${env.SLACK_COLOR_GOOD}",
message: "${env.PROJECT_NAME} [${env.GIT_BRANCH}] #${env.BUILD_NUMBER} *Success* after ${currentBuild.durationString.replace('and counting', '')}(<${env.BUILD_URL}|Open>)")
}
}
}