2003-04-01 01:59:04 +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 *
|
|
|
|
* http://hdf.ncsa.uiuc.edu/HDF5/doc/Copyright.html. If you do not have *
|
|
|
|
* access to either file, you may request a copy from hdfhelp@ncsa.uiuc.edu. *
|
|
|
|
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
|
1997-07-31 05:17:56 +08:00
|
|
|
|
|
|
|
/* $Id$ */
|
|
|
|
|
|
|
|
/*
|
|
|
|
FILE
|
1998-01-17 06:23:43 +08:00
|
|
|
testhdf5.c - HDF5 testing framework main file.
|
1997-07-31 05:17:56 +08:00
|
|
|
|
|
|
|
REMARKS
|
1998-01-17 06:23:43 +08:00
|
|
|
General test wrapper for HDF5 base library test programs
|
1997-07-31 05:17:56 +08:00
|
|
|
|
|
|
|
DESIGN
|
1998-01-17 06:23:43 +08:00
|
|
|
Each test function should be implemented as function having no
|
|
|
|
parameters and returning void (i.e. no return value). They should be put
|
|
|
|
into the list of InitTest() calls in main() below. Functions which depend
|
|
|
|
on other functionality should be placed below the InitTest() call for the
|
|
|
|
base functionality testing.
|
|
|
|
Each test module should include testhdf5.h and define a unique set of
|
|
|
|
names for test files they create.
|
1997-07-31 05:17:56 +08:00
|
|
|
|
|
|
|
BUGS/LIMITATIONS
|
|
|
|
|
|
|
|
EXPORTED ROUTINES/VARIABLES:
|
1998-01-17 06:23:43 +08:00
|
|
|
Two variables are exported: num_errs, and Verbosity.
|
1997-07-31 05:17:56 +08:00
|
|
|
|
|
|
|
*/
|
|
|
|
|
1997-08-16 00:53:11 +08:00
|
|
|
#include <stdarg.h>
|
|
|
|
|
1997-07-31 05:17:56 +08:00
|
|
|
#define MAXNUMOFTESTS 30
|
|
|
|
#define HDF5_TEST_MASTER
|
|
|
|
|
|
|
|
/* Internal Variables */
|
1998-01-17 06:23:43 +08:00
|
|
|
static int Index = 0;
|
1997-07-31 05:17:56 +08:00
|
|
|
|
1997-08-16 00:53:11 +08:00
|
|
|
/* Global variables */
|
1998-10-28 01:05:37 +08:00
|
|
|
int num_errs = 0;
|
1998-01-17 06:23:43 +08:00
|
|
|
int Verbosity;
|
1997-08-16 00:53:11 +08:00
|
|
|
|
1997-07-31 05:17:56 +08:00
|
|
|
/* ANY new test needs to have a prototype in tproto.h */
|
2001-04-04 02:09:16 +08:00
|
|
|
#include "testhdf5.h"
|
1997-07-31 05:17:56 +08:00
|
|
|
|
1998-01-17 06:23:43 +08:00
|
|
|
struct TestStruct {
|
1998-07-11 06:00:26 +08:00
|
|
|
int NumErrors;
|
|
|
|
char Description[64];
|
|
|
|
int SkipFlag;
|
|
|
|
char Name[16];
|
|
|
|
void (*Call) (void);
|
|
|
|
void (*Cleanup) (void);
|
1998-01-17 06:23:43 +08:00
|
|
|
} Test[MAXNUMOFTESTS];
|
1997-07-31 05:17:56 +08:00
|
|
|
|
1998-07-11 06:00:26 +08:00
|
|
|
static void InitTest(const char *TheName, void (*TheCall) (void), void (*Cleanup) (void), const char *TheDescr);
|
1998-01-17 06:23:43 +08:00
|
|
|
static void usage(void);
|
1997-07-31 05:17:56 +08:00
|
|
|
|
1998-01-17 06:23:43 +08:00
|
|
|
static void
|
1998-07-11 06:00:26 +08:00
|
|
|
InitTest(const char *TheName, void (*TheCall) (void), void (*Cleanup) (void), const char *TheDescr)
|
1997-07-31 05:17:56 +08:00
|
|
|
{
|
1998-01-17 06:23:43 +08:00
|
|
|
if (Index >= MAXNUMOFTESTS) {
|
|
|
|
print_func("Uh-oh, too many tests added, increase MAXNUMOFTEST!\n");
|
1998-10-28 01:05:37 +08:00
|
|
|
exit(-1);
|
1998-01-17 06:23:43 +08:00
|
|
|
} /* end if */
|
1997-07-31 05:17:56 +08:00
|
|
|
HDstrcpy(Test[Index].Description, TheDescr);
|
|
|
|
HDstrcpy(Test[Index].Name, TheName);
|
|
|
|
Test[Index].Call = TheCall;
|
1998-07-11 06:00:26 +08:00
|
|
|
Test[Index].Cleanup = Cleanup;
|
1997-07-31 05:17:56 +08:00
|
|
|
Test[Index].NumErrors = -1;
|
|
|
|
Test[Index].SkipFlag = 0;
|
|
|
|
Index++;
|
|
|
|
}
|
|
|
|
|
1998-01-17 06:23:43 +08:00
|
|
|
static void
|
|
|
|
usage(void)
|
1997-07-31 05:17:56 +08:00
|
|
|
{
|
2001-08-15 06:09:56 +08:00
|
|
|
int i;
|
1997-07-31 05:17:56 +08:00
|
|
|
|
|
|
|
print_func("Usage: testhdf5 [-v[erbose] (l[ow]|m[edium]|h[igh]|0-10)] \n");
|
|
|
|
print_func(" [-[e]x[clude] name+] \n");
|
|
|
|
print_func(" [-o[nly] name+] \n");
|
|
|
|
print_func(" [-b[egin] name] \n");
|
|
|
|
print_func(" [-s[ummary]] \n");
|
|
|
|
print_func(" [-c[leanoff]] \n");
|
|
|
|
print_func(" [-n[ocaching]] \n");
|
|
|
|
print_func(" [-h[elp]] \n");
|
|
|
|
print_func("\n\n");
|
|
|
|
print_func("verbose controls the amount of information displayed\n");
|
|
|
|
print_func("exclude to exclude tests by name\n");
|
|
|
|
print_func("only to name tests which should be run\n");
|
|
|
|
print_func("begin start at the name of the test givin\n");
|
|
|
|
print_func("summary prints a summary of test results at the end\n");
|
|
|
|
print_func("cleanoff does not delete *.hdf files after execution of tests\n");
|
|
|
|
print_func("nocaching do not turn on low-level DD caching\n");
|
|
|
|
print_func("help print out this information\n");
|
|
|
|
print_func("\n\n");
|
|
|
|
print_func("This program currently tests the following: \n\n");
|
|
|
|
print_func("%16s %s\n", "Name", "Description");
|
|
|
|
print_func("%16s %s\n", "----", "-----------");
|
|
|
|
for (i = 0; i < Index; i++)
|
|
|
|
print_func("%16s %s\n", Test[i].Name, Test[i].Description);
|
|
|
|
print_func("\n\n");
|
1998-01-17 06:23:43 +08:00
|
|
|
} /* end usage() */
|
1997-07-31 05:17:56 +08:00
|
|
|
|
|
|
|
/*
|
|
|
|
* This routine is designed to provide equivalent functionality to 'printf'
|
|
|
|
* and allow easy replacement for environments which don't have stdin/stdout
|
|
|
|
* available. (i.e. Windows & the Mac)
|
|
|
|
*/
|
1998-01-17 06:23:43 +08:00
|
|
|
int
|
|
|
|
print_func(const char *format,...)
|
1997-07-31 05:17:56 +08:00
|
|
|
{
|
1998-01-17 06:23:43 +08:00
|
|
|
va_list arglist;
|
|
|
|
int ret_value;
|
1997-07-31 05:17:56 +08:00
|
|
|
|
|
|
|
va_start(arglist, format);
|
1998-01-17 06:23:43 +08:00
|
|
|
ret_value = vprintf(format, arglist);
|
1997-07-31 05:17:56 +08:00
|
|
|
va_end(arglist);
|
1998-01-17 06:23:43 +08:00
|
|
|
return (ret_value);
|
1997-07-31 05:17:56 +08:00
|
|
|
}
|
|
|
|
|
1998-01-17 06:23:43 +08:00
|
|
|
int
|
|
|
|
main(int argc, char *argv[])
|
1997-07-31 05:17:56 +08:00
|
|
|
{
|
1998-01-17 06:23:43 +08:00
|
|
|
int CLLoop; /* Command Line Loop */
|
|
|
|
int Loop, Loop1;
|
|
|
|
int Summary = 0;
|
|
|
|
int CleanUp = 1;
|
|
|
|
int Cache = 1;
|
2002-01-24 05:28:24 +08:00
|
|
|
unsigned major, minor, release;
|
1997-07-31 05:17:56 +08:00
|
|
|
|
|
|
|
#if !(defined MAC || defined __MWERKS__ || defined SYMANTEC_C)
|
|
|
|
/* Un-buffer the stdout and stderr */
|
|
|
|
setbuf(stderr, NULL);
|
|
|
|
setbuf(stdout, NULL);
|
|
|
|
#endif
|
|
|
|
|
1998-03-01 02:19:05 +08:00
|
|
|
/*
|
|
|
|
* Turn off automatic error reporting since we do it ourselves. Besides,
|
|
|
|
* half the functions this test calls are private, so automatic error
|
|
|
|
* reporting wouldn't do much good since it's triggered at the API layer.
|
|
|
|
*/
|
2003-09-25 03:26:50 +08:00
|
|
|
#ifdef H5_WANT_H5_V1_6_COMPAT
|
|
|
|
H5Eset_auto (NULL, NULL);
|
|
|
|
#else
|
2003-07-26 10:55:47 +08:00
|
|
|
H5Eset_auto (H5E_DEFAULT, NULL, NULL);
|
2003-09-25 03:26:50 +08:00
|
|
|
#endif /* H5_WANT_H5_V1_6_COMPAT */
|
1998-03-01 02:19:05 +08:00
|
|
|
|
1997-07-31 05:17:56 +08:00
|
|
|
/* Tests are generally arranged from least to most complexity... */
|
2001-09-26 13:37:15 +08:00
|
|
|
InitTest("configure", test_configure, cleanup_configure, "Configure definitions");
|
1998-07-11 06:00:26 +08:00
|
|
|
InitTest("metadata", test_metadata, cleanup_metadata, "Encode/decode metadata code");
|
2000-05-09 07:09:09 +08:00
|
|
|
InitTest("tbbt", test_tbbt, NULL, "Threaded, Balanced, Binary Trees");
|
[svn-r6252] Purpose:
Lots of performance improvements & a couple new internal API interfaces.
Description:
Performance Improvements:
- Cached file offset & length sizes in shared file struct, to avoid
constantly looking them up in the FCPL.
- Generic property improvements:
- Added "revision" number to generic property classes to speed
up comparisons.
- Changed method of storing properties from using a hash-table
to the TBBT routines in the library.
- Share the propery names between classes and the lists derived
from them.
- Removed redundant 'def_value' buffer from each property.
- Switching code to use a "copy on write" strategy for
properties in each list, where the properties in each list
are shared with the properties in the class, until a
property's value is changed in a list.
- Fixed error in layout code which was allocating too many buffers.
- Redefined public macros of the form (H5open()/H5check, <variable>)
internally to only be (<variable>), avoiding innumerable useless
calls to H5open() and H5check_version().
- Reuse already zeroed buffers in H5F_contig_fill instead of
constantly re-zeroing them.
- Don't write fill values if writing entire dataset.
- Use gettimeofday() system call instead of time() system when
checking the modification time of a dataset.
- Added reference counted string API and use it for tracking the
names of objects opening in a file (for the ID->name code).
- Removed redundant H5P_get() calls in B-tree routines.
- Redefine H5T datatype macros internally to the library, to avoid
calling H5check redundantly.
- Keep dataspace information for dataset locally instead of reading
from disk each time. Added new module to track open objects
in a file, to allow this (which will be useful eventually for
some FPH5 metadata caching issues).
- Remove H5AC_find macro which was inlining metadata cache lookups,
and call function instead.
- Remove redundant memset() calls from H5G_namei() routine.
- Remove redundant checking of object type when locating objects
in metadata cache and rely on the address only.
- Create default dataset object to use when default dataset creation
property list is used to create datasets, bypassing querying
for all the property list values.
- Use default I/O vector size when performing raw data with the
default dataset transfer property list, instead of querying for
I/O vector size.
- Remove H5P_DEFAULT internally to the library, replacing it with
more specific default property list based on the type of
property list needed.
- Remove redundant memset() calls in object header message (H5O*)
routines.
- Remove redunant memset() calls in data I/O routines.
- Split free-list allocation routines into malloc() and calloc()-
like routines, instead of one combined routine.
- Remove lots of indirection in H5O*() routines.
- Simplify metadata cache entry comparison routine (used when
flushing entire cache out).
- Only enable metadata cache statistics when H5AC_DEBUG is turned
on, instead of always tracking them.
- Simplify address comparison macro (H5F_addr_eq).
- Remove redundant metadata cache entry protections during dataset
creation by protecting the object header once and making all
the modifications necessary for the dataset creation before
unprotecting it.
- Reduce # of "number of element in extent" computations performed
by computing and storing the value during dataspace creation.
- Simplify checking for group location's file information, when file
has not been involving in file-mounting operations.
- Use binary encoding for modification time, instead of ASCII.
- Hoist H5HL_peek calls (to get information in a local heap)
out of loops in many group routine.
- Use static variable for iterators of selections, instead of
dynamically allocation them each time.
- Lookup & insert new entries in one step, avoiding traversing
group's B-tree twice.
- Fixed memory leak in H5Gget_objname_idx() routine (tangential to
performance improvements, but fixed along the way).
- Use free-list for reference counted strings.
- Don't bother copying object names into cached group entries,
since they are re-created when an object is opened.
The benchmark I used to measure these results created several thousand
small (2K) datasets in a file and wrote out the data for them. This is
Elena's "regular.c" benchmark.
These changes resulted in approximately ~4.3x speedup of the
development branch when compared to the previous code in the
development branch and ~1.4x speedup compared to the release
branch.
Additionally, these changes reduce the total memory used (code and
data) by the development branch by ~800KB, bringing the development
branch back into the same ballpark as the release branch.
I'll send out a more detailed description of the benchmark results
as a followup note.
New internal API routines:
Added "reference counted strings" API for tracking strings that get
used by multiple owners without duplicating the strings.
Added "ternary search tree" API for text->object mappings.
Platforms tested:
Tested h5committest {arabica (fortran), eirene (fortran, C++)
modi4 (parallel, fortran)}
Other platforms/configurations tested?
FreeBSD 4.7 (sleipnir) serial & parallel
Solaris 2.6 (baldric) serial
2003-01-10 01:20:03 +08:00
|
|
|
InitTest("tst", test_tst, NULL, "Ternary Search Trees");
|
2003-02-25 04:25:13 +08:00
|
|
|
InitTest("heap", test_heap, NULL, "Memory Heaps");
|
[svn-r6252] Purpose:
Lots of performance improvements & a couple new internal API interfaces.
Description:
Performance Improvements:
- Cached file offset & length sizes in shared file struct, to avoid
constantly looking them up in the FCPL.
- Generic property improvements:
- Added "revision" number to generic property classes to speed
up comparisons.
- Changed method of storing properties from using a hash-table
to the TBBT routines in the library.
- Share the propery names between classes and the lists derived
from them.
- Removed redundant 'def_value' buffer from each property.
- Switching code to use a "copy on write" strategy for
properties in each list, where the properties in each list
are shared with the properties in the class, until a
property's value is changed in a list.
- Fixed error in layout code which was allocating too many buffers.
- Redefined public macros of the form (H5open()/H5check, <variable>)
internally to only be (<variable>), avoiding innumerable useless
calls to H5open() and H5check_version().
- Reuse already zeroed buffers in H5F_contig_fill instead of
constantly re-zeroing them.
- Don't write fill values if writing entire dataset.
- Use gettimeofday() system call instead of time() system when
checking the modification time of a dataset.
- Added reference counted string API and use it for tracking the
names of objects opening in a file (for the ID->name code).
- Removed redundant H5P_get() calls in B-tree routines.
- Redefine H5T datatype macros internally to the library, to avoid
calling H5check redundantly.
- Keep dataspace information for dataset locally instead of reading
from disk each time. Added new module to track open objects
in a file, to allow this (which will be useful eventually for
some FPH5 metadata caching issues).
- Remove H5AC_find macro which was inlining metadata cache lookups,
and call function instead.
- Remove redundant memset() calls from H5G_namei() routine.
- Remove redundant checking of object type when locating objects
in metadata cache and rely on the address only.
- Create default dataset object to use when default dataset creation
property list is used to create datasets, bypassing querying
for all the property list values.
- Use default I/O vector size when performing raw data with the
default dataset transfer property list, instead of querying for
I/O vector size.
- Remove H5P_DEFAULT internally to the library, replacing it with
more specific default property list based on the type of
property list needed.
- Remove redundant memset() calls in object header message (H5O*)
routines.
- Remove redunant memset() calls in data I/O routines.
- Split free-list allocation routines into malloc() and calloc()-
like routines, instead of one combined routine.
- Remove lots of indirection in H5O*() routines.
- Simplify metadata cache entry comparison routine (used when
flushing entire cache out).
- Only enable metadata cache statistics when H5AC_DEBUG is turned
on, instead of always tracking them.
- Simplify address comparison macro (H5F_addr_eq).
- Remove redundant metadata cache entry protections during dataset
creation by protecting the object header once and making all
the modifications necessary for the dataset creation before
unprotecting it.
- Reduce # of "number of element in extent" computations performed
by computing and storing the value during dataspace creation.
- Simplify checking for group location's file information, when file
has not been involving in file-mounting operations.
- Use binary encoding for modification time, instead of ASCII.
- Hoist H5HL_peek calls (to get information in a local heap)
out of loops in many group routine.
- Use static variable for iterators of selections, instead of
dynamically allocation them each time.
- Lookup & insert new entries in one step, avoiding traversing
group's B-tree twice.
- Fixed memory leak in H5Gget_objname_idx() routine (tangential to
performance improvements, but fixed along the way).
- Use free-list for reference counted strings.
- Don't bother copying object names into cached group entries,
since they are re-created when an object is opened.
The benchmark I used to measure these results created several thousand
small (2K) datasets in a file and wrote out the data for them. This is
Elena's "regular.c" benchmark.
These changes resulted in approximately ~4.3x speedup of the
development branch when compared to the previous code in the
development branch and ~1.4x speedup compared to the release
branch.
Additionally, these changes reduce the total memory used (code and
data) by the development branch by ~800KB, bringing the development
branch back into the same ballpark as the release branch.
I'll send out a more detailed description of the benchmark results
as a followup note.
New internal API routines:
Added "reference counted strings" API for tracking strings that get
used by multiple owners without duplicating the strings.
Added "ternary search tree" API for text->object mappings.
Platforms tested:
Tested h5committest {arabica (fortran), eirene (fortran, C++)
modi4 (parallel, fortran)}
Other platforms/configurations tested?
FreeBSD 4.7 (sleipnir) serial & parallel
Solaris 2.6 (baldric) serial
2003-01-10 01:20:03 +08:00
|
|
|
InitTest("refstr", test_refstr, NULL, "Reference Counted Strings");
|
1998-07-11 06:00:26 +08:00
|
|
|
InitTest("file", test_file, cleanup_file, "Low-Level File I/O");
|
|
|
|
InitTest("h5s", test_h5s, cleanup_h5s, "Dataspaces");
|
|
|
|
InitTest("attr", test_attr, cleanup_attr, "Attributes");
|
1998-07-15 05:14:12 +08:00
|
|
|
InitTest("select", test_select, cleanup_select, "Selections");
|
2000-10-20 00:42:33 +08:00
|
|
|
InitTest("time", test_time, cleanup_time, "Time Datatypes");
|
1998-10-14 05:30:49 +08:00
|
|
|
InitTest("reference", test_reference, cleanup_reference, "References");
|
1999-06-12 06:05:04 +08:00
|
|
|
InitTest("vltypes", test_vltypes, cleanup_vltypes, "Variable-Length Datatypes");
|
1999-09-29 08:30:47 +08:00
|
|
|
InitTest("vlstrings", test_vlstrings, cleanup_vlstrings, "Variable-Length Strings");
|
2000-04-06 04:51:44 +08:00
|
|
|
InitTest("iterate", test_iterate, cleanup_iterate, "Group & Attribute Iteration");
|
2000-11-10 05:47:59 +08:00
|
|
|
InitTest("array", test_array, cleanup_array, "Array Datatypes");
|
2000-11-12 08:10:08 +08:00
|
|
|
InitTest("genprop", test_genprop, cleanup_genprop, "Generic Properties");
|
2002-01-24 05:28:24 +08:00
|
|
|
InitTest("misc", test_misc, cleanup_misc, "Miscellaneous");
|
1997-07-31 05:17:56 +08:00
|
|
|
|
1998-01-17 06:23:43 +08:00
|
|
|
Verbosity = 4; /* Default Verbosity is Low */
|
1998-09-01 11:35:23 +08:00
|
|
|
H5get_libversion(&major, &minor, &release);
|
1997-07-31 05:17:56 +08:00
|
|
|
|
|
|
|
print_func("\nFor help use: testhdf5 -help\n");
|
1998-07-18 03:03:43 +08:00
|
|
|
print_func("Linked with hdf5 version %u.%u release %u\n",
|
|
|
|
(unsigned)major, (unsigned)minor, (unsigned)release);
|
1998-01-17 06:23:43 +08:00
|
|
|
for (CLLoop = 1; CLLoop < argc; CLLoop++) {
|
|
|
|
if ((argc > CLLoop + 1) && ((HDstrcmp(argv[CLLoop], "-verbose") == 0) ||
|
|
|
|
(HDstrcmp(argv[CLLoop], "-v") == 0))) {
|
|
|
|
if (argv[CLLoop + 1][0] == 'l')
|
|
|
|
Verbosity = 4;
|
|
|
|
else if (argv[CLLoop + 1][0] == 'm')
|
|
|
|
Verbosity = 6;
|
|
|
|
else if (argv[CLLoop + 1][0] == 'h')
|
|
|
|
Verbosity = 10;
|
|
|
|
else
|
|
|
|
Verbosity = atoi(argv[CLLoop + 1]);
|
|
|
|
} /* end if */
|
|
|
|
if ((argc > CLLoop) && ((HDstrcmp(argv[CLLoop], "-summary") == 0) ||
|
|
|
|
(HDstrcmp(argv[CLLoop], "-s") == 0)))
|
|
|
|
Summary = 1;
|
|
|
|
|
|
|
|
if ((argc > CLLoop) && ((HDstrcmp(argv[CLLoop], "-help") == 0) ||
|
|
|
|
(HDstrcmp(argv[CLLoop], "-h") == 0))) {
|
|
|
|
usage();
|
|
|
|
exit(0);
|
|
|
|
}
|
|
|
|
if ((argc > CLLoop) && ((HDstrcmp(argv[CLLoop], "-cleanoff") == 0) ||
|
|
|
|
(HDstrcmp(argv[CLLoop], "-c") == 0)))
|
|
|
|
CleanUp = 0;
|
|
|
|
|
|
|
|
if ((argc > CLLoop) && ((HDstrcmp(argv[CLLoop], "-nocache") == 0) ||
|
1998-02-10 03:37:40 +08:00
|
|
|
(HDstrcmp(argv[CLLoop], "-n") == 0))) {
|
1998-01-17 06:23:43 +08:00
|
|
|
Cache = 0;
|
1998-02-10 03:37:40 +08:00
|
|
|
printf ("Cache = %d\n", Cache);
|
|
|
|
}
|
1998-01-17 06:23:43 +08:00
|
|
|
|
|
|
|
if ((argc > CLLoop + 1) && ((HDstrcmp(argv[CLLoop], "-exclude") == 0) ||
|
|
|
|
(HDstrcmp(argv[CLLoop], "-x") == 0))) {
|
|
|
|
Loop = CLLoop + 1;
|
|
|
|
while ((Loop < argc) && (argv[Loop][0] != '-')) {
|
|
|
|
for (Loop1 = 0; Loop1 < Index; Loop1++)
|
|
|
|
if (HDstrcmp(argv[Loop], Test[Loop1].Name) == 0)
|
|
|
|
Test[Loop1].SkipFlag = 1;
|
|
|
|
Loop++;
|
|
|
|
} /* end while */
|
|
|
|
} /* end if */
|
|
|
|
if ((argc > CLLoop + 1) && ((HDstrcmp(argv[CLLoop], "-begin") == 0) ||
|
|
|
|
(HDstrcmp(argv[CLLoop], "-b") == 0))) {
|
|
|
|
Loop = CLLoop + 1;
|
|
|
|
while ((Loop < argc) && (argv[Loop][0] != '-')) {
|
|
|
|
for (Loop1 = 0; Loop1 < Index; Loop1++) {
|
|
|
|
if (HDstrcmp(argv[Loop], Test[Loop1].Name) != 0)
|
|
|
|
Test[Loop1].SkipFlag = 1;
|
|
|
|
if (HDstrcmp(argv[Loop], Test[Loop1].Name) == 0)
|
|
|
|
Loop1 = Index;
|
|
|
|
} /* end for */
|
|
|
|
Loop++;
|
|
|
|
} /* end while */
|
|
|
|
} /* end if */
|
|
|
|
if ((argc > CLLoop + 1) && ((HDstrcmp(argv[CLLoop], "-only") == 0) ||
|
|
|
|
(HDstrcmp(argv[CLLoop], "-o") == 0))) {
|
|
|
|
for (Loop = 0; Loop < Index; Loop++)
|
|
|
|
Test[Loop].SkipFlag = 1;
|
|
|
|
Loop = CLLoop + 1;
|
|
|
|
while ((Loop < argc) && (argv[Loop][0] != '-')) {
|
|
|
|
for (Loop1 = 0; Loop1 < Index; Loop1++)
|
|
|
|
if (HDstrcmp(argv[Loop], Test[Loop1].Name) == 0)
|
|
|
|
Test[Loop1].SkipFlag = 0;
|
|
|
|
Loop++;
|
|
|
|
} /* end while */
|
|
|
|
} /* end if */
|
|
|
|
} /* end for */
|
1997-07-31 05:17:56 +08:00
|
|
|
|
|
|
|
#ifdef NOT_YET
|
1998-01-17 06:23:43 +08:00
|
|
|
if (Cache) /* turn on caching, unless we were instucted not to */
|
|
|
|
Hcache(CACHE_ALL_FILES, TRUE);
|
1997-07-31 05:17:56 +08:00
|
|
|
#endif /* NOT_YET */
|
|
|
|
|
1998-01-17 06:23:43 +08:00
|
|
|
for (Loop = 0; Loop < Index; Loop++) {
|
|
|
|
if (Test[Loop].SkipFlag) {
|
|
|
|
MESSAGE(2, ("Skipping -- %s \n", Test[Loop].Description));
|
|
|
|
} else {
|
|
|
|
MESSAGE(2, ("Testing -- %s (%s) \n", Test[Loop].Description,
|
|
|
|
Test[Loop].Name));
|
|
|
|
MESSAGE(5, ("===============================================\n"));
|
|
|
|
Test[Loop].NumErrors = num_errs;
|
|
|
|
(*Test[Loop].Call) ();
|
|
|
|
Test[Loop].NumErrors = num_errs - Test[Loop].NumErrors;
|
|
|
|
MESSAGE(5, ("===============================================\n"));
|
|
|
|
MESSAGE(5, ("There were %d errors detected.\n\n", (int) Test[Loop].NumErrors));
|
|
|
|
} /* end else */
|
|
|
|
} /* end for */
|
1997-07-31 05:17:56 +08:00
|
|
|
|
1997-08-30 00:59:28 +08:00
|
|
|
MESSAGE(2, ("\n\n"))
|
1997-07-31 05:17:56 +08:00
|
|
|
if (num_errs)
|
|
|
|
print_func("!!! %d Error(s) were detected !!!\n\n", (int) num_errs);
|
|
|
|
else
|
|
|
|
print_func("All tests were successful. \n\n");
|
|
|
|
|
1998-01-17 06:23:43 +08:00
|
|
|
if (Summary) {
|
|
|
|
print_func("Summary of Test Results:\n");
|
|
|
|
print_func("Name of Test Errors Description of Test\n");
|
|
|
|
print_func("---------------- ------ --------------------------------------\n");
|
1997-07-31 05:17:56 +08:00
|
|
|
|
1998-01-17 06:23:43 +08:00
|
|
|
for (Loop = 0; Loop < Index; Loop++) {
|
|
|
|
if (Test[Loop].NumErrors == -1)
|
|
|
|
print_func("%16s %6s %s\n", Test[Loop].Name, "N/A", Test[Loop].Description);
|
|
|
|
else
|
|
|
|
print_func("%16s %6d %s\n", Test[Loop].Name, (int) Test[Loop].NumErrors,
|
|
|
|
Test[Loop].Description);
|
|
|
|
} /* end for */
|
|
|
|
print_func("\n\n");
|
|
|
|
} /* end if */
|
1998-07-11 06:00:26 +08:00
|
|
|
if (CleanUp && !getenv("HDF5_NOCLEANUP")) {
|
|
|
|
MESSAGE(2, ("\nCleaning Up temp files...\n\n"));
|
|
|
|
|
|
|
|
/* call individual cleanup routines in each source module */
|
|
|
|
for (Loop = 0; Loop < Index; Loop++)
|
|
|
|
if (!Test[Loop].SkipFlag && Test[Loop].Cleanup!=NULL)
|
|
|
|
(*Test[Loop].Cleanup) ();
|
|
|
|
}
|
1998-10-28 01:05:37 +08:00
|
|
|
return (num_errs);
|
1998-01-17 06:23:43 +08:00
|
|
|
} /* end main() */
|