2019-11-22 02:25:46 +03:00
|
|
|
#!/bin/bash
|
|
|
|
set -e
|
|
|
|
set +x
|
|
|
|
|
2019-11-26 04:55:57 +03:00
|
|
|
if [[ $(uname) != "Linux" ]]; then
|
2020-03-07 19:37:47 +03:00
|
|
|
echo "ERROR: this script is designed to be run on Linux. Can't run on $(uname)"
|
2019-11-26 04:55:57 +03:00
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
|
2020-07-23 21:59:23 +03:00
|
|
|
CURRENT_HOST_OS="$(bash -c 'source /etc/os-release && echo $NAME')"
|
|
|
|
CURRENT_HOST_OS_VERSION="$(bash -c 'source /etc/os-release && echo $VERSION_ID')"
|
|
|
|
|
|
|
|
if [[ "$CURRENT_HOST_OS" != "Ubuntu" || "$CURRENT_HOST_OS_VERSION" != "18.04" ]]; then
|
|
|
|
echo "ERROR: this script is designed to be run on Ubuntu 18.04. Can't run on $CURRENT_HOST_OS $CURRENT_HOST_OS_VERSION"
|
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
|
2019-11-22 02:25:46 +03:00
|
|
|
if [[ ($1 == '--help') || ($1 == '-h') ]]; then
|
2019-11-23 07:30:38 +03:00
|
|
|
echo "usage: $(basename $0)"
|
2019-11-22 02:25:46 +03:00
|
|
|
echo
|
|
|
|
echo "Pull from upstream & run checkout_build_archive_upload.sh"
|
|
|
|
echo "in a safe way so that multiple instances of the script cannot be run"
|
2019-11-23 07:25:36 +03:00
|
|
|
echo
|
|
|
|
echo "This script is designed to be run as a cronjob"
|
2019-11-22 02:25:46 +03:00
|
|
|
exit 0
|
|
|
|
fi
|
|
|
|
|
2019-11-22 05:52:51 +03:00
|
|
|
if [[ (-z $AZ_ACCOUNT_KEY) || (-z $AZ_ACCOUNT_NAME) ]]; then
|
|
|
|
echo "ERROR: Either \$AZ_ACCOUNT_KEY or \$AZ_ACCOUNT_NAME environment variable is missing."
|
|
|
|
echo " 'Azure Account Name' and 'Azure Account Key' secrets that are required"
|
|
|
|
echo " to upload builds ot Azure CDN."
|
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
|
2019-11-23 02:48:25 +03:00
|
|
|
if ! command -v az >/dev/null; then
|
2019-11-22 06:14:30 +03:00
|
|
|
echo "ERROR: az is not found in PATH"
|
|
|
|
exit 1
|
|
|
|
fi
|
2019-11-22 05:52:51 +03:00
|
|
|
|
2019-11-22 02:25:46 +03:00
|
|
|
# Setup a LOCKDIR so that we don't run the same script multiple times.
|
2019-11-23 07:25:36 +03:00
|
|
|
LOCKDIR="/tmp/$(basename $0).lock"
|
2019-11-22 02:25:46 +03:00
|
|
|
if [[ -d ${LOCKDIR} ]]; then
|
|
|
|
echo "Already running (lockdir $LOCKDIR exists. Remove it manually if running)"
|
|
|
|
exit 0
|
|
|
|
fi
|
2019-11-23 07:25:36 +03:00
|
|
|
|
2019-11-22 04:39:11 +03:00
|
|
|
mkdir -p $LOCKDIR
|
2019-11-22 02:25:46 +03:00
|
|
|
# make sure the lockfile is removed when we exit and then claim it
|
|
|
|
trap "rm -rf ${LOCKDIR}; cd $(pwd -P); exit" INT TERM EXIT
|
|
|
|
cd "$(dirname "$0")"
|
|
|
|
|
|
|
|
# Check if git repo is dirty.
|
|
|
|
if [[ -n $(git status -s) ]]; then
|
2019-11-23 07:25:36 +03:00
|
|
|
echo "ERROR: dirty GIT state - commit everything and re-run the script."
|
2019-11-22 02:25:46 +03:00
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
|
2020-07-24 00:44:28 +03:00
|
|
|
IS_FIRST_RUN_FILE="/tmp/pw-buildbot-first-run.txt";
|
|
|
|
if ! [[ -f $IS_FIRST_RUN_FILE ]]; then
|
|
|
|
source ./send_telegram_message.sh
|
|
|
|
send_telegram_message '**Ubuntu 18.04 Buildbot Is Active**'
|
|
|
|
fi
|
|
|
|
touch "$IS_FIRST_RUN_FILE"
|
|
|
|
|
2019-11-22 02:25:46 +03:00
|
|
|
git pull origin master
|
2020-07-23 21:59:23 +03:00
|
|
|
../checkout_build_archive_upload.sh firefox-ubuntu-18.04 >/tmp/$(basename $0)--firefox.log || true
|
2019-11-23 07:25:36 +03:00
|
|
|
|
|
|
|
git pull origin master
|
2020-07-24 01:57:53 +03:00
|
|
|
../checkout_build_archive_upload.sh webkit-ubuntu-18.04 >/tmp/$(basename $0)--webkit.log || true
|
2020-08-08 02:22:05 +03:00
|
|
|
|
|
|
|
git pull origin master
|
|
|
|
../checkout_build_archive_upload.sh chromium-linux-mirror-to-cdn >/tmp/$(basename $0)--chromium-linux.log || true
|
|
|
|
../checkout_build_archive_upload.sh chromium-mac-mirror-to-cdn >/tmp/$(basename $0)--chromium-mac.log || true
|
|
|
|
../checkout_build_archive_upload.sh chromium-win32-mirror-to-cdn >/tmp/$(basename $0)--chromium-win32.log || true
|
|
|
|
../checkout_build_archive_upload.sh chromium-win64-mirror-to-cdn >/tmp/$(basename $0)--chromium-win64.log || true
|