diff options
author | Simon Brandhof <simon.brandhof@gmail.com> | 2012-07-17 22:11:29 +0200 |
---|---|---|
committer | Simon Brandhof <simon.brandhof@gmail.com> | 2012-07-17 22:12:02 +0200 |
commit | 597590251a7b5cd90ca862031b714237233065dc (patch) | |
tree | 20eb41bb516ec68a84e9f5b15719edbac4f17957 /push.sh | |
parent | cd34d391476d4d4276289032e36934333f53a88c (diff) | |
download | sonarqube-597590251a7b5cd90ca862031b714237233065dc.tar.gz sonarqube-597590251a7b5cd90ca862031b714237233065dc.zip |
Add unbreakable build script for mac
Diffstat (limited to 'push.sh')
-rwxr-xr-x | push.sh | 55 |
1 files changed, 55 insertions, 0 deletions
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 |