| #!/bin/bash -e |
| |
| # Stolen from http://git.openstack.org/cgit/openstack-infra/config/plain/modules/jenkins/files/slave_scripts/gerrit-git-prep.sh |
| |
| GERRIT_SITE=$1 |
| GIT_ORIGIN=$2 |
| |
| if [ -z "$GERRIT_SITE" ] |
| then |
| echo "The gerrit site name (eg 'https://review.openstack.org') must be the first argument." |
| exit 1 |
| fi |
| |
| if [ -z "$ZUUL_URL" ] |
| then |
| echo "The ZUUL_URL must be provided." |
| exit 1 |
| fi |
| |
| if [ -z "$GIT_ORIGIN" ] || [ -n "$ZUUL_NEWREV" ] |
| then |
| GIT_ORIGIN="$GERRIT_SITE/p" |
| # git://git.openstack.org/ |
| # https://review.openstack.org/p |
| fi |
| |
| if [ -z "$ZUUL_REF" ] |
| then |
| if [ -n "$BRANCH" ] |
| then |
| echo "No ZUUL_REF so using requested branch $BRANCH from origin." |
| ZUUL_REF=$BRANCH |
| # use the origin since zuul mergers have outdated branches |
| ZUUL_URL=$GIT_ORIGIN |
| else |
| echo "Provide either ZUUL_REF or BRANCH in the calling enviromnent." |
| exit 1 |
| fi |
| fi |
| |
| if [ ! -z "$ZUUL_CHANGE" ] |
| then |
| echo "Triggered by: $GERRIT_SITE/$ZUUL_CHANGE" |
| fi |
| |
| set -x |
| if [[ ! -e .git ]] |
| then |
| ls -a |
| rm -fr .[^.]* * |
| if [ -d /opt/git/$ZUUL_PROJECT/.git ] |
| then |
| git clone -vvvvvv file:///opt/git/$ZUUL_PROJECT . |
| else |
| git clone -vvvvvv $GIT_ORIGIN/$ZUUL_PROJECT . |
| fi |
| fi |
| git remote -vvvvvv set-url origin $GIT_ORIGIN/$ZUUL_PROJECT |
| |
| # attempt to work around bugs 925790 and 1229352 |
| if ! git remote -vvvvvv update |
| then |
| echo "The remote update failed, so garbage collecting before trying again." |
| git gc |
| git remote -vvvvvv update |
| fi |
| |
| git reset --hard |
| if ! git clean -x -f -d -q ; then |
| sleep 1 |
| git clean -x -f -d -q |
| fi |
| |
| if echo "$ZUUL_REF" | grep -q ^refs/tags/ |
| then |
| git fetch -vvvvvv --tags $ZUUL_URL/$ZUUL_PROJECT |
| git checkout $ZUUL_REF |
| git reset --hard $ZUUL_REF |
| elif [ -z "$ZUUL_NEWREV" ] |
| then |
| git fetch -vvvvvv $ZUUL_URL/$ZUUL_PROJECT $ZUUL_REF |
| git checkout FETCH_HEAD |
| git reset --hard FETCH_HEAD |
| else |
| git checkout $ZUUL_NEWREV |
| git reset --hard $ZUUL_NEWREV |
| fi |
| |
| if ! git clean -x -f -d -q ; then |
| sleep 1 |
| git clean -x -f -d -q |
| fi |
| |
| if [ -f .gitmodules ] |
| then |
| git submodule init |
| git submodule sync |
| git submodule update --init |
| fi |
| |
| # Added for turbo-hipster |
| git branch -D working || true |
| git checkout -b working |