netcdf-c/ncdap_test/tst_ncdap.sh

135 lines
2.5 KiB
Bash
Raw Normal View History

2010-06-03 21:24:43 +08:00
#!/bin/sh
quiet=0
leakcheck=0
PARAMS="[log]"
#PARAMS="${PARAMS}[fetch=memory]"
#PARAMS="${PARAMS}[show=fetch]"
2010-06-03 21:24:43 +08:00
OCLOGFILE=/dev/null
# Capture arguments
srcdir="$1"
builddir="$2"
mode="$3"
# Locate the testdata and expected directory
testdata3="${srcdir}/testdata3"
expected3="${srcdir}/expected3"
expected4="${srcdir}/expected4"
# get the list of test files
. ${srcdir}/tst_ncdap_shared.sh
2013-02-26 12:31:06 +08:00
FLAGS=
2010-06-03 21:24:43 +08:00
case "$mode" in
*3)
EXPECTED="$expected3"
TITLE="DAP to netCDF-3 translation"
PARAMS="${PARAMS}[cache]"
2010-06-03 21:24:43 +08:00
;;
*4)
EXPECTED="$expected4"
TITLE="DAP to netCDF-4 translation"
PARAMS="${PARAMS}[netcdf4][cache]"
2010-06-03 21:24:43 +08:00
;;
esac
case "$mode" in
file*)
TESTURL="$FILEURL"
TESTSET="$FILETESTS"
;;
2013-02-26 12:31:06 +08:00
dds*)
TESTURL="[noprefetch]$FILEURL"
TESTSET="$DDSTESTS"
FLAGS="-h"
;;
2010-06-03 21:24:43 +08:00
remote*)
TESTURL="$REMOTEURL"
TITLE="Remote $TITLE"
TESTSET="$REMOTETESTS"
;;
esac
RESULTSDIR="./results"
# Locate some tools
2013-02-26 12:31:06 +08:00
NCDUMP="${builddir}/ncdump/ncdump $FLAGS"
2010-06-03 21:24:43 +08:00
if test "x$leakcheck" = "x1" ; then
VALGRIND="valgrind -q --error-exitcode=2 --leak-check=full"
else
VALGRIND=
fi
rm -fr ${RESULTSDIR}
mkdir "${RESULTSDIR}"
rm -f ./.dodsrc ./.ocrc ./.daprc
2010-06-03 21:24:43 +08:00
passcount=0
xfailcount=0
failcount=0
echo "*** Testing $TITLE "
echo " Base URL: ${TESTURL}"
echo " Client Parameters: ${PARAMS}"
cd ${RESULTSDIR}
2010-07-20 02:06:09 +08:00
2010-06-03 21:24:43 +08:00
for x in ${TESTSET} ; do
url="${PARAMS}${TESTURL}/$x"
2012-07-18 04:13:17 +08:00
if test "x$quiet" = "x0" ; then echo "*** Testing: ${x} ; url=$url" ; fi
2010-06-03 21:24:43 +08:00
# determine if this is an xfailtest
isxfail=0
for t in ${XFAILTESTS} ; do
if test "x${t}" = "x${x}" ; then isxfail=1; fi
done
ok=1
if ${VALGRIND} ${NCDUMP} "${url}" > ${x}.dmp ; then ok=$ok; else ok=0; fi
# compare with expected
if diff -w ${EXPECTED}/${x}.dmp ${x}.dmp ; then ok=$ok; else ok=0; fi
if test "$ok" = 1 ; then
status=0 # succeed
elif test "x$isxfail" = "x0" ; then
status=1 # fail
else
status=2 # xfail
fi
case "$status" in
0)
passcount=`expr $passcount + 1`
if test "x$quiet" = "x" ; then echo "*** SUCCEED: ${x}"; fi
;;
1)
failcount=`expr $failcount + 1`
echo "*** FAIL: ${x}"
;;
2)
xfailcount=`expr $xfailcount + 1`
2012-07-18 04:13:17 +08:00
echo "*** XFAIL : ${x}"
2010-06-03 21:24:43 +08:00
;;
esac
done
2010-07-20 02:06:09 +08:00
rm -f ./.dodsrc ./.ocrc ./.daprc
2010-07-20 02:06:09 +08:00
2010-06-03 21:24:43 +08:00
cd ..
echo "pwd=" `pwd`
2010-06-03 21:24:43 +08:00
totalcount=`expr $passcount + $failcount + $xfailcount`
okcount=`expr $passcount + $xfailcount`
2010-06-03 21:24:43 +08:00
echo "*** PASSED: ${okcount}/${totalcount} ; ${xfailcount} expected failures ; ${failcount} unexpected failures"
#failcount=0
if test "$failcount" -gt 0
then
exit 1
else
exit 0
fi