You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
100 lines
2.2 KiB
100 lines
2.2 KiB
2 years ago
|
#!/bin/sh
|
||
|
# Tests for ncgen4 using list of test cdl files from the cdl4
|
||
|
# directory, and comparing output to expected results in the expected4
|
||
|
# directory. Note that these tests are run for classic files in
|
||
|
# tst_ncgen4_classic.sh
|
||
|
# Dennis Heimbigner
|
||
|
|
||
|
if test "x$srcdir" = x ; then srcdir=`pwd`; fi
|
||
|
. ../test_common.sh
|
||
|
|
||
|
. "$srcdir/test_nczarr.sh"
|
||
|
|
||
|
set -e
|
||
|
|
||
|
|
||
|
# To add a new test,
|
||
|
# 1. put the .cdl file in the 'ncdump/cdl' directory
|
||
|
# 2. put the result of running ncgen then ncdump
|
||
|
# into the directory 'expected' as .dmp
|
||
|
# 3. Add the test to the end of the TESTS variable
|
||
|
# 4. Add the new files into ncdump/cdl/Makefile.am
|
||
|
# and ncdump/expected/Makefile.am
|
||
|
|
||
|
TESTS="\
|
||
|
dimscope \
|
||
|
tst_group_data \
|
||
|
tst_solar_1 \
|
||
|
tst_nul4 \
|
||
|
"
|
||
|
|
||
|
# These tests need to leave _FillValue
|
||
|
FVTESTS="tst_nans"
|
||
|
|
||
|
ALLTESTS="$TESTS $FVTESTS"
|
||
|
|
||
|
# Location constants
|
||
|
cdl="$srcdir/../ncdump/cdl"
|
||
|
expected="$srcdir/../ncdump/expected"
|
||
|
RESULTSDIR="./results"
|
||
|
|
||
|
# Functions
|
||
|
|
||
|
# See if this is an FVTEST
|
||
|
testiffv() {
|
||
|
ok=0
|
||
|
for FV in $FVTESTS ; do
|
||
|
if test "x$FV" = "x$1" ; then ok=1; fi
|
||
|
done
|
||
|
}
|
||
|
|
||
|
# Remove fillvalue attribute since zarr generates it when hdf5 does not
|
||
|
fvclean() {
|
||
|
cat $1 \
|
||
|
| sed -e '/:_FillValue/d' \
|
||
|
| cat > $2
|
||
|
}
|
||
|
|
||
|
difftest() {
|
||
|
echo ""; echo "*** Test zext=$zext"
|
||
|
for t in ${ALLTESTS} ; do
|
||
|
echo "*** Testing: ${t}"
|
||
|
# determine if we need the specflag set
|
||
|
# determine properties
|
||
|
checkprops ${t}
|
||
|
ref="ref_${t}"
|
||
|
rm -fr ${t}.$zext
|
||
|
rm -f tmp_${t}.dmp
|
||
|
fileargs $t
|
||
|
${NCGEN} -4 -lb -o ${fileurl} ${cdl}/${ref}.cdl
|
||
|
${NCDUMP} ${headflag} ${specflag} -n ${ref} ${fileurl} > tmp_${t}.dmp
|
||
|
testiffv $t
|
||
|
if test "x$ok" = x0 ; then
|
||
|
fvclean tmp_${t}.dmp tmp_${t}.dmpx
|
||
|
else
|
||
|
cp tmp_${t}.dmp tmp_${t}.dmpx
|
||
|
fi
|
||
|
# compare against expected
|
||
|
diff -b -w ${expected}/${ref}.dmp ./tmp_${t}.dmpx
|
||
|
echo "*** SUCCEED: ${t}"
|
||
|
done
|
||
|
}
|
||
|
|
||
|
runtestset() {
|
||
|
extfor $1
|
||
|
echo "*** Testing nczarr X ncgen with zmap=${zext}"
|
||
|
rm -fr ${RESULTSDIR}.$zext
|
||
|
mkdir ${RESULTSDIR}.${zext}
|
||
|
WD=`pwd `
|
||
|
cd ${RESULTSDIR}.${zext}
|
||
|
difftest
|
||
|
cd $WD
|
||
|
echo "*** PASSED: zext=${zext}"
|
||
|
}
|
||
|
|
||
|
runtestset file
|
||
|
if test "x$FEATURE_NCZARR_ZIP" = xyes ; then runtestset zip; fi
|
||
|
if test "x$FEATURE_S3TESTS" = xyes ; then runtestset s3; fi
|
||
|
|
||
|
echo "*** PASSED ***"
|