6 default_cmd
="sparse \$file"
7 tests_list
=`find . -name '*.c' | sed -e 's#^\./\(.*\)#\1#' | sort`
8 prog_name
=`basename $0`
11 # - tests that have not been converted to test-suite format
14 # - tests that failed but are known to fail
20 # defaults to not verbose
24 # get_value(key, file) - gets the value of a (key, value) pair in file.
26 # returns 0 on success, 1 if the file does not have the key
29 last_result
=`grep $1: $2 | sed -e "s/^.*$1:\(.*\)$/\1/"`
30 [ -z "$last_result" ] && return 1
35 # get_tag(key, file) - does file has the tag key in it ?
37 # returns 0 if present, 1 otherwise
40 last_result
=`grep $1 $2`
45 # verbose(string) - prints string if we are in verbose mode
48 [ "$V" -eq "1" ] && echo " $1"
53 # error(string[, die]) - prints an error and exits with value die if given
57 [ -n "$2" ] && exit $2
63 echo "$prog_name - a tiny automatic testing script"
64 echo "Usage: $prog_name [command] [command arguments]"
67 echo " none runs the whole test suite"
68 echo " single file runs the test in 'file'"
69 echo " format file [name [cmd]] helps writing a new test case using cmd"
71 echo " help prints usage"
75 # do_test(file) - tries to validate a test case
77 # it "parses" file, looking for check-* tags and tries to validate
78 # the test against an expected result
80 # - 0 if the test passed,
82 # - 2 if it is not a "test-suite" test.
88 # can this test be handled by test-suite ?
89 # (it has to have a check-name key in it)
90 get_value
"check-name" $file
91 if [ "$?" -eq 1 ]; then
92 echo "warning: test '$file' unhandled"
93 unhandled_tests
=`expr $unhandled_tests + 1`
96 test_name
=$last_result
98 echo " TEST $test_name ($file)"
100 # does the test provide a specific command ?
101 cmd
=`eval echo $default_path/$default_cmd`
102 get_value
"check-command" $file
103 if [ "$?" -eq "0" ]; then
104 last_result
=`echo $last_result | sed -e 's/^ *//'`
105 cmd
=`eval echo $default_path/$last_result`
107 verbose
"Using command : $cmd"
109 # grab the expected output
110 sed -n '/check-output-start/,/check-output-end/p' $file \
111 |
grep -v check-output
> "$file".output.expected
112 sed -n '/check-error-start/,/check-error-end/p' $file \
113 |
grep -v check-error
> "$file".error.expected
115 # grab the expected exit value
116 get_value
"check-exit-value" $file
117 if [ "$?" -eq "0" ]; then
118 expected_exit_value
=`echo $last_result | tr -d ' '`
120 grep -q -E "^[^:]+:[[:digit:]]+:[[:digit:]]+: error:" "$file".error.expected
121 if [ "$?" -eq "0" ]; then
122 expected_exit_value
=1
124 expected_exit_value
=0
127 verbose
"Expecting exit value: $expected_exit_value"
130 # grab the actual output & exit value
131 $cmd 1> $file.output.got
2> $file.error.got
134 for stream
in output error
; do
135 diff -u "$file".
$stream.expected
"$file".
$stream.got
> "$file".
$stream.
diff
136 if [ "$?" -ne "0" ]; then
137 error
"actual $stream text does not match expected $stream text."
138 error
"see $file.$stream.* for further investigation."
139 cat "$file".
$stream.
diff
144 if [ "$actual_exit_value" -ne "$expected_exit_value" ]; then
145 error
"Actual exit value does not match the expected one."
146 error
"expected $expected_exit_value, got $actual_exit_value."
150 if [ "$test_failed" -eq "1" ]; then
151 ko_tests
=`expr $ko_tests + 1`
152 get_tag
"check-known-to-fail" $file
153 if [ "$?" -eq "0" ]; then
154 echo "info: test '$file' is known to fail"
155 known_ko_tests
=`expr $known_ko_tests + 1`
159 ok_tests
=`expr $ok_tests + 1`
166 for i
in $tests_list; do
170 # prints some numbers
171 tests_nr
=`expr $ok_tests + $ko_tests`
172 echo -n "Out of $tests_nr tests, $ok_tests passed, $ko_tests failed"
173 echo " ($known_ko_tests of them are known to fail)"
174 if [ "$unhandled_tests" -ne "0" ]; then
175 echo "$unhandled_tests tests could not be handled by $prog_name"
180 # do_format(file[, name[, cmd]]) - helps a test writer to format test-suite tags
186 elif [ -z "$3" ]; then
194 cmd
=`eval echo $default_path/$fcmd`
195 $cmd 1> $file.output.got
2> $file.error.got
201 if [ "$fcmd" != "$default_cmd" ]; then
202 echo " * check-command: $fcmd"
204 if [ "$fexit_value" -ne "0" ]; then
205 echo " * check-exit-value: $fexit_value"
207 for stream
in output error
; do
208 if [ -s "$file.$stream.got" ]; then
210 echo " * check-$stream-start"
211 cat "$file.$stream.got"
212 echo " * check-$stream-end"
220 # arg_file(filename) - checks if filename exists
228 error
"Can't open file $1"
242 0) echo "$2 passed !";;
243 1) echo "$2 failed !";;
244 2) echo "$2 can't be handled by $prog_name";;
249 do_format
"$2" "$3" "$4"