Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
49 changes: 32 additions & 17 deletions ci3/denoise
Original file line number Diff line number Diff line change
Expand Up @@ -8,9 +8,11 @@ if [ "$#" != 1 ]; then
exit 1
fi

cmd=$1

if [[ "${DENOISE:-0}" -eq 0 ]] || [[ "${BUILD_SYSTEM_DEBUG:-0}" -eq 1 ]]; then
set -e
bash -c "$1"
bash -c "$cmd"
exit 0
fi

Expand All @@ -25,15 +27,39 @@ export FORCE_COLOR=${FORCE_COLOR:-1}
[ -t 1 ] && realtime=1 || realtime=0

key=$(uuid)
url=http://ci.aztec-labs.com/$key
outfile=/tmp/$key
trap 'rm -f $outfile' EXIT
touch $outfile

function publish_log {
if [ "$CI_REDIS_AVAILABLE" -eq 0 ]; then
return
fi

{
echo -e "Command: $cmd (exit: $status)\n"
cat $outfile
} | redis_setexz $key $CI_REDIS_EXPIRE
}

function live_publish_log {
while [ -f $outfile ]; do
publish_log
sleep 5
done
}

if [ "$CI_REDIS_AVAILABLE" -eq 1 ]; then
live_publish_log &
log_info="(${yellow}${url}${reset})"
fi

# Execute the command and process the output, allow for errors.
set +e
echo -e "Executing: $1 (${yellow}ci llog $key${reset})"
echo -e "Executing: $cmd ${log_info:-}"
echo -n " 0 "
bash -c "$1" 2>&1 | while IFS= read -r line; do
bash -c "$cmd" 2>&1 | while IFS= read -r line; do
((dot_count++))
[ $realtime -eq 1 ] && printf "."
if [[ "$dots_per_line" -gt 0 && $((dot_count % dots_per_line)) -eq 0 ]]; then
Expand All @@ -45,26 +71,15 @@ done;
# Get the exit status of the command
status=${PIPESTATUS[0]}

if [ "$CI_REDIS_AVAILABLE" -eq 1 ]; then
{
echo "Command: $1 (exit: $status)"
cat $outfile
} | redis_setexz $key $CI_REDIS_EXPIRE
fi
publish_log

# Handle non-zero exit status
if [ "$status" -ne 0 ]; then
echo -e "\nCommand exited with status $status. Dumping output:"
cat $outfile
echo -e -n ". ${red}failed${reset} (${SECONDS}s)"
echo -e ". ${red}failed${reset} (${SECONDS}s) ${log_info:-}"
else
echo -e -n ". ${green}done${reset} (${SECONDS}s)"
fi

if [ "$CI_REDIS_AVAILABLE" -eq 1 ]; then
url=http://ci.aztec-labs.com/$key
echo -e -n " (${yellow}${url}${reset})"
echo -e ". ${green}done${reset} (${SECONDS}s)"
fi
echo

exit $status
4 changes: 1 addition & 3 deletions ci3/parallelise
Original file line number Diff line number Diff line change
Expand Up @@ -22,9 +22,7 @@ if [ -t 1 ]; then
fi
set -e
else
# TODO: Reinstate once better live logging.
# denoise "parallel $parallel_args 'run_test_cmd {}'"
parallel $parallel_args 'run_test_cmd {}'
denoise "parallel $parallel_args 'run_test_cmd {}'"
fi

slow_jobs=$(cat joblog.txt | \
Expand Down
2 changes: 1 addition & 1 deletion ci3/source_redis
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@
# Declare CI_REDIS host, allowing override.
export CI_REDIS=${CI_REDIS:-localhost}

# If we haven't yet checked for redis availablility.
# If we haven't yet checked for redis availability.
if [ -z "${CI_REDIS_AVAILABLE:-}" ]; then
# Start by setting it as not available.
export CI_REDIS_AVAILABLE=0
Expand Down
Loading