2010-06-03 21:24:43 +08:00
|
|
|
#!/bin/sh
|
|
|
|
|
2013-02-26 12:31:06 +08:00
|
|
|
set -x
|
2010-06-03 21:24:43 +08:00
|
|
|
quiet=0
|
|
|
|
leakcheck=0
|
|
|
|
|
2012-01-30 02:56:29 +08:00
|
|
|
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"
|
2012-01-30 02:56:29 +08:00
|
|
|
PARAMS="${PARAMS}[cache]"
|
2010-06-03 21:24:43 +08:00
|
|
|
;;
|
|
|
|
*4)
|
|
|
|
EXPECTED="$expected4"
|
|
|
|
TITLE="DAP to netCDF-4 translation"
|
2012-01-30 02:56:29 +08:00
|
|
|
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}"
|
|
|
|
|
|
|
|
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
|
|
|
rm -f ./.dodsrc
|
|
|
|
echo '#DODSRC' >./.dodsrc
|
|
|
|
|
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
|
|
|
|
|
2010-06-03 21:24:43 +08:00
|
|
|
cd ..
|
|
|
|
|
|
|
|
totalcount=`expr $passcount + $failcount + $xfailcount`
|
|
|
|
okcount=`expr $passcount + $xfailcount`
|
|
|
|
|
|
|
|
echo "*** PASSED: ${okcount}/${totalcount} ; ${xfailcount} expected failures ; ${failcount} unexpected failures"
|
|
|
|
|
|
|
|
#failcount=0
|
|
|
|
if test "$failcount" -gt 0
|
|
|
|
then
|
|
|
|
exit 1
|
|
|
|
else
|
|
|
|
exit 0
|
|
|
|
fi
|