playwright/browser_patches/export.sh

134 lines
4.0 KiB
Bash
Raw Normal View History

2019-11-19 05:18:28 +03:00
#!/bin/bash
set -e
set +x
2019-11-20 03:08:27 +03:00
trap "cd $(pwd -P)" EXIT
2019-11-19 05:18:28 +03:00
cd "$(dirname "$0")"
2019-11-22 04:06:57 +03:00
REMOTE_BROWSER_UPSTREAM="browser_upstream"
BUILD_BRANCH="playwright-build"
2019-11-19 05:18:28 +03:00
if [[ ($1 == '--help') || ($1 == '-h') ]]; then
echo "usage: export.sh [firefox|webkit] [custom_checkout_path]"
echo
2019-11-22 04:06:57 +03:00
echo "Exports patch from the current branch of the checkout to browser folder."
echo "The checkout has to be 'prepared', meaning that 'prepare_checkout.sh' should be"
echo "run against it first."
2019-11-19 05:18:28 +03:00
echo
echo "You can optionally specify custom_checkout_path if you have browser checkout somewhere else"
echo "and wish to export patches from it."
echo
exit 0
fi
if [[ $# == 0 ]]; then
echo "missing browser: 'firefox' or 'webkit'"
echo "try './export.sh --help' for more information"
exit 1
fi
# FRIENDLY_CHECKOUT_PATH is used only for logging.
FRIENDLY_CHECKOUT_PATH="";
CHECKOUT_PATH=""
EXPORT_PATH=""
if [[ ("$1" == "firefox") || ("$1" == "firefox/") ]]; then
FRIENDLY_CHECKOUT_PATH="//browser_patches/firefox/checkout";
CHECKOUT_PATH="$PWD/firefox/checkout"
EXPORT_PATH="$PWD/firefox/"
2019-11-22 04:06:57 +03:00
source "./firefox/UPSTREAM_CONFIG.sh"
2019-11-19 05:18:28 +03:00
elif [[ ("$1" == "webkit") || ("$1" == "webkit/") ]]; then
FRIENDLY_CHECKOUT_PATH="//browser_patches/webkit/checkout";
CHECKOUT_PATH="$PWD/webkit/checkout"
EXPORT_PATH="$PWD/webkit/"
2019-11-22 04:06:57 +03:00
source "./webkit/UPSTREAM_CONFIG.sh"
2019-11-19 05:18:28 +03:00
else
echo ERROR: unknown browser to export - "$1"
exit 1
fi
# we will use this just for beauty.
if [[ $# == 2 ]]; then
echo "WARNING: using custom checkout path $2"
2019-11-19 05:18:28 +03:00
CHECKOUT_PATH=$2
FRIENDLY_CHECKOUT_PATH="<custom_checkout ( $2 )>"
2019-11-19 05:18:28 +03:00
fi
# if there's no checkout folder - bail out.
if ! [[ -d $CHECKOUT_PATH ]]; then
echo "ERROR: $FRIENDLY_CHECKOUT_PATH is missing - nothing to export."
exit 1;
else
echo "-- checking $FRIENDLY_CHECKOUT_PATH exists - OK"
fi
# if folder exists but not a git repository - bail out.
if ! [[ -d $CHECKOUT_PATH/.git ]]; then
echo "ERROR: $FRIENDLY_CHECKOUT_PATH is not a git repository! Nothing to export."
exit 1
else
echo "-- checking $FRIENDLY_CHECKOUT_PATH is a git repo - OK"
fi
# Switch to git repository.
cd $CHECKOUT_PATH
2019-11-22 04:06:57 +03:00
# Setting up |$REMOTE_BROWSER_UPSTREAM| remote and fetch the $BASE_BRANCH
if git remote get-url $REMOTE_BROWSER_UPSTREAM >/dev/null; then
if ! [[ $(git config --get remote.$REMOTE_BROWSER_UPSTREAM.url || echo "") == "$REMOTE_URL" ]]; then
echo "ERROR: remote $REMOTE_BROWSER_UPSTREAM is not pointing to '$REMOTE_URL'! run `prepare_checkout.sh` first"
exit 1
2019-11-22 04:06:57 +03:00
fi
else
echo "ERROR: checkout does not have $REMOTE_BROWSER_UPSTREAM; run `prepare_checkout.sh` first"
exit 1
fi
2019-11-19 05:18:28 +03:00
# Check if git repo is dirty.
if [[ -n $(git status -s --untracked-files=no) ]]; then
2019-11-19 05:18:28 +03:00
echo "ERROR: $FRIENDLY_CHECKOUT_PATH has dirty GIT state - aborting export."
exit 1
else
echo "-- checking $FRIENDLY_CHECKOUT_PATH is clean - OK"
fi
CURRENT_BRANCH=$(git rev-parse --abbrev-ref HEAD)
NEW_BASE_REVISION=$(git merge-base $REMOTE_BROWSER_UPSTREAM/$BASE_BRANCH $CURRENT_BRANCH)
2019-11-19 05:18:28 +03:00
echo "=============================================================="
echo " Repository: $FRIENDLY_CHECKOUT_PATH"
2019-11-22 04:06:57 +03:00
echo " Changes between branches: $REMOTE_BROWSER_UPSTREAM/$BASE_BRANCH..$CURRENT_BRANCH"
echo " BASE_REVISION: $NEW_BASE_REVISION"
2019-11-19 05:18:28 +03:00
echo
git checkout -b tmpsquash_export_script $NEW_BASE_REVISION
2019-11-19 05:18:28 +03:00
git merge --squash $CURRENT_BRANCH
HAS_CHANGES="false"
2019-11-22 04:06:57 +03:00
if ! git commit -am "chore: bootstrap"; then
echo "-- no code changes"
else
HAS_CHANGES="true"
PATCH_NAME=$(git format-patch -1 HEAD)
mv $PATCH_NAME $EXPORT_PATH/patches/
2019-11-22 04:06:57 +03:00
fi
2019-11-19 05:18:28 +03:00
git checkout $CURRENT_BRANCH
git branch -D tmpsquash_export_script
if [[ "$NEW_BASE_REVISION" == "$BASE_REVISION" ]]; then
echo "-- no BASE_REVISION changes"
else
HAS_CHANGES="true"
fi
if [[ $HAS_CHANGES == "false" ]]; then
exit 0
fi
2019-11-22 04:06:57 +03:00
echo "REMOTE_URL=\"$REMOTE_URL\"
BASE_BRANCH=\"$BASE_BRANCH\"
BASE_REVISION=\"$NEW_BASE_REVISION\"" > $EXPORT_PATH/UPSTREAM_CONFIG.sh
2019-11-19 05:18:28 +03:00
# Increment BUILD_NUMBER
BUILD_NUMBER=$(cat $EXPORT_PATH/BUILD_NUMBER)
BUILD_NUMBER=$((BUILD_NUMBER+1))
echo $BUILD_NUMBER > $EXPORT_PATH/BUILD_NUMBER