2010-06-03 21:24:43 +08:00
|
|
|
#!/bin/sh
|
2017-03-09 08:01:10 +08:00
|
|
|
|
|
|
|
if test "x$srcdir" = x ; then srcdir=`pwd`; fi
|
|
|
|
. ../test_common.sh
|
2010-06-03 21:24:43 +08:00
|
|
|
|
2014-09-19 08:26:06 +08:00
|
|
|
. ${srcdir}/tst_ncgen_shared.sh
|
2010-06-03 21:24:43 +08:00
|
|
|
|
|
|
|
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}"
|
|
|
|
|
2017-11-17 23:22:49 +08:00
|
|
|
mkdir ${RESULTSDIR}
|
2010-06-03 21:24:43 +08:00
|
|
|
cd ${RESULTSDIR}
|
|
|
|
for x in ${TESTSET} ; do
|
2013-01-04 04:45:34 +08:00
|
|
|
test "x$verbose" = x1 && echo "*** Testing: ${x}"
|
2010-08-10 04:39:36 +08:00
|
|
|
# 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
|
2021-09-13 08:03:57 +08:00
|
|
|
isnocycle=0
|
|
|
|
for t in ${NOCYCLE} ; do
|
|
|
|
if test "x${t}" = "x${x}" ; then isnocycle=1; fi
|
|
|
|
done
|
2010-08-10 04:39:36 +08:00
|
|
|
if test "${isxfail}" = "1"; then
|
|
|
|
echo "xfail test: ${x}: ignored"
|
|
|
|
xfailcount=`expr $xfailcount + 1`
|
2021-09-13 08:03:57 +08:00
|
|
|
elif test "${isnocycle}" = "1"; then
|
|
|
|
echo "test: ${x}: ignored for cycle test"
|
2010-06-03 21:24:43 +08:00
|
|
|
else
|
2017-11-25 22:28:07 +08:00
|
|
|
rm -f ${x}_$$.nc ${x}_$$.dmp
|
2010-08-10 04:39:36 +08:00
|
|
|
# step 1: use original cdl to build the .nc
|
2017-11-25 22:28:07 +08:00
|
|
|
${NCGEN} -b -k${KFLAG} -o ${x}_$$.nc ${cdl}/${x}.cdl
|
2010-08-10 04:39:36 +08:00
|
|
|
# step 2: dump .nc file
|
2017-11-25 22:28:07 +08:00
|
|
|
${NCDUMP} ${headflag} ${specflag} -n ${x} ${x}_$$.nc > ${x}_$$.dmp
|
2013-01-04 04:45:34 +08:00
|
|
|
# step 3: use ncgen and the ncdump output to (re-)build the .nc
|
2017-11-25 22:28:07 +08:00
|
|
|
rm -f ${x}_$$.nc
|
|
|
|
${NCGEN} -b -k${KFLAG} -o ${x}_$$.nc ${x}_$$.dmp
|
2010-08-10 04:39:36 +08:00
|
|
|
# step 4: dump .nc file again
|
2017-11-25 22:28:07 +08:00
|
|
|
${NCDUMP} ${headflag} ${specflag} -n ${x} ${x}_$$.nc > ${x}_$$.dmp2
|
2010-08-10 04:39:36 +08:00
|
|
|
# compare the two ncdump outputs
|
2017-11-25 22:28:07 +08:00
|
|
|
if diff -b -w ${x}_$$.dmp ${x}_$$.dmp2 ; then ok=1; else ok=0; fi
|
|
|
|
rm -f ${x}_$$.nc ${x}_$$.dmp
|
2010-08-10 04:39:36 +08:00
|
|
|
if test "x$ok" = "x1" ; then
|
2013-01-04 04:45:34 +08:00
|
|
|
test "x$verbose" = x1 && echo "*** SUCCEED: ${x}"
|
2010-08-10 04:39:36 +08:00
|
|
|
passcount=`expr $passcount + 1`
|
|
|
|
else
|
|
|
|
echo "*** FAIL: ${x}"
|
|
|
|
failcount=`expr $failcount + 1`
|
|
|
|
fi
|
2010-06-03 21:24:43 +08:00
|
|
|
fi
|
|
|
|
done
|
|
|
|
cd ..
|
|
|
|
|
|
|
|
totalcount=`expr $passcount + $failcount + $xfailcount`
|
|
|
|
okcount=`expr $passcount + $xfailcount`
|
|
|
|
|
2010-08-10 04:39:36 +08:00
|
|
|
echo "*** PASSED: ${okcount}/${totalcount} ; ${failcount} unexpected failures; ${xfailcount} expected failures ignored"
|
2017-11-17 23:22:49 +08:00
|
|
|
rm -rf ${RESULTSDIR}
|
2010-06-03 21:24:43 +08:00
|
|
|
|
|
|
|
if test $failcount -gt 0 ; then
|
|
|
|
exit 1
|
|
|
|
else
|
|
|
|
exit 0
|
|
|
|
fi
|