mirror of https://github.com/efabless/caravel.git
60 lines
1.8 KiB
Bash
60 lines
1.8 KiB
Bash
|
#!/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
|