Skip to content

Instantly share code, notes, and snippets.

@fsvehla
Created January 5, 2009 15:12
Show Gist options
  • Save fsvehla/43427 to your computer and use it in GitHub Desktop.
Save fsvehla/43427 to your computer and use it in GitHub Desktop.
#!/bin/bash
# Cronic v2 - cron job report wrapper
# Copyright 2007 Chuck Houpt
# Made compatible with default paths under OpenSolaris 2008.5
set -eu
OUT=/tmp/cronic.out.$$
ERR=/tmp/cronic.err.$$
TRACE=/tmp/cronic.trace.$$
set +e
"$@" >$OUT 2>$TRACE
RESULT=$?
set -e
PATTERN="^${PS4:0:1}\\+${PS4:1}"
if /usr/gnu/bin/grep -aq "$PATTERN" $TRACE
then
! /usr/grnu/bin/grep -av "$PATTERN" $TRACE > $ERR
else
ERR=$TRACE
fi
if [ $RESULT -ne 0 -o -s "$ERR" ]
then
echo "Cronic detected failure or error output for the command:"
echo "$@"
echo
echo "RESULT CODE: $RESULT"
echo
echo "ERROR OUTPUT:"
cat "$ERR"
echo
echo "STANDARD OUTPUT:"
cat "$OUT"
if [ $TRACE != $ERR ]
then
echo
echo "TRACE-ERROR OUTPUT:"
cat "$TRACE"
fi
fi
rm -f "$OUT"
rm -f "$ERR"
rm -f "$TRACE"
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment