From: Simon Brandhof Date: Tue, 17 Jul 2012 20:11:29 +0000 (+0200) Subject: Add unbreakable build script for mac X-Git-Tag: 3.2~29 X-Git-Url: https://source.dussan.org/?a=commitdiff_plain;h=597590251a7b5cd90ca862031b714237233065dc;p=sonarqube.git Add unbreakable build script for mac --- diff --git a/push.sh b/push.sh new file mode 100755 index 00000000000..8268fa99eac --- /dev/null +++ b/push.sh @@ -0,0 +1,55 @@ +#!/bin/bash +# Unbreakable build + +function alert_user { +echo "${1}" +which -s growlnotify && growlnotify `basename $0` -m "${1}" +} + +function exit_ko { +alert_user "${1}"; exit 1 +} + +function exit_ok { +alert_user "${1}"; exit 0 +} + +LOCATION=$(pwd) +REMOTE=${1:-origin} +REMOTE_URL=$(git remote show -n ${REMOTE} | awk '/Fetch/ {print $3}') +BRANCH=$(git symbolic-ref -q HEAD) +BRANCH=${BRANCH##refs/heads/} + +# Git black magic to pull rebase even with uncommited work in progress +git fetch ${REMOTE} +git add -A; git ls-files --deleted -z | xargs -0 -I {} git rm {}; git commit -m "wip" +git rebase ${REMOTE}/${BRANCH} + +if [ "$?" -ne 0 ]; then +git rebase --abort +git log -n 1 | grep -q -c "wip" && git reset HEAD~1 +exit_ko "Unable to rebase. please pull or rebase and fix conflicts manually." +fi +git log -n 1 | grep -q -c "wip" && git reset HEAD~1 + +# Private build +rm -Rf ../privatebuild +git clone --single-branch -slb "${BRANCH}" . ../privatebuild +cd ../privatebuild + +# Build with maven +set MAVEN_OPTS=-Xmx1G +mvn -T4 install -Pdev -DskipSanityChecks=false +if [ $? -ne 0 ]; then +exit_ko "Unable to build" +fi + +# Push +git push ${REMOTE_URL} ${BRANCH} +if [ $? -ne 0 ]; then +exit_ko "Unable to push" +fi + +# Update working directory +cd ${LOCATION} && git fetch ${REMOTE} +exit_ok "Yet another successful build!" \ No newline at end of file