blob: ba7e2f7eff4e7da35c665367f55ed6b0765c8b11 [file] [log] [blame]
#!/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
}