2010-06-03 21:24:43 +08:00
|
|
|
#!/bin/sh
|
2017-11-25 22:28:07 +08:00
|
|
|
# For a netCDF-3 build, test nccopy on netCDF files in this
|
|
|
|
# directory. This test depends on a bunch of other ncdump tests
|
|
|
|
# running first, to produce the data files that are used to test
|
|
|
|
# nccopy.
|
|
|
|
# Dennis Heimbigner
|
2017-03-09 08:01:10 +08:00
|
|
|
|
2017-09-20 04:48:24 +08:00
|
|
|
if test "x$srcdir" = x ; then srcdir=`pwd`; fi
|
2017-03-09 08:01:10 +08:00
|
|
|
. ../test_common.sh
|
|
|
|
|
2010-06-03 21:24:43 +08:00
|
|
|
set -e
|
|
|
|
echo ""
|
|
|
|
|
2017-09-20 04:48:24 +08:00
|
|
|
# get some config.h parameters
|
|
|
|
if test -f ${top_builddir}/config.h ; then
|
2018-06-30 10:17:07 +08:00
|
|
|
if fgrep -e '#define ENABLE_CDF5 1' ${top_builddir}/config.h >/dev/null ; then
|
2017-09-20 04:48:24 +08:00
|
|
|
HAVE_CDF5=1
|
|
|
|
else
|
|
|
|
HAVE_CDF5=0
|
|
|
|
fi
|
|
|
|
else
|
|
|
|
echo "Cannot locate config.h"
|
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
|
2017-11-25 22:28:07 +08:00
|
|
|
TESTFILES='tst_output_c0 tst_output_c0tmp ctest0 ctest0_64 test0_offset test1_offset
|
2017-11-25 20:23:45 +08:00
|
|
|
tst_calendars tst_mslp tst_mslp_64 tst_ncml tst_small tst_utf8'
|
2010-06-03 21:24:43 +08:00
|
|
|
|
2017-09-21 01:25:36 +08:00
|
|
|
if test "x$HAVE_CDF5" = x1 ; then
|
2017-09-20 04:48:24 +08:00
|
|
|
TESTFILES="$TESTFILES small small2"
|
|
|
|
fi
|
|
|
|
|
|
|
|
|
2010-09-01 06:41:00 +08:00
|
|
|
echo "*** Testing netCDF-3 features of nccopy on ncdump/*.nc files"
|
2010-06-03 21:24:43 +08:00
|
|
|
for i in $TESTFILES ; do
|
2017-11-17 23:22:49 +08:00
|
|
|
echo "*** Testing nccopy $i.nc nccopy3_copy_of_$i.nc ..."
|
|
|
|
${NCCOPY} $i.nc nccopy3_copy_of_$i.nc
|
|
|
|
${NCDUMP} -n nccopy3_copy_of_$i $i.nc > tmp_tst_nccopy3.cdl
|
|
|
|
${NCDUMP} nccopy3_copy_of_$i.nc > nccopy3_copy_of_$i.cdl
|
|
|
|
diff nccopy3_copy_of_$i.cdl tmp_tst_nccopy3.cdl
|
|
|
|
rm nccopy3_copy_of_$i.nc nccopy3_copy_of_$i.cdl tmp_tst_nccopy3.cdl
|
2010-06-03 21:24:43 +08:00
|
|
|
done
|
2012-06-13 05:50:02 +08:00
|
|
|
echo "*** Testing nccopy -u"
|
2017-03-09 08:01:10 +08:00
|
|
|
${NCGEN} -b $srcdir/tst_brecs.cdl
|
2010-09-01 06:41:00 +08:00
|
|
|
# convert record dimension to fixed-size dimension
|
2017-11-17 23:22:49 +08:00
|
|
|
$NCCOPY -u tst_brecs.nc nccopy3_copy_of_tst_brecs.nc
|
|
|
|
${NCDUMP} -n nccopy3_copy_of_tst_brecs tst_brecs.nc | sed '/ = UNLIMITED ;/s/\(.*\) = UNLIMITED ; \/\/ (\(.*\) currently)/\1 = \2 ;/' > tmp_tst_nccopy3.cdl
|
|
|
|
${NCDUMP} nccopy3_copy_of_tst_brecs.nc > nccopy3_copy_of_tst_brecs.cdl
|
|
|
|
diff -b nccopy3_copy_of_tst_brecs.cdl tmp_tst_nccopy3.cdl
|
|
|
|
rm nccopy3_copy_of_tst_brecs.cdl tmp_tst_nccopy3.cdl tst_brecs.nc nccopy3_copy_of_tst_brecs.nc
|
2010-09-01 06:41:00 +08:00
|
|
|
|
2010-06-03 21:24:43 +08:00
|
|
|
echo "*** All nccopy tests passed!"
|
|
|
|
exit 0
|