netcdf-c/ncdump/tst_ncgen4_cycle.sh

67 lines
1.9 KiB
Bash
Executable File

#!/bin/sh
. ${srcdir}/tst_ncgen4_shared.sh
if test "${MODE}" = 3 ; then
TESTSET="${TESTS3} ${BIGTESTS3} ${BIGBIG3}"
if test "${KFLAG}" = 4 ; then
TESTSET="${TESTSET} ${SPECIALTESTS3}"
fi
else
TESTSET="${TESTS3} ${TESTS4} ${BIGTESTS} ${SPECIALTESTS}"
fi
echo "*** Cycle testing ncgen with -k${KFLAG}"
cd ${RESULTSDIR}
for x in ${TESTSET} ; do
test $verbose = 1 && echo "*** Testing: ${x}"
# determine if we need the specflag set
specflag=
headflag=
for s in ${SPECIALTESTS} ; do
if test "x${s}" = "x${x}" ; then specflag="-s"; headflag="-h"; fi
done
# determine if this is an xfailtest;if so, then no point in running it
isxfail=0
for t in ${XFAILTESTS} ; do
if test "x${t}" = "x${x}" ; then isxfail=1; fi
done
if test "${isxfail}" = "1"; then
echo "xfail test: ${x}: ignored"
xfailcount=`expr $xfailcount + 1`
else
rm -f ${x}.nc ${x}.dmp
# step 1: use original cdl to build the .nc
${builddir}/../ncgen/ncgen -b -k${KFLAG} -o ${x}.nc ${cdl}/${x}.cdl
# step 2: dump .nc file
${builddir}/../ncdump/ncdump ${headflag} ${specflag} ${x}.nc > ${x}.dmp
# step 3: use ncdump output to (re-)build the .nc
rm -f ${x}.nc
${builddir}/../ncgen/ncgen -b -k${KFLAG} -o ${x}.nc ${x}.dmp
# step 4: dump .nc file again
${builddir}/../ncdump/ncdump ${headflag} ${specflag} ${x}.nc > ${x}.dmp2
# compare the two ncdump outputs
if diff -b -w ${x}.dmp ${x}.dmp2 ; then ok=1; else ok=0; fi
if test "x$ok" = "x1" ; then
test $verbose = 1 && echo "*** SUCCEED: ${x}"
passcount=`expr $passcount + 1`
else
echo "*** FAIL: ${x}"
failcount=`expr $failcount + 1`
fi
fi
done
cd ..
totalcount=`expr $passcount + $failcount + $xfailcount`
okcount=`expr $passcount + $xfailcount`
echo "*** PASSED: ${okcount}/${totalcount} ; ${failcount} unexpected failures; ${xfailcount} expected failures ignored"
if test $failcount -gt 0 ; then
exit 1
else
exit 0
fi