| #!/bin/sh |
| |
| top_srcdir=@abs_top_srcdir@ |
| top_builddir=@abs_top_builddir@ |
| |
| wd="${top_srcdir}/samples/data" |
| |
| run_test() { |
| name=$1 |
| shift |
| expect_status=$1 |
| shift |
| input_file=$1 |
| shift |
| cmd=$1 |
| shift |
| |
| export XERCESC_NLS_HOME=${top_builddir}/src |
| |
| builddir=$(pwd) |
| if [ ! -d observed ]; then |
| mkdir -p observed |
| fi |
| output="${builddir}/observed/${name}.log" |
| |
| test_status=fail |
| cd "$wd" |
| if [ -n "$input_file" ]; then |
| echo "Running ${top_builddir}/$cmd $@ < "$input_file" > \"$output\" 2> \"$output\" $input" |
| "${top_builddir}/$cmd" "$@" < "$input_file" > "$output" 2> "$output" $input && test_status=pass |
| else |
| echo "Running ${top_builddir}/$cmd $@ > \"$output\" 2> \"$output\" $input" |
| "${top_builddir}/$cmd" "$@" > "$output" 2> "$output" $input && test_status=pass |
| fi |
| echo "Result: $test_status" |
| if [ "$expect_status" != "$test_status" ]; then |
| echo "$name: Expected $expect_status status but got $test_status status" >&2 |
| if [ "$expect_status" = pass ]; then |
| exit 1 |
| fi |
| exit 0 |
| fi |
| |
| cd "$builddir" |
| # Replace timings in output |
| sed -i -e 's;\( *[0-9][0-9]* *ms *\);{timing removed};' "$output" |
| |
| exp=$(cat "${srcdir}/expected/${name}.log") |
| obs=$(cat "$output") |
| |
| echo "------" |
| echo "obs=$obs" |
| echo "------" |
| echo "exp=$exp" |
| echo "------" |
| # If the observed and expected logs differ, output a diff and fail |
| if [ "$exp" != "$obs" ]; then |
| diff -u "${srcdir}/expected/${name}.log" "$output" |
| echo "Observed output does not match expected output" >&2 |
| if [ "$expect_status" = pass ]; then |
| exit 1 |
| fi |
| exit 0 |
| fi |
| |
| if [ "$expect_status" = pass ]; then |
| exit 0 |
| fi |
| exit 1 |
| } |