1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64
|
#!/bin/sh
# simple test harness for mcelog daemon trigger test cases
# ./test subdir [debugger]
# run mcelog test in specific sub directory
# requires root rights and a built mce-inject in ../../mce-inject or $PATH
# warning: this kills any other running mcelogs
D=${2:-}
if [ "$1" = "" ] ; then
echo "usage $0 testdir"
exit 1
fi
if [ "$(whoami)" != "root" ] ; then
echo "Must run as root"
exit 1
fi
echo "++++++++++++ running $1 test +++++++++++++++++++"
# disable trigger
echo -n "" > /sys/devices/system/machinecheck/machinecheck0/trigger
killall mcelog || true
#killwatchdog() {
# kill %1 || true
#}
#
#watchdog() {
# sleep 10
# echo timeout waiting for mcelog
# killall mcelog
#}
cd $1
./inject
#trap killwatchdog 0
#watchdog &
rm -f log
$D ../../mcelog --foreground --daemon --config $1.conf --logfile log
# let triggers finish
sleep 1
NUMT="$(awk '/# trigger: / { print $3 }' $1.conf)"
NUMC="$(grep -c 'Running trigger' log || true)"
if [ "$NUMC" = 0 ] ; then
echo "$1: no triggers at all"
exit 1
fi
if [ "$NUMT" != "" ] ; then
if [ "$NUMC" != "$NUMT" ] ; then
echo "$1: triggers did not trigger as expected: $NUMT != $NUMC"
exit 1
fi
else
echo "$1: did not declare number of triggers"
fi
#trap "" 0
#killwatchdog
|