-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy pathbuild-locally.sh
executable file
·198 lines (175 loc) · 7.22 KB
/
build-locally.sh
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
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
#!/usr/bin/env bash
#
# Copyright contributors to the Galasa project
#
# SPDX-License-Identifier: EPL-2.0
#
# Where is this script executing from ?
BASEDIR=$(dirname "$0");pushd $BASEDIR 2>&1 >> /dev/null ;BASEDIR=$(pwd);popd 2>&1 >> /dev/null
# echo "Running from directory ${BASEDIR}"
export ORIGINAL_DIR=$(pwd)
cd "${BASEDIR}"
#--------------------------------------------------------------------------
# Set Colors
#--------------------------------------------------------------------------
bold=$(tput bold)
underline=$(tput sgr 0 1)
reset=$(tput sgr0)
red=$(tput setaf 1)
green=$(tput setaf 76)
white=$(tput setaf 7)
tan=$(tput setaf 202)
blue=$(tput setaf 25)
#--------------------------------------------------------------------------
#
# Headers and Logging
#
#--------------------------------------------------------------------------
underline() { printf "${underline}${bold}%s${reset}\n" "$@" ;}
h1() { printf "\n${underline}${bold}${blue}%s${reset}\n" "$@" ;}
h2() { printf "\n${underline}${bold}${white}%s${reset}\n" "$@" ;}
debug() { printf "${white}%s${reset}\n" "$@" ;}
info() { printf "${white}➜ %s${reset}\n" "$@" ;}
success() { printf "${green}✔ %s${reset}\n" "$@" ;}
error() { printf "${red}✖ %s${reset}\n" "$@" ;}
warn() { printf "${tan}➜ %s${reset}\n" "$@" ;}
bold() { printf "${bold}%s${reset}\n" "$@" ;}
note() { printf "\n${underline}${bold}${blue}Note:${reset} ${blue}%s${reset}\n" "$@" ;}
#-----------------------------------------------------------------------------------------
# Functions
#-----------------------------------------------------------------------------------------
function usage {
info "Syntax: build-locally.sh [OPTIONS]"
cat << EOF
Options are:
-c | --clean : Do a clean build. One of the --clean or --delta flags are mandatory.
-d | --delta : Do a delta build. One of the --clean or --delta flags are mandatory.
Environment variables used:
None
EOF
}
#--------------------------------------------------------------------------
#
# Main script logic
#
#--------------------------------------------------------------------------
#-----------------------------------------------------------------------------------------
# Process parameters
#-----------------------------------------------------------------------------------------
build_type=""
while [ "$1" != "" ]; do
case $1 in
-c | --clean ) build_type="clean"
;;
-d | --delta ) build_type="delta"
;;
-h | --help ) usage
exit
;;
* ) error "Unexpected argument $1"
usage
exit 1
esac
shift
done
if [[ "${build_type}" == "" ]]; then
error "Need to use either the --clean or --delta parameter."
usage
exit 1
fi
function check_exit_code () {
# This function takes 2 parameters in the form:
# $1 an integer value of the returned exit code
# $2 an error message to display if $1 is not equal to 0
if [[ "$1" != "0" ]]; then
error "$2"
exit 1
fi
}
function check_secrets {
h2 "updating secrets baseline"
cd ${BASEDIR}
detect-secrets scan --exclude-files "build-images/github-webhook-receiver/go.sum|go.work.sum|offline-tools/copyrighter/go.sum|build-images/github-webhook-monitor/go.sum" --update .secrets.baseline
rc=$?
check_exit_code $rc "Failed to run detect-secrets. Please check it is installed properly"
success "updated secrets file"
h2 "running audit for secrets"
detect-secrets audit .secrets.baseline
rc=$?
check_exit_code $rc "Failed to audit detect-secrets."
#Check all secrets have been audited
secrets=$(grep -c hashed_secret .secrets.baseline)
audits=$(grep -c is_secret .secrets.baseline)
if [[ "$secrets" != "$audits" ]]; then
error "Not all secrets found have been audited"
exit 1
fi
sed -i '' '/[ ]*"generated_at": ".*",/d' .secrets.baseline
success "secrets audit complete"
}
#--------------------------------------------------------------------------
# Clean up if we need to.
#--------------------------------------------------------------------------
if [[ "${build_type}" == "clean" ]]; then
h2 "Cleaning the binaries out..."
cd ${BASEDIR}/build-images/github-webhook-receiver
make clean
rc=$?
check_exit_code $rc "Failed to build and run unit tests. rc=${rc}"
success "Binaries cleaned up - OK"
fi
#--------------------------------------------------------------------------
# Setup go packages
#--------------------------------------------------------------------------
h2 "Getting dependent Go packages..."
cd ${BASEDIR}/build-images/github-webhook-receiver
make setup
rc=$?
check_exit_code $rc "Failed to get golang dependencies. rc=${rc}"
success "New binaries built - OK"
#--------------------------------------------------------------------------
# Build and invoke unit tests
#--------------------------------------------------------------------------
h2 "Building new binaries..."
cd ${BASEDIR}/build-images/github-webhook-receiver
make delta-build
rc=$?
check_exit_code $rc "Failed to build binary executable programs. rc=${rc}"
success "New binaries built - OK"
#--------------------------------------------------------------------------
# Build the documentation
# generated_docs_folder=${BASEDIR}/github-webhook-receiver/docs/generated
# h2 "Generating documentation"
# info "Documentation will be placed in ${generated_docs_folder}"
# mkdir -p ${generated_docs_folder}
# # Figure out which type of machine this script is currently running on.
# unameOut="$(uname -s)"
# case "${unameOut}" in
# Linux*) machine=linux;;
# Darwin*) machine=darwin;;
# *) error "Unknown machine type ${unameOut}"
# exit 1
# esac
# architecture="$(uname -m)"
# # Call the documentation generator, which builds .md files
# info "Using program ${BASEDIR}/bin/gendocs-github-webhook-receiver-${machine}-${architecture} to generate the documentation..."
# ${BASEDIR}/bin/gendocs-galasactl-${machine}-${architecture} ${generated_docs_folder}
# rc=$? ; if [[ "${rc}" != "0" ]]; then error "Failed to generate documentation. rc=${rc}" ; exit 1 ; fi
# # The files have a line "###### Auto generated by cobra at 17/12/2022"
# # As we are (currently) checking-in these .md files, we don't want them to show as
# # changed in git (which compares the content, not timestamps).
# # So lets remove these lines from all the .md files.
# info "Removing lines with date/time in, to limit delta changes in git..."
# mkdir -p ${BASEDIR}/build
# temp_file="${BASEDIR}/build/temp.md"
# for FILE in ${generated_docs_folder}/*; do
# mv -f ${FILE} ${temp_file}
# cat ${temp_file} | grep -v "###### Auto generated by" > ${FILE}
# rm ${temp_file}
# success "Processed file ${FILE}"
# done
# success "Documentation generated - OK"
#--------------------------------------------------------------------------
h2 "Use the results.."
info "Binary executable programs are found in the 'bin' folder."
ls ${BASEDIR}/build-images/github-webhook-receiver/bin | grep -v "gendocs"