2020-12-17 11:48:02 +08:00
|
|
|
#!/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"
|
|
|
|
|
2023-04-26 07:15:06 +08:00
|
|
|
# Isolate both test and S3
|
|
|
|
s3isolate "testdir_ncgen4"
|
|
|
|
THISDIR=`pwd`
|
|
|
|
cd $ISOPATH
|
2020-12-17 11:48:02 +08:00
|
|
|
|
2023-04-26 07:15:06 +08:00
|
|
|
set -e
|
2020-12-17 11:48:02 +08:00
|
|
|
|
|
|
|
# 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 \
|
|
|
|
"
|
|
|
|
|
2021-09-03 07:04:26 +08:00
|
|
|
# These tests need to leave _FillValue
|
|
|
|
FVTESTS="tst_nans"
|
2020-12-17 11:48:02 +08:00
|
|
|
|
2021-09-03 07:04:26 +08:00
|
|
|
ALLTESTS="$TESTS $FVTESTS"
|
2020-12-17 11:48:02 +08:00
|
|
|
|
|
|
|
# Location constants
|
|
|
|
cdl="$srcdir/../ncdump/cdl"
|
|
|
|
expected="$srcdir/../ncdump/expected"
|
|
|
|
|
|
|
|
# Functions
|
|
|
|
|
2021-09-03 07:04:26 +08:00
|
|
|
# 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
|
|
|
|
}
|
|
|
|
|
2020-12-17 11:48:02 +08:00
|
|
|
runtestset() {
|
|
|
|
extfor $1
|
|
|
|
echo "*** Testing nczarr X ncgen with zmap=${zext}"
|
|
|
|
difftest
|
|
|
|
echo "*** PASSED: zext=${zext}"
|
|
|
|
}
|
|
|
|
|
2021-01-29 11:11:01 +08:00
|
|
|
runtestset file
|
|
|
|
if test "x$FEATURE_NCZARR_ZIP" = xyes ; then runtestset zip; fi
|
2020-12-17 11:48:02 +08:00
|
|
|
if test "x$FEATURE_S3TESTS" = xyes ; then runtestset s3; fi
|
|
|
|
|
|
|
|
echo "*** PASSED ***"
|
2023-04-26 07:15:06 +08:00
|
|
|
|
|
|
|
if test "x$FEATURE_S3TESTS" = xyes ; then s3sdkdelete "/${S3ISOPATH}" ; fi # Cleanup
|