summaryrefslogtreecommitdiffstats
path: root/tools/misc/testh5repart.sh.in
blob: e33a905dc64f08c3f2db0baec631e55752c963e5 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
#! /bin/sh
#
# Copyright by The HDF Group.
# 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 COPYING file, which can be found at the root of the source code
# distribution tree, or in https://support.hdfgroup.org/ftp/HDF5/releases.
# If you do not have access to either file, you may request a copy from
# help@hdfgroup.org.
#
# Tests for the h5repart tool

srcdir=@srcdir@

TESTNAME=h5repart
EXIT_SUCCESS=0
EXIT_FAILURE=1

REPART=h5repart             # The tool name
REPART_BIN=`pwd`/$REPART    # The path of the tool binary

REPARTED_FAM=repart_test                # The test name
REPARTED_FAM_BIN=`pwd`/$REPARTED_FAM    # The path of the test binary

nerrors=0
verbose=yes

test -d ../testfiles || mkdir ../testfiles

actual_dir=`pwd`/../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.
#
TOOLTEST() {
   # Run tool test.
   TESTING $REPART $@
   (
#      echo
      cd $srcdir/../testfiles
      $RUNSERIAL $REPART_BIN $@
   )

   if test $? -eq 0; then
       echo " PASSED"
   else
       echo " FAILED"
       nerrors=`expr $nerrors + 1`
   fi
}

OUTPUTTEST() {
   # Run test program.
   TESTING $REPARTED_FAM $@
   (
      cd $actual_dir
      $RUNSERIAL $REPARTED_FAM_BIN $@
   )

   if test $? -eq 0; then
       echo " PASSED"
   else
       echo " FAILED"
       nerrors=`expr $nerrors + 1`
   fi
}

# Print a "SKIP" message
SKIP() {
    TESTING $REPART $@
    echo  " -SKIP-"
}

##############################################################################
##############################################################################
###              T H E   T E S T S                                ###
##############################################################################
##############################################################################

# repartition family member size to 20,000 bytes.
TOOLTEST -m 20000 family_file%05d.h5 $actual_dir/fst_family%05d.h5
# repartition family member size to 5 KB.
TOOLTEST -m 5k family_file%05d.h5 $actual_dir/scd_family%05d.h5
# convert family file to sec2 file of 20,000 bytes
TOOLTEST -m 20000 -family_to_sec2 family_file%05d.h5 $actual_dir/family_to_sec2.h5

# test the output files repartitioned above.
OUTPUTTEST
echo

# Clean up output file
if test -z "$HDF5_NOCLEANUP"; then
    cd $actual_dir
    rm -f fst_family*.h5 scd_family*.h5 family_to_sec2.h5
fi

if test $nerrors -eq 0 ; then
    echo "All $TESTNAME tests passed."
    exit $EXIT_SUCCESS
else
    echo "$TESTNAME tests failed with $nerrors errors."
    exit $EXIT_FAILURE
fi