X-Git-Url: https://git.dlugolecki.net.pl/?a=blobdiff_plain;f=t%2Fsrc%2Ftest_gom;fp=t%2Fsrc%2Ftest_gom;h=108f4981f2f7421b4a335c5b317cd4d4b69039fd;hb=cf73759d92858885e4e71f6fc85f6d4478593958;hp=0dbcd62a47c7d3d82a2d362855f7981c5f530640;hpb=4feb8b50ee137bbd9512b17c9f7ef9ebbf559be2;p=gedcom-parse.git diff --git a/t/src/test_gom b/t/src/test_gom index 0dbcd62..108f498 100755 --- a/t/src/test_gom +++ b/t/src/test_gom @@ -17,7 +17,12 @@ do done file=$1 -expected_result=$2 +test_name=$2 +expected_result=$3 +if [ -z "$test_name" ] +then + test_name=check +fi if [ -z "$expected_result" ] then expected_result=0 @@ -34,6 +39,11 @@ else options="$options $extra_options" fi +outfile=$test_name.out +logfile=check.out +reffile=$srcdir/output/$test_name.ref +options="$options -o $outfile" + builddir=`pwd` ltcmd="$builddir/../libtool --mode=execute -dlopen $builddir/../gedcom/libgedcom.la -dlopen $builddir/../gom/libgedcom_gom.la" GCONV_PATH=.:$GCONV_PATH @@ -42,6 +52,8 @@ ln -s $srcdir/../data/gedcom.enc . ln -s $builddir/../iconv/glibc/.libs/ANSI_Z39.47.so . ln -s $srcdir/../iconv/glibc/gconv-modules . rm -f core +echo "======================================================">> $logfile +echo "Performing test '$test_name'" >> $logfile if [ "$GOM_DMALLOC_TEST" = "" ] then $ltcmd $GEDCOM_TESTENV $builddir/src/gomtest $options $testfile @@ -55,9 +67,25 @@ result=$? rm gedcom.enc rm ANSI_Z39.47.so rm gconv-modules -if [ "$result" -eq "$expected_result" -a ! -r core ] + +echo "Result is $result (expected: $expected_result)" >> $logfile +if [ "$result" -ne "$expected_result" ] then - exit 0 -else exit 1 +else + if [ -r core ] + then + echo "Core file generated!" >> $logfile + exit 1 + else + if diff $outfile $reffile >/dev/null 2>>$logfile + then + echo "Output agrees with reference output" >> $logfile + rm $outfile + exit 0 + else + echo "Differences with reference output detected!" >> $logfile + exit 1 + fi + fi fi