#!/bin/bash # SPDX-FileCopyrightText: 2020 Efabless Corporation # # Licensed under the Apache License, Version 2.0 (the "License"); # you may not use this file except in compliance with the License. # You may obtain a copy of the License at # # http://www.apache.org/licenses/LICENSE-2.0 # # Unless required by applicable law or agreed to in writing, software # distributed under the License is distributed on an "AS IS" BASIS, # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. # See the License for the specific language governing permissions and # limitations under the License. # SPDX-License-Identifier: Apache-2.0 # Adopted from Chris Snow # https://stackoverflow.com/questions/26082444/how-to-work-around-travis-cis-4mb-output-limit/26082445#26082445 # Abort on Error set -e # Test script is provided as a relative path export WORKDIR=$(pwd) export COMMAND=$1 export TAILING_LINES=${2:-500} export PING_SLEEP=30s export BUILD_OUTPUT=$WORKDIR/build.out touch $BUILD_OUTPUT dump_output() { echo Tailing the last $TAILING_LINES lines of output: tail -$TAILING_LINES $BUILD_OUTPUT rm -f $BUILD_OUTPUT } error_handler() { echo ERROR: An error was encountered with the build. dump_output kill $PING_LOOP_PID 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 echo \$(date) - running $COMMAND ...; sleep $PING_SLEEP; done" & export PING_LOOP_PID=$! # your_build_command_1 >> $BUILD_OUTPUT 2>&1 # your_build_command_2 >> $BUILD_OUTPUT 2>&1 $COMMAND >> $BUILD_OUTPUT 2>&1 # 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