forked from hyperledger-archives/sawtooth-supply-chain
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Jenkinsfile
126 lines (112 loc) · 3.92 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
115
116
117
118
119
120
121
122
123
124
125
126
#!groovy
// Copyright 2017 Intel Corporation
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
// ------------------------------------------------------------------------------
pipeline {
agent {
node {
label 'master'
customWorkspace "workspace/${env.BUILD_TAG}"
}
}
triggers {
cron(env.BRANCH_NAME == 'master' ? 'H 3 * * *' : '')
}
options {
timestamps()
buildDiscarder(logRotator(daysToKeepStr: '31'))
}
environment {
ISOLATION_ID = sh(returnStdout: true, script: 'printf $BUILD_TAG | sha256sum | cut -c1-64').trim()
}
stages {
stage('Check Whitelist') {
steps {
readTrusted 'bin/whitelist'
sh './bin/whitelist "$CHANGE_AUTHOR" /etc/jenkins-authorized-builders'
}
when {
not {
branch 'master'
}
}
}
stage('Check for Signed-Off Commits') {
steps {
sh '''#!/bin/bash -l
if [ -v CHANGE_URL ] ;
then
temp_url="$(echo $CHANGE_URL |sed s#github.com/#api.github.com/repos/#)/commits"
pull_url="$(echo $temp_url |sed s#pull#pulls#)"
IFS=$'\n'
for m in $(curl -s "$pull_url" | grep "message") ; do
if echo "$m" | grep -qi signed-off-by:
then
continue
else
echo "FAIL: Missing Signed-Off Field"
echo "$m"
exit 1
fi
done
unset IFS;
fi
'''
}
}
stage('Fetch Tags') {
steps {
sh 'git fetch --tag'
}
}
stage('Build Test Dependencies') {
steps {
sh 'docker-compose -f docker-compose-installed.yaml build --force-rm'
}
}
stage('Create Git Archive') {
steps {
sh '''
REPO=$(git remote show -n origin | grep Fetch | awk -F'[/.]' '{print $6}')
VERSION=`git describe --dirty`
git archive HEAD --format=zip -9 --output=$REPO-$VERSION.zip
git archive HEAD --format=tgz -9 --output=$REPO-$VERSION.tgz
'''
}
}
stage ('Build Documentation') {
steps {
sh 'docker build . -f docs/supply-chain-build-docs -t supply-chain-build-docs:$ISOLATION_ID'
sh 'docker run --rm -v $(pwd):/project/sawtooth-supply-chain supply-chain-build-docs:$ISOLATION_ID'
}
}
stage('Build Archive Artifacts') {
steps {
sh 'mkdir -p build/debs'
sh 'docker run -v $(pwd)/build/debs:/build supply-tp-installed:$ISOLATION_ID bash -c "cp /tmp/supply-chain-tp*.deb /build"'
}
}
}
post {
success {
archiveArtifacts '*.tgz, *.zip, build/debs/*.deb, docs/build/html/**, docs/build/latex/*.pdf'
}
aborted {
error "Aborted, exiting now"
}
failure {
error "Failed, exiting now"
}
}
}