blob: d2e9f73c196625ba51bb9668ab57be30c301e0d8 (
plain)
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
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
|
#!/bin/bash
TESTS="$@"
RET=0
TIMEOUT=30
FAILED=""
MAYBE_FAILED=""
do_kmsg="1"
if ! [ $(id -u) = 0 ]; then
do_kmsg="0"
fi
TEST_DIR=$(dirname $0)
TEST_FILES=""
if [ -f "$TEST_DIR/config.local" ]; then
. $TEST_DIR/config.local
for dev in $TEST_FILES; do
if [ ! -e "$dev" ]; then
echo "Test file $dev not valid"
exit 1
fi
done
fi
_check_dmesg()
{
local dmesg_marker="$1"
local seqres="$2.seqres"
if [[ $do_kmsg -eq 0 ]]; then
return 0
fi
dmesg | bash -c "$DMESG_FILTER" | grep -A 9999 "$dmesg_marker" >"${seqres}.dmesg"
grep -q -e "kernel BUG at" \
-e "WARNING:" \
-e "BUG:" \
-e "Oops:" \
-e "possible recursive locking detected" \
-e "Internal error" \
-e "INFO: suspicious RCU usage" \
-e "INFO: possible circular locking dependency detected" \
-e "general protection fault:" \
-e "blktests failure" \
"${seqres}.dmesg"
# shellcheck disable=SC2181
if [[ $? -eq 0 ]]; then
return 1
else
rm -f "${seqres}.dmesg"
return 0
fi
}
run_test()
{
T="$1"
D="$2"
DMESG_FILTER="cat"
if [ "$do_kmsg" -eq 1 ]; then
if [ -z "$D" ]; then
local dmesg_marker="Running test $T:"
else
local dmesg_marker="Running test $T $D:"
fi
echo $dmesg_marker | tee /dev/kmsg
else
local dmesg_marker=""
echo Running test $T $D
fi
timeout --preserve-status -s INT $TIMEOUT ./$T $D
r=$?
if [ "${r}" -eq 124 ]; then
echo "Test $T timed out (may not be a failure)"
elif [ "${r}" -ne 0 ]; then
echo "Test $T failed with ret ${r}"
if [ -z "$D" ]; then
FAILED="$FAILED <$T>"
else
FAILED="$FAILED <$T $D>"
fi
RET=1
elif ! _check_dmesg "$dmesg_marker" "$T"; then
echo "Test $T failed dmesg check"
if [ -z "$D" ]; then
FAILED="$FAILED <$T>"
else
FAILED="$FAILED <$T $D>"
fi
RET=1
elif [ ! -z "$D" ]; then
sleep .1
ps aux | grep "\[io_wq_manager\]" > /dev/null
R="$?"
if [ "$R" -eq 0 ]; then
MAYBE_FAILED="$MAYBE_FAILED $T"
fi
fi
}
for t in $TESTS; do
run_test $t
if [ ! -z "$TEST_FILES" ]; then
for dev in $TEST_FILES; do
run_test $t $dev
done
fi
done
if [ "${RET}" -ne 0 ]; then
echo "Tests $FAILED failed"
exit $RET
else
sleep 1
ps aux | grep "\[io_wq_manager\]" > /dev/null
R="$?"
if [ "$R" -ne 0 ]; then
MAYBE_FAILED=""
fi
if [ ! -z "$MAYBE_FAILED" ]; then
echo "Tests _maybe_ failed: $MAYBE_FAILED"
fi
echo "All tests passed"
exit 0
fi
|