2006-06-18 02:16:05 +08:00
|
|
|
#! /bin/sh
|
|
|
|
#
|
2007-02-08 03:56:21 +08:00
|
|
|
# Copyright by The HDF Group.
|
2006-06-18 02:16:05 +08:00
|
|
|
# Copyright by the Board of Trustees of the University of Illinois.
|
|
|
|
# All rights reserved.
|
|
|
|
#
|
|
|
|
# This file is part of HDF5. The full HDF5 copyright notice, including
|
|
|
|
# terms governing use, modification, and redistribution, is contained in
|
|
|
|
# the files COPYING and Copyright.html. COPYING can be found at the root
|
|
|
|
# of the source code distribution tree; Copyright.html can be found at the
|
|
|
|
# root level of an installed copy of the electronic HDF5 document set and
|
|
|
|
# is linked from the top-level documents page. It can also be found at
|
2007-02-08 03:56:21 +08:00
|
|
|
# http://hdfgroup.org/HDF5/doc/Copyright.html. If you do not have
|
|
|
|
# access to either file, you may request a copy from help@hdfgroup.org.
|
2006-06-18 02:16:05 +08:00
|
|
|
#
|
|
|
|
# Tests for the h5dump tool
|
|
|
|
|
|
|
|
# Determine which filters are available
|
|
|
|
USE_FILTER_SZIP="@USE_FILTER_SZIP@"
|
|
|
|
USE_FILTER_DEFLATE="@USE_FILTER_DEFLATE@"
|
|
|
|
USE_FILTER_SHUFFLE="@USE_FILTER_SHUFFLE@"
|
|
|
|
USE_FILTER_FLETCHER32="@USE_FILTER_FLETCHER32@"
|
|
|
|
USE_FILTER_NBIT="@USE_FILTER_NBIT@"
|
|
|
|
USE_FILTER_SCALEOFFSET="@USE_FILTER_SCALEOFFSET@"
|
|
|
|
|
|
|
|
STAT=h5stat # The tool name
|
|
|
|
STAT_BIN=`pwd`/$STAT # The path of the tool binary
|
|
|
|
|
|
|
|
CMP='cmp -s'
|
|
|
|
DIFF='diff -c'
|
|
|
|
|
|
|
|
nerrors=0
|
|
|
|
verbose=yes
|
|
|
|
|
|
|
|
# The build (current) directory might be different than the source directory.
|
|
|
|
if test -z "$srcdir"; then
|
|
|
|
srcdir=.
|
|
|
|
fi
|
|
|
|
|
|
|
|
test -d ./testfiles || mkdir ./testfiles
|
|
|
|
|
|
|
|
# Print a line-line message left justified in a field of 70 characters
|
|
|
|
# beginning with the word "Testing".
|
|
|
|
#
|
|
|
|
TESTING() {
|
|
|
|
SPACES=" "
|
|
|
|
echo "Testing $* $SPACES" | cut -c1-70 | tr -d '\012'
|
|
|
|
}
|
|
|
|
|
|
|
|
# Run a test and print PASS or *FAIL*. If a test fails then increment
|
|
|
|
# the `nerrors' global variable and (if $verbose is set) display the
|
|
|
|
# difference between the actual output and the expected output. The
|
|
|
|
# expected output is given as the first argument to this function and
|
|
|
|
# the actual output file is calculated by replacing the `.ddl' with
|
|
|
|
# `.out'. The actual output is not removed if $HDF5_NOCLEANUP has a
|
|
|
|
# non-zero value.
|
|
|
|
#
|
|
|
|
TOOLTEST() {
|
|
|
|
expect="$srcdir/testfiles/$1"
|
|
|
|
actual="./testfiles/`basename $1 .ddl`.out"
|
|
|
|
actual_err="./testfiles/`basename $1 .ddl`.err"
|
|
|
|
shift
|
|
|
|
|
|
|
|
# Run test.
|
|
|
|
TESTING $STAT $@
|
|
|
|
(
|
|
|
|
echo "#############################"
|
|
|
|
echo "Expected output for '$STAT $@'"
|
|
|
|
echo "#############################"
|
|
|
|
cd $srcdir/testfiles
|
|
|
|
$RUNSERIAL $STAT_BIN $@
|
|
|
|
) >$actual 2>$actual_err
|
|
|
|
cat $actual_err >> $actual
|
|
|
|
|
|
|
|
|
|
|
|
if [ ! -f $expect ]; then
|
|
|
|
# Create the expect file if it doesn't yet exist.
|
|
|
|
echo " CREATED"
|
|
|
|
cp $actual $expect
|
|
|
|
elif $CMP $expect $actual; then
|
|
|
|
echo " PASSED"
|
|
|
|
else
|
|
|
|
echo "*FAILED*"
|
|
|
|
echo " Expected result (*.ddl) differs from actual result (*.out)"
|
|
|
|
nerrors="`expr $nerrors + 1`"
|
|
|
|
test yes = "$verbose" && $DIFF $expect $actual |sed 's/^/ /'
|
|
|
|
fi
|
|
|
|
|
|
|
|
# Clean up output file
|
|
|
|
if test -z "$HDF5_NOCLEANUP"; then
|
|
|
|
rm -f $actual $actual_err
|
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
# Print a "SKIP" message
|
|
|
|
SKIP() {
|
|
|
|
TESTING $STAT $@
|
|
|
|
echo " -SKIP-"
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
##############################################################################
|
|
|
|
##############################################################################
|
|
|
|
### T H E T E S T S ###
|
|
|
|
##############################################################################
|
|
|
|
##############################################################################
|
|
|
|
|
2006-06-19 01:41:58 +08:00
|
|
|
# Test for help flag
|
2006-06-18 02:16:05 +08:00
|
|
|
TOOLTEST h5stat_help1.ddl -h
|
|
|
|
TOOLTEST h5stat_help2.ddl --help
|
2006-06-19 01:41:58 +08:00
|
|
|
|
|
|
|
# Test file with groups, compressed datasets, user-applied fileters, etc.
|
|
|
|
# h5stat_filters.h5 is a copy of ../../testfiles/tfilters.h5 as of release 1.8.0-alpha4
|
|
|
|
TOOLTEST h5stat_filters.ddl h5stat_filters.h5
|
2006-07-15 04:23:43 +08:00
|
|
|
TOOLTEST h5stat_filters-file.ddl -f h5stat_filters.h5
|
2006-06-19 01:41:58 +08:00
|
|
|
TOOLTEST h5stat_filters-F.ddl -F h5stat_filters.h5
|
|
|
|
TOOLTEST h5stat_filters-d.ddl -d h5stat_filters.h5
|
|
|
|
TOOLTEST h5stat_filters-g.ddl -g h5stat_filters.h5
|
|
|
|
TOOLTEST h5stat_filters-dT.ddl -dT h5stat_filters.h5
|
2007-07-14 05:12:25 +08:00
|
|
|
# h5stat_tsohm.h5 is a copy of ../../../test/tsohm.h5 generated by tsohm.c
|
|
|
|
# as of release 1.8.0-alpha4
|
|
|
|
TOOLTEST h5stat_tsohm.ddl h5stat_tsohm.h5
|
|
|
|
# h5stat_newgrat.h5 is generated by h5stat_gentest.c
|
|
|
|
TOOLTEST h5stat_newgrat.ddl h5stat_newgrat.h5
|
2006-06-18 02:16:05 +08:00
|
|
|
echo
|
|
|
|
|
|
|
|
|
|
|
|
if test $nerrors -eq 0 ; then
|
|
|
|
echo "All $STAT tests passed."
|
|
|
|
fi
|
|
|
|
|
|
|
|
exit $nerrors
|
|
|
|
|