-
Notifications
You must be signed in to change notification settings - Fork 150
Expand file tree
/
Copy pathJenkinsfile
More file actions
143 lines (138 loc) · 4.73 KB
/
Jenkinsfile
File metadata and controls
143 lines (138 loc) · 4.73 KB
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
/*
* (c) Copyright, Real-Time Innovations, 2021. All rights reserved.
* RTI grants Licensee a license to use, modify, compile, and create derivative
* works of the software solely for use with RTI Connext DDS. Licensee may
* redistribute copies of the software provided that all such copies are subject
* to this license. The software is provided "as is", with no warranty of any
* type, including any warranty for fitness for any purpose. RTI is under no
* obligation to maintain or support the software. RTI shall not be liable for
* any incidental or consequential damages arising out of the use or inability
* to use the software.
*/
/**
* Hold information about the pipeline.
*/
Map pipelineInfo = [:]
pipeline {
agent {
label "${runInsideExecutor.labelFromJobName()}"
}
options {
skipDefaultCheckout()
disableConcurrentBuilds()
/*
To avoid excessive resource usage in server, we limit the number
of builds to keep in pull requests
*/
buildDiscarder(
logRotator(
artifactDaysToKeepStr: '',
artifactNumToKeepStr: '',
daysToKeepStr: '',
/*
For pull requests only keep the last 10 builds, for regular
branches keep up to 20 builds.
*/
numToKeepStr: changeRequest() ? '10' : '20'
)
)
// Set a timeout for the entire pipeline
timeout(time: 3, unit: 'HOURS')
}
stages {
stage('Configuration') {
steps {
script {
checkoutCommunityRepoBranch(
'rticonnextdds-examples',
env.BRANCH_NAME,
false,
)
pipelineInfo.dockerDir = "${env.WORKSPACE}/resources/docker/"
pipelineInfo.staticAnalysisDir = "${env.WORKSPACE}/static_analysis_report"
runInsideExecutor(
'',
pipelineInfo.dockerDir,
) {
pipelineInfo.connextArch = getEnvVar('CONNEXTDDS_ARCH')
}
}
}
}
stage('Download Packages') {
steps {
runInsideExecutor(
'',
pipelineInfo.dockerDir,
) {
script {
pipelineInfo.connextDir = installConnext(
pipelineInfo.connextArch,
env.WORKSPACE,
)
}
}
}
}
stage('Build all modes') {
matrix {
axes {
axis {
name 'buildMode'
values 'release', 'debug'
}
axis {
name 'linkMode'
values 'static', 'dynamic'
}
}
stages {
stage('Build single mode') {
steps {
runInsideExecutor(
'',
pipelineInfo.dockerDir,
) {
echo("Building ${buildMode}/${linkMode}")
buildExamples(
pipelineInfo.connextArch,
pipelineInfo.connextDir,
buildMode,
linkMode,
env.WORKSPACE,
)
}
}
}
}
}
}
stage('Static Analysis') {
steps {
runInsideExecutor(
'',
pipelineInfo.dockerDir,
) {
runStaticAnalysis(
buildExamples.getBuildDirectory('release', 'dynamic'),
pipelineInfo.connextDir,
pipelineInfo.staticAnalysisDir,
)
}
publishHTML(target: [
allowMissing: true,
alwaysLinkToLastBuild: true,
keepAll: true,
reportDir: pipelineInfo.staticAnalysisDir,
reportFiles: 'index.html',
reportName: 'LLVM Scan build static analysis',
])
}
}
}
post {
cleanup {
cleanWs()
}
}
}