forked from nrfconnect/sdk-zephyr
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathJenkinsfile
114 lines (103 loc) · 3.71 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
def IMAGE_TAG = "ncs-toolchain:1.08"
def REPO_CI_TOOLS = "https://github.com/zephyrproject-rtos/ci-tools.git"
def REPO_CI_TOOLS_SHA = "9f4dc0be401c2b1e9b1c647513fb996bd8abd057"
pipeline {
agent {
docker {
image "$IMAGE_TAG"
label "docker && ncs"
args '-e PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/workdir/.local/bin'
}
}
options {
// Checkout the repository to this folder instead of root
checkoutToSubdirectory('zephyr')
}
environment {
// ENVs for check-compliance
GH_TOKEN = credentials('nordicbuilder-compliance-token') // This token is used to by check_compliance to comment on PRs and use checks
GH_USERNAME = "NordicBuilder"
COMPLIANCE_ARGS = "-r NordicPlayground/fw-nrfconnect-zephyr"
COMPLIANCE_REPORT_ARGS = "-p $CHANGE_ID -S $GIT_COMMIT -g"
LC_ALL = "C.UTF-8"
// ENVs for sanitycheck
ARCH = "-a arm"
SANITYCHECK_OPTIONS = "--inline-logs --enable-coverage -N"
SANITYCHECK_RETRY = "--only-failed --outdir=out-2nd-pass"
SANITYCHECK_RETRY_2 = "--only-failed --outdir=out-3rd-pass"
// ENVs for building (triggered by sanitycheck)
ZEPHYR_TOOLCHAIN_VARIANT = 'zephyr'
GNUARMEMB_TOOLCHAIN_PATH = '/workdir/gcc-arm-none-eabi-7-2018-q2-update'
ZEPHYR_SDK_INSTALL_DIR = '/opt/zephyr-sdk'
}
stages {
stage('Checkout repositories') {
steps {
dir("ci-tools") {
git branch: "master", url: "$REPO_CI_TOOLS"
sh "git checkout ${REPO_CI_TOOLS_SHA}"
}
dir('zephyr') {
sh "git rev-parse HEAD"
}
// Initialize west
sh "west init -l zephyr/"
// Checkout
sh "west update"
}
}
stage('Testing') {
parallel {
stage('Run compliance check') {
steps {
dir('zephyr') {
script {
// If we're a pull request, compare the target branch against the current HEAD (the PR)
if (env.CHANGE_TARGET) {
COMMIT_RANGE = "origin/$CHANGE_TARGET..HEAD"
COMPLIANCE_ARGS = "$COMPLIANCE_ARGS $COMPLIANCE_REPORT_ARGS"
sh "echo change id: $CHANGE_ID"
sh "echo git commit: $GIT_COMMIT"
sh "echo commit range: $COMMIT_RANGE"
sh "git rev-parse origin/$CHANGE_TARGET"
sh "git rev-parse HEAD"
}
// If not a PR, it's a non-PR-branch or master build. Compare against the origin.
else {
COMMIT_RANGE = "origin/${env.BRANCH_NAME}..HEAD"
}
// Run the compliance check
try {
sh "(source zephyr-env.sh && ../ci-tools/scripts/check_compliance.py $COMPLIANCE_ARGS --commits $COMMIT_RANGE)"
}
finally {
junit 'compliance.xml'
archiveArtifacts artifacts: 'compliance.xml'
}
}
}
}
}
stage('Sanitycheck (all)') {
steps {
dir('zephyr') {
sh "echo variant: $ZEPHYR_TOOLCHAIN_VARIANT"
sh "echo SDK dir: $ZEPHYR_SDK_INSTALL_DIR"
sh "cat /opt/zephyr-sdk/sdk_version"
sh "source zephyr-env.sh && \
(./scripts/sanitycheck $SANITYCHECK_OPTIONS $ARCH || \
(sleep 10; ./scripts/sanitycheck $SANITYCHECK_OPTIONS $SANITYCHECK_RETRY) || \
(sleep 10; ./scripts/sanitycheck $SANITYCHECK_OPTIONS $SANITYCHECK_RETRY_2))"
}
}
}
}
}
}
post {
always {
// Clean up the working space at the end (including tracked files)
cleanWs()
}
}
}