2017-08-03 18:18:55 -04:00
|
|
|
#!/usr/bin/env bash
|
|
|
|
|
2017-11-29 05:47:04 -05:00
|
|
|
set -eu -o pipefail
|
|
|
|
|
2020-03-10 01:17:48 -04:00
|
|
|
# statc makes `stat -c` work on both Linux & OSX
|
|
|
|
function statc () {
|
|
|
|
case $(uname) in
|
|
|
|
Darwin*) format='-f%z' ;;
|
|
|
|
*) format='-c%s' ;;
|
|
|
|
esac
|
|
|
|
|
|
|
|
stat ${format} $@
|
|
|
|
}
|
|
|
|
|
|
|
|
# sedr makes `sed -r` work on both Linux & OSX
|
|
|
|
function sedr () {
|
|
|
|
case $(uname) in
|
|
|
|
Darwin*) flag='-E' ;;
|
|
|
|
*) flag='-r' ;;
|
|
|
|
esac
|
|
|
|
|
|
|
|
sed ${flag} "$@"
|
|
|
|
}
|
|
|
|
|
2017-08-03 18:18:55 -04:00
|
|
|
readonly PROJECT_NAME="angular-payload-size"
|
2018-04-11 19:01:53 -04:00
|
|
|
NODE_MODULES_BIN=$PROJECT_ROOT/node_modules/.bin/
|
2017-08-03 18:18:55 -04:00
|
|
|
|
2018-10-25 06:50:32 -04:00
|
|
|
# Get the gzip size of a file with the specified compression level.
|
|
|
|
# $1: string - The file path.
|
|
|
|
# $2: number - The level of compression.
|
|
|
|
getGzipSize() {
|
|
|
|
local filePath=$1
|
|
|
|
local compLevel=$2
|
|
|
|
local compPath=$1$2.gz
|
|
|
|
local size=-1
|
|
|
|
|
|
|
|
gzip -c -$compLevel "$filePath" >> "$compPath"
|
2020-03-10 01:17:48 -04:00
|
|
|
size=$(statc "$compPath")
|
2018-10-25 06:50:32 -04:00
|
|
|
rm "$compPath"
|
|
|
|
|
|
|
|
echo $size
|
|
|
|
}
|
|
|
|
|
2017-08-03 18:18:55 -04:00
|
|
|
# Calculate the size of target file uncompressed size, gzip7 size, gzip9 size
|
|
|
|
# Write to global variable $payloadData, $filename
|
|
|
|
calculateSize() {
|
|
|
|
label=$(echo "$filename" | sed "s/.*\///" | sed "s/\..*//")
|
|
|
|
|
2020-03-10 01:17:48 -04:00
|
|
|
rawSize=$(statc $filename)
|
2019-10-11 08:29:23 -04:00
|
|
|
gzip7Size=$(getGzipSize "$filename" 7)
|
|
|
|
gzip9Size=$(getGzipSize "$filename" 9)
|
|
|
|
|
|
|
|
# Log the sizes (for information/debugging purposes).
|
|
|
|
printf "Size: %6d (gzip7: %6d, gzip9: %6d) %s\n" $rawSize $gzip7Size $gzip9Size $label
|
|
|
|
|
|
|
|
payloadData="$payloadData\"uncompressed/$label\": $rawSize, "
|
|
|
|
payloadData="$payloadData\"gzip7/$label\": $gzip7Size, "
|
|
|
|
payloadData="$payloadData\"gzip9/$label\": $gzip9Size, "
|
2017-08-03 18:18:55 -04:00
|
|
|
}
|
|
|
|
|
2017-11-29 05:47:04 -05:00
|
|
|
# Check whether the file size is under limit.
|
|
|
|
# Exit with an error if limit is exceeded.
|
|
|
|
# $1: string - The name in database.
|
|
|
|
# $2: string - The payload size limit file.
|
2017-08-03 18:18:55 -04:00
|
|
|
checkSize() {
|
2017-11-18 15:26:33 -05:00
|
|
|
name="$1"
|
|
|
|
limitFile="$2"
|
2018-10-17 12:19:15 -04:00
|
|
|
|
|
|
|
# In non-PR builds, `CI_BRANCH` is the branch being built (e.g. `pull/12345`), not the targeted branch.
|
|
|
|
# Thus, PRs will fall back to using the size limits for `master`.
|
2020-03-10 01:17:48 -04:00
|
|
|
node ${PROJECT_ROOT}/scripts/ci/payload-size.js $limitFile $name ${CI_BRANCH:-} ${CI_COMMIT:-}
|
2017-08-03 18:18:55 -04:00
|
|
|
}
|
|
|
|
|
2017-11-29 05:47:04 -05:00
|
|
|
# Write timestamp to global variable `$payloadData`.
|
2017-08-03 18:18:55 -04:00
|
|
|
addTimestamp() {
|
|
|
|
# Add Timestamp
|
|
|
|
timestamp=$(date +%s)
|
|
|
|
payloadData="$payloadData\"timestamp\": $timestamp, "
|
|
|
|
}
|
|
|
|
|
2019-09-07 11:48:51 -04:00
|
|
|
# Write the current CI build URL to global variable `$payloadData`.
|
|
|
|
# This allows mapping the data stored in the database to the CI build job that generated it, which
|
|
|
|
# might contain more info/context.
|
|
|
|
# $1: string - The CI build URL.
|
|
|
|
addBuildUrl() {
|
|
|
|
buildUrl="$1"
|
|
|
|
payloadData="$payloadData\"buildUrl\": \"$buildUrl\", "
|
|
|
|
}
|
|
|
|
|
2019-01-08 06:41:24 -05:00
|
|
|
# Write the commit message for the current CI commit range to global variable `$payloadData`.
|
2018-10-18 08:43:58 -04:00
|
|
|
# $1: string - The commit range for this build (in `<SHA-1>...<SHA-2>` format).
|
2017-08-03 18:18:55 -04:00
|
|
|
addMessage() {
|
2018-10-18 08:43:58 -04:00
|
|
|
commitRange="$1"
|
|
|
|
|
2017-08-24 15:49:58 -04:00
|
|
|
# Grab the set of SHAs for the message. This can fail when you force push or do initial build
|
2018-10-17 12:19:15 -04:00
|
|
|
# because $CI_COMMIT_RANGE may contain the previous SHA which will not be in the
|
2017-08-24 15:49:58 -04:00
|
|
|
# force push or commit, hence we default to last commit.
|
2020-03-10 01:17:48 -04:00
|
|
|
message=$(git --git-dir ${PROJECT_ROOT}/.git log --oneline $commitRange -- || git --git-dir ${PROJECT_ROOT}/.git log --oneline -n1)
|
2017-09-13 10:21:20 -04:00
|
|
|
message=$(echo $message | sed 's/\\/\\\\/g' | sed 's/"/\\"/g')
|
2018-10-18 08:43:58 -04:00
|
|
|
payloadData="$payloadData\"message\": \"$message\", "
|
2017-08-03 18:18:55 -04:00
|
|
|
}
|
|
|
|
|
2018-10-18 08:43:58 -04:00
|
|
|
# Convert the current `payloadData` value to a JSON string.
|
|
|
|
# (Basically remove trailing `,` and wrap in `{...}`.)
|
|
|
|
payloadToJson() {
|
2020-03-10 01:17:48 -04:00
|
|
|
echo "{$(sedr 's|, *$||' <<< $payloadData)}"
|
2018-10-18 08:43:58 -04:00
|
|
|
}
|
|
|
|
|
2017-11-29 05:47:04 -05:00
|
|
|
# Upload data to firebase database if it's commit, print out data for pull requests.
|
|
|
|
# $1: string - The name in database.
|
2017-08-03 18:18:55 -04:00
|
|
|
uploadData() {
|
|
|
|
name="$1"
|
2017-11-03 18:20:09 -04:00
|
|
|
|
2018-10-17 12:19:15 -04:00
|
|
|
readonly safeBranchName=$(echo $CI_BRANCH | sed -e 's/\./_/g')
|
2018-10-18 08:43:58 -04:00
|
|
|
readonly dbPath=/payload/$name/$safeBranchName/$CI_COMMIT
|
|
|
|
readonly jsonPayload=$(payloadToJson)
|
2017-08-03 18:18:55 -04:00
|
|
|
|
2018-10-18 08:43:58 -04:00
|
|
|
# WARNING: CI_SECRET_PAYLOAD_FIREBASE_TOKEN should NOT be printed.
|
|
|
|
set +x
|
|
|
|
$NODE_MODULES_BIN/firebase database:update --data "$jsonPayload" --project $PROJECT_NAME --confirm --token "$CI_SECRET_PAYLOAD_FIREBASE_TOKEN" $dbPath
|
2017-08-03 18:18:55 -04:00
|
|
|
}
|
|
|
|
|
2017-11-29 05:47:04 -05:00
|
|
|
# Track payload size.
|
|
|
|
# $1: string - The name in database.
|
|
|
|
# $2: string - The file path.
|
|
|
|
# $3: true | false - Whether to check the payload size and fail the test if it exceeds limit.
|
2019-11-22 08:16:39 -05:00
|
|
|
# $4: [string] - The payload size limit file. Only necessary if `$3` is `true`.
|
2017-08-03 18:18:55 -04:00
|
|
|
trackPayloadSize() {
|
|
|
|
name="$1"
|
|
|
|
path="$2"
|
|
|
|
checkSize="$3"
|
2019-11-22 08:16:39 -05:00
|
|
|
limitFile="${4:-}"
|
2017-08-03 18:18:55 -04:00
|
|
|
|
|
|
|
payloadData=""
|
2017-11-29 05:47:04 -05:00
|
|
|
|
2018-10-18 08:43:58 -04:00
|
|
|
# Calculate the file sizes.
|
2019-11-22 08:16:39 -05:00
|
|
|
echo "Calculating sizes for files in '$path'..."
|
2017-08-03 18:18:55 -04:00
|
|
|
for filename in $path; do
|
|
|
|
calculateSize
|
|
|
|
done
|
2018-10-18 08:43:58 -04:00
|
|
|
|
|
|
|
# Save the file sizes to be retrieved from `payload-size.js`.
|
|
|
|
echo "$(payloadToJson)" > /tmp/current.log
|
|
|
|
|
|
|
|
# If this is a non-PR build, upload the data to firebase.
|
2020-03-10 01:17:48 -04:00
|
|
|
if [[ "${CI_PULL_REQUEST:-}" == "false" ]]; then
|
2019-11-22 08:16:39 -05:00
|
|
|
echo "Uploading data for '$name'..."
|
2019-06-19 12:05:54 -04:00
|
|
|
addTimestamp
|
2019-09-07 11:48:51 -04:00
|
|
|
addBuildUrl $CI_BUILD_URL
|
2019-06-19 12:05:54 -04:00
|
|
|
addMessage $CI_COMMIT_RANGE
|
|
|
|
uploadData $name
|
2019-11-22 08:16:39 -05:00
|
|
|
else
|
|
|
|
echo "Skipped uploading data for '$name', because this is a pull request."
|
2019-06-19 12:05:54 -04:00
|
|
|
fi
|
2018-10-18 08:43:58 -04:00
|
|
|
|
|
|
|
# Check the file sizes against the specified limits.
|
2017-11-18 15:26:33 -05:00
|
|
|
if [[ $checkSize = true ]]; then
|
2019-11-22 08:16:39 -05:00
|
|
|
echo "Verifying sizes against '$limitFile'..."
|
2017-11-29 05:47:04 -05:00
|
|
|
checkSize $name $limitFile
|
2019-11-22 08:16:39 -05:00
|
|
|
else
|
|
|
|
echo "Skipped verifying sizes (checkSize: false)."
|
2017-08-03 18:18:55 -04:00
|
|
|
fi
|
|
|
|
}
|