File: test

package info (click to toggle)
mcelog 104-1
  • links: PTS, VCS
  • area: main
  • in suites: jessie, jessie-kfreebsd
  • size: 996 kB
  • ctags: 1,508
  • sloc: ansic: 7,739; sh: 481; makefile: 87
file content (72 lines) | stat: -rwxr-xr-x 1,514 bytes parent folder | download
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
65
66
67
68
69
70
71
72
#!/bin/bash
# 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

#trap killwatchdog 0
#watchdog & 
rm -f *.log
rm -f results
for conf in `ls *.conf`
do
	log=`echo $conf | sed "s/conf/log/g"`
	./inject $conf
	$D ../../mcelog --foreground --daemon --debug-numerrors --config $conf --logfile $log >> result

	# let triggers finish
	sleep 1

	NUMT="$(awk '/# trigger: / { print $3 }' $conf)"
	NUMC="$(grep -c 'Running trigger' $log || true)"

	if [ "$NUMT" != 0 ] ; then
		if [ "$NUMC" = 0 ] ; then
			echo "$conf: no triggers at all" >> results
		fi
	fi

	if [ "$NUMT" != "" ] ; then
		if [ "$NUMC" != "$NUMT" ] ; then
			echo "$conf: triggers did not trigger as expected: $NUMT != $NUMC" >> results
		else
			echo "$conf: triggers trigger as expected" >> results
		fi
	else
		echo "$conf: did not declare number of triggers" >> results
	fi
done
#trap "" 0 
#killwatchdog