This repository has been archived by the owner on May 13, 2020. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 7
/
Jenkinsfile
executable file
·89 lines (89 loc) · 2.16 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
pipeline {
agent {
node {
label 'rust&&sgx'
}
}
options {
timeout(time: 2, unit: 'HOURS')
buildDiscarder(logRotator(numToKeepStr: '14'))
}
stages {
stage('Environment') {
steps {
sh './ci/install_rust.sh'
}
}
stage('Build') {
steps {
sh 'cargo build | tee build.log'
}
}
stage('Test') {
steps {
echo 'Stage TEST'
sh 'cargo test --all'
}
}
stage('Clippy') {
steps {
sh 'cargo clean'
catchError(buildResult: 'SUCCESS', stageResult: 'FAILURE') {
sh 'cargo +nightly-2019-11-25 clippy 2>&1 | tee clippy.log'
}
}
}
stage('Formatter') {
steps {
catchError(buildResult: 'SUCCESS', stageResult: 'UNSTABLE') {
sh 'cargo fmt -- --check > ${WORKSPACE}/fmt.log'
}
}
}
stage('Results') {
steps {
recordIssues(
aggregatingResults: true,
enabledForFailure: true,
qualityGates: [[threshold: 1, type: 'TOTAL', unstable: true]],
tools: [
cargo(
pattern: 'build.log',
reportEncoding: 'UTF-8'
),
groovyScript(
parserId:'clippy-warnings',
pattern: 'clippy.log',
reportEncoding: 'UTF-8'
),
groovyScript(
parserId:'clippy-errors',
pattern: 'clippy.log',
reportEncoding: 'UTF-8'
)
]
)
catchError(buildResult: 'SUCCESS', stageResult: 'UNSTABLE') {
sh './ci/check_fmt_log.sh'
}
}
}
stage('Archive build output') {
steps {
archiveArtifacts artifacts: '*.log'
}
}
}
post {
unsuccessful {
emailext (
subject: "Jenkins Build '${env.JOB_NAME} [${env.BUILD_NUMBER}]' is ${currentBuild.currentResult}",
body: "${env.JOB_NAME} build ${env.BUILD_NUMBER} is ${currentBuild.currentResult}\n\nMore info at: ${env.BUILD_URL}",
to: "${env.RECIPIENTS_SUBSTRATEE}"
)
}
always {
cleanWs()
}
}
}