Cloned library NetCDF-C-4.9.2 with extra build files for internal package management.
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.
 
 
 
 
 
 

99 lines
2.2 KiB

#!/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 ***"