| #!/bin/bash |
| # Abort on Error |
| set -e |
| |
| export PING_SLEEP=30s |
| export WORKDIR="$( cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd )" |
| export BUILD_OUTPUT=$WORKDIR/build.out |
| |
| touch $BUILD_OUTPUT |
| |
| dump_output() { |
| echo Tailing the last 500 lines of output: |
| tail -500 $BUILD_OUTPUT |
| } |
| error_handler() { |
| echo ERROR: An error was encountered with the build. |
| dump_output |
| exit 1 |
| } |
| # If an error occurs, run our error handler to output a tail of the build |
| trap 'error_handler' ERR |
| |
| # Set up a repeating loop to send some output to Travis. |
| |
| bash -c "while true; do tail -5 $BUILD_OUTPUT; sleep $PING_SLEEP; done" & |
| PING_LOOP_PID=$! |
| |
| mvn -version |
| |
| if [ "$1" = "glassfish-copyright:check" ]; then |
| mvn -e $1 -Dcopyright.quiet=false |
| else |
| mvn -e -U -B clean install $1 >> $BUILD_OUTPUT 2>&1 |
| fi |
| |
| # The build finished without returning an error so dump a tail of the output |
| dump_output |
| |
| # nicely terminate the ping output loop |
| kill $PING_LOOP_PID |