2003-04-01 01:59:04 +08:00
|
|
|
/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
|
2007-02-07 22:56:24 +08:00
|
|
|
* Copyright by The HDF Group. *
|
2003-04-01 01:59:04 +08:00
|
|
|
* All rights reserved. *
|
|
|
|
* *
|
|
|
|
* This file is part of HDF5. The full HDF5 copyright notice, including *
|
|
|
|
* terms governing use, modification, and redistribution, is contained in *
|
2017-04-18 03:32:16 +08:00
|
|
|
* the COPYING file, which can be found at the root of the source code *
|
2021-02-17 22:52:04 +08:00
|
|
|
* distribution tree, or in https://www.hdfgroup.org/licenses. *
|
2017-04-18 03:32:16 +08:00
|
|
|
* If you do not have access to either file, you may request a copy from *
|
|
|
|
* help@hdfgroup.org. *
|
2003-04-01 01:59:04 +08:00
|
|
|
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
|
|
|
|
|
1998-11-21 11:36:51 +08:00
|
|
|
/*
|
2020-08-07 08:58:07 +08:00
|
|
|
* Programmer: Robb Matzke
|
1998-11-21 11:36:51 +08:00
|
|
|
* Friday, November 20, 1998
|
|
|
|
*
|
|
|
|
* Purpose: Test support stuff.
|
|
|
|
*/
|
2021-02-23 12:29:56 +08:00
|
|
|
#ifndef H5TEST_H
|
|
|
|
#define H5TEST_H
|
1998-11-21 11:36:51 +08:00
|
|
|
|
2018-02-15 00:08:09 +08:00
|
|
|
/*
|
|
|
|
* Include required headers. This file tests internal library functions,
|
2021-07-10 05:27:10 +08:00
|
|
|
* so we include the private headers here.
|
2018-02-15 00:08:09 +08:00
|
|
|
*/
|
2001-04-04 02:09:16 +08:00
|
|
|
#include "hdf5.h"
|
|
|
|
#include "H5private.h"
|
2018-02-15 00:08:09 +08:00
|
|
|
#include "H5Eprivate.h"
|
1998-11-21 11:36:51 +08:00
|
|
|
|
2004-01-23 04:57:34 +08:00
|
|
|
/*
|
|
|
|
* Predefined test verbosity levels.
|
|
|
|
*
|
|
|
|
* Convention:
|
2005-08-14 04:53:35 +08:00
|
|
|
*
|
2004-01-23 04:57:34 +08:00
|
|
|
* The higher the verbosity value, the more information printed.
|
|
|
|
* So, output for higher verbosity also include output of all lower
|
|
|
|
* verbosity.
|
2005-08-14 04:53:35 +08:00
|
|
|
*
|
2004-01-23 04:57:34 +08:00
|
|
|
* Value Description
|
|
|
|
* 0 None: No informational message.
|
|
|
|
* 1 "All tests passed"
|
|
|
|
* 2 Header of overall test
|
|
|
|
* 3 Default: header and results of individual test
|
2005-08-14 04:53:35 +08:00
|
|
|
* 4
|
2004-01-23 04:57:34 +08:00
|
|
|
* 5 Low: Major category of tests.
|
|
|
|
* 6
|
|
|
|
* 7 Medium: Minor category of tests such as functions called.
|
|
|
|
* 8
|
|
|
|
* 9 High: Highest level. All information.
|
|
|
|
*/
|
2020-09-30 22:27:10 +08:00
|
|
|
#define VERBO_NONE 0 /* None */
|
|
|
|
#define VERBO_DEF 3 /* Default */
|
|
|
|
#define VERBO_LO 5 /* Low */
|
|
|
|
#define VERBO_MED 7 /* Medium */
|
|
|
|
#define VERBO_HI 9 /* High */
|
2004-01-23 04:57:34 +08:00
|
|
|
|
2004-01-23 07:05:55 +08:00
|
|
|
/*
|
|
|
|
* Verbose queries
|
|
|
|
* Only None needs an exact match. The rest are at least as much.
|
|
|
|
*/
|
2010-01-28 06:03:28 +08:00
|
|
|
|
|
|
|
/* A macro version of HDGetTestVerbosity(). */
|
|
|
|
/* Should be used internally by the libtest.a only. */
|
|
|
|
#define HDGetTestVerbosity() (TestVerbosity)
|
|
|
|
|
2020-09-30 22:27:10 +08:00
|
|
|
#define VERBOSE_NONE (HDGetTestVerbosity() == VERBO_NONE)
|
|
|
|
#define VERBOSE_DEF (HDGetTestVerbosity() >= VERBO_DEF)
|
|
|
|
#define VERBOSE_LO (HDGetTestVerbosity() >= VERBO_LO)
|
|
|
|
#define VERBOSE_MED (HDGetTestVerbosity() >= VERBO_MED)
|
|
|
|
#define VERBOSE_HI (HDGetTestVerbosity() >= VERBO_HI)
|
2004-01-23 07:05:55 +08:00
|
|
|
|
2004-04-04 05:35:01 +08:00
|
|
|
/*
|
|
|
|
* Test controls definitions.
|
|
|
|
*/
|
2020-09-30 22:27:10 +08:00
|
|
|
#define SKIPTEST 1 /* Skip this test */
|
|
|
|
#define ONLYTEST 2 /* Do only this test */
|
|
|
|
#define BEGINTEST 3 /* Skip all tests before this test */
|
2004-04-04 05:35:01 +08:00
|
|
|
|
2000-01-26 12:20:36 +08:00
|
|
|
/*
|
2019-08-16 05:46:00 +08:00
|
|
|
* This contains the filename prefix specified as command line option for
|
2005-08-14 04:53:35 +08:00
|
|
|
* the parallel test files.
|
2000-01-26 12:20:36 +08:00
|
|
|
*/
|
2010-11-20 01:45:55 +08:00
|
|
|
H5TEST_DLLVAR char *paraprefix;
|
2002-05-22 02:49:44 +08:00
|
|
|
#ifdef H5_HAVE_PARALLEL
|
2020-09-30 22:27:10 +08:00
|
|
|
H5TEST_DLLVAR MPI_Info h5_io_info_g; /* MPI INFO object for IO */
|
2002-05-22 02:49:44 +08:00
|
|
|
#endif
|
2000-01-26 12:20:36 +08:00
|
|
|
|
2003-04-14 19:21:18 +08:00
|
|
|
/*
|
|
|
|
* Print the current location on the standard output stream.
|
|
|
|
*/
|
2022-05-04 23:49:01 +08:00
|
|
|
#define AT() \
|
|
|
|
do { \
|
|
|
|
HDprintf(" at %s:%d in %s()...\n", __FILE__, __LINE__, __func__); \
|
|
|
|
} while (0)
|
2003-04-14 19:21:18 +08:00
|
|
|
|
1998-11-21 11:36:51 +08:00
|
|
|
/*
|
|
|
|
* The name of the test is printed by saying TESTING("something") which will
|
|
|
|
* result in the string `Testing something' being flushed to standard output.
|
2001-01-26 01:03:29 +08:00
|
|
|
* If a test passes, fails, or is skipped then the PASSED(), H5_FAILED(), or
|
|
|
|
* SKIPPED() macro should be called. After H5_FAILED() or SKIPPED() the caller
|
1998-11-21 11:36:51 +08:00
|
|
|
* should print additional information to stdout indented by at least four
|
|
|
|
* spaces. If the h5_errors() is used for automatic error handling then
|
2001-01-26 01:03:29 +08:00
|
|
|
* the H5_FAILED() macro is invoked automatically when an API function fails.
|
1998-11-21 11:36:51 +08:00
|
|
|
*/
|
2020-09-30 22:27:10 +08:00
|
|
|
#define TESTING(WHAT) \
|
2022-05-04 23:49:01 +08:00
|
|
|
do { \
|
2020-09-30 22:27:10 +08:00
|
|
|
HDprintf("Testing %-62s", WHAT); \
|
|
|
|
HDfflush(stdout); \
|
2022-05-04 23:49:01 +08:00
|
|
|
} while (0)
|
2020-09-30 22:27:10 +08:00
|
|
|
#define TESTING_2(WHAT) \
|
2022-05-04 23:49:01 +08:00
|
|
|
do { \
|
2020-09-30 22:27:10 +08:00
|
|
|
HDprintf(" Testing %-60s", WHAT); \
|
|
|
|
HDfflush(stdout); \
|
2022-05-04 23:49:01 +08:00
|
|
|
} while (0)
|
2020-09-30 22:27:10 +08:00
|
|
|
#define PASSED() \
|
|
|
|
do { \
|
|
|
|
HDputs(" PASSED"); \
|
|
|
|
HDfflush(stdout); \
|
|
|
|
} while (0)
|
|
|
|
#define H5_FAILED() \
|
2022-05-04 23:49:01 +08:00
|
|
|
do { \
|
2020-09-30 22:27:10 +08:00
|
|
|
HDputs("*FAILED*"); \
|
|
|
|
HDfflush(stdout); \
|
2022-05-04 23:49:01 +08:00
|
|
|
} while (0)
|
2020-09-30 22:27:10 +08:00
|
|
|
#define H5_WARNING() \
|
2022-05-04 23:49:01 +08:00
|
|
|
do { \
|
2020-09-30 22:27:10 +08:00
|
|
|
HDputs("*WARNING*"); \
|
|
|
|
HDfflush(stdout); \
|
2022-05-04 23:49:01 +08:00
|
|
|
} while (0)
|
2020-09-30 22:27:10 +08:00
|
|
|
#define SKIPPED() \
|
2022-05-04 23:49:01 +08:00
|
|
|
do { \
|
2020-09-30 22:27:10 +08:00
|
|
|
HDputs(" -SKIP-"); \
|
|
|
|
HDfflush(stdout); \
|
2022-05-04 23:49:01 +08:00
|
|
|
} while (0)
|
2020-09-30 22:27:10 +08:00
|
|
|
#define PUTS_ERROR(s) \
|
2022-05-04 23:49:01 +08:00
|
|
|
do { \
|
2020-09-30 22:27:10 +08:00
|
|
|
HDputs(s); \
|
|
|
|
AT(); \
|
|
|
|
goto error; \
|
2022-05-04 23:49:01 +08:00
|
|
|
} while (0)
|
2020-09-30 22:27:10 +08:00
|
|
|
#define TEST_ERROR \
|
2022-05-04 23:49:01 +08:00
|
|
|
do { \
|
2020-09-30 22:27:10 +08:00
|
|
|
H5_FAILED(); \
|
|
|
|
AT(); \
|
|
|
|
goto error; \
|
2022-05-04 23:49:01 +08:00
|
|
|
} while (0)
|
2020-09-30 22:27:10 +08:00
|
|
|
#define STACK_ERROR \
|
2022-05-04 23:49:01 +08:00
|
|
|
do { \
|
2020-09-30 22:27:10 +08:00
|
|
|
H5Eprint2(H5E_DEFAULT, stdout); \
|
|
|
|
goto error; \
|
2022-05-04 23:49:01 +08:00
|
|
|
} while (0)
|
2020-09-30 22:27:10 +08:00
|
|
|
#define FAIL_STACK_ERROR \
|
2022-05-04 23:49:01 +08:00
|
|
|
do { \
|
2020-09-30 22:27:10 +08:00
|
|
|
H5_FAILED(); \
|
|
|
|
AT(); \
|
|
|
|
H5Eprint2(H5E_DEFAULT, stdout); \
|
|
|
|
goto error; \
|
2022-05-04 23:49:01 +08:00
|
|
|
} while (0)
|
2020-09-30 22:27:10 +08:00
|
|
|
#define FAIL_PUTS_ERROR(s) \
|
2022-05-04 23:49:01 +08:00
|
|
|
do { \
|
2020-09-30 22:27:10 +08:00
|
|
|
H5_FAILED(); \
|
|
|
|
AT(); \
|
|
|
|
HDputs(s); \
|
|
|
|
goto error; \
|
2022-05-04 23:49:01 +08:00
|
|
|
} while (0)
|
1998-11-21 11:36:51 +08:00
|
|
|
|
2021-06-29 12:59:25 +08:00
|
|
|
/* Number of seconds to wait before killing a test (requires alarm(2)) */
|
2020-09-30 22:27:10 +08:00
|
|
|
#define H5_ALARM_SEC 1200 /* default is 20 minutes */
|
2005-09-20 04:32:18 +08:00
|
|
|
|
2019-01-06 13:06:45 +08:00
|
|
|
/* Flags for h5_fileaccess_flags() */
|
2021-09-30 02:28:12 +08:00
|
|
|
#define H5_FILEACCESS_LIBVER 0x01
|
|
|
|
|
|
|
|
/* Flags for h5_driver_uses_multiple_files() */
|
|
|
|
#define H5_EXCLUDE_MULTIPART_DRIVERS 0x01
|
|
|
|
#define H5_EXCLUDE_NON_MULTIPART_DRIVERS 0x02
|
2019-01-06 13:06:45 +08:00
|
|
|
|
2021-11-23 22:09:05 +08:00
|
|
|
/* Fill an array on the heap with an increasing count value. BUF
|
|
|
|
* is expected to point to a `struct { TYPE arr[...][...]; }`.
|
2020-04-26 07:49:04 +08:00
|
|
|
*/
|
2021-11-23 22:09:05 +08:00
|
|
|
#define H5TEST_FILL_2D_HEAP_ARRAY(BUF, TYPE) \
|
2020-09-30 22:27:10 +08:00
|
|
|
do { \
|
|
|
|
/* Prefix with h5tfa to avoid shadow warnings */ \
|
2021-11-23 22:09:05 +08:00
|
|
|
size_t h5tfa_i = 0; \
|
|
|
|
size_t h5tfa_j = 0; \
|
|
|
|
TYPE h5tfa_count = 0; \
|
2020-09-30 22:27:10 +08:00
|
|
|
\
|
2021-11-23 22:09:05 +08:00
|
|
|
for (h5tfa_i = 0; h5tfa_i < NELMTS((BUF)->arr); h5tfa_i++) \
|
|
|
|
for (h5tfa_j = 0; h5tfa_j < NELMTS((BUF)->arr[0]); h5tfa_j++) { \
|
|
|
|
(BUF)->arr[h5tfa_i][h5tfa_j] = h5tfa_count; \
|
2020-09-30 22:27:10 +08:00
|
|
|
h5tfa_count++; \
|
|
|
|
} \
|
|
|
|
} while (0)
|
2020-04-26 07:49:04 +08:00
|
|
|
|
1998-11-21 11:36:51 +08:00
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
2022-05-02 04:54:41 +08:00
|
|
|
/*
|
|
|
|
* Ugly hack to cast away const for freeing const-qualified pointers.
|
|
|
|
* Should only be used sparingly, where the alternative (like keeping
|
|
|
|
* an equivalent non-const pointer around) is far messier.
|
|
|
|
*/
|
|
|
|
#ifndef h5_free_const
|
|
|
|
#define h5_free_const(mem) HDfree((void *)(uintptr_t)mem)
|
|
|
|
#endif
|
|
|
|
|
2004-01-07 01:53:13 +08:00
|
|
|
/* Generally useful testing routines */
|
2020-09-30 22:27:10 +08:00
|
|
|
H5TEST_DLL void h5_clean_files(const char *base_name[], hid_t fapl);
|
|
|
|
H5TEST_DLL int h5_cleanup(const char *base_name[], hid_t fapl);
|
2022-07-27 05:45:46 +08:00
|
|
|
H5TEST_DLL char *h5_fixname(const char *base_name, hid_t fapl, char *fullname, size_t size);
|
|
|
|
H5TEST_DLL char *h5_fixname_superblock(const char *base_name, hid_t fapl, char *fullname, size_t size);
|
|
|
|
H5TEST_DLL char *h5_fixname_no_suffix(const char *base_name, hid_t fapl, char *fullname, size_t size);
|
|
|
|
H5TEST_DLL char *h5_fixname_printf(const char *base_name, hid_t fapl, char *fullname, size_t size);
|
2020-09-30 22:27:10 +08:00
|
|
|
H5TEST_DLL hid_t h5_fileaccess(void);
|
|
|
|
H5TEST_DLL hid_t h5_fileaccess_flags(unsigned flags);
|
|
|
|
H5TEST_DLL void h5_no_hwconv(void);
|
2006-10-02 18:24:03 +08:00
|
|
|
H5TEST_DLL const char *h5_rmprefix(const char *filename);
|
2020-09-30 22:27:10 +08:00
|
|
|
H5TEST_DLL void h5_reset(void);
|
|
|
|
H5TEST_DLL void h5_restore_err(void);
|
|
|
|
H5TEST_DLL void h5_show_hostname(void);
|
[svn-r15825] Description:
Fix various problems with a the core & sec2 VFDs.
Improve the h5_get_file_size() routine to handle files created with
VFDs that use multiple files.
Tested on:
Mac OS X/32 10.5.5 (amazon) in debug mode
Mac OS X/32 10.5.5 (amazon) w/C++ & FORTRAN, w/threadsafe,
in production mode
FreeBSD/32 6.3 (duty) in debug mode
FreeBSD/64 6.3 (liberty) w/C++ & FORTRAN, in debug mode
Linux/32 2.6 (kagiso) w/PGI compilers, w/C++ & FORTRAN, w/threadsafe,
in debug mode
Linux/64-amd64 2.6 (smirom) w/Intel compilers w/default API=1.6.x,
w/C++ & FORTRAN, in production mode
Solaris/32 2.10 (linew) w/deprecated symbols disabled, w/C++ & FORTRAN,
w/szip filter, in production mode
Linux/64-ia64 2.6 (cobalt) w/Intel compilers, w/C++ & FORTRAN,
in production mode
Linux/64-ia64 2.4 (tg-login3) w/parallel, w/FORTRAN, in production mode
Linux/64-amd64 2.6 (abe) w/parallel, w/FORTRAN, in production mode
2008-10-09 11:44:22 +08:00
|
|
|
H5TEST_DLL h5_stat_size_t h5_get_file_size(const char *filename, hid_t fapl);
|
2022-07-11 23:29:46 +08:00
|
|
|
H5TEST_DLL int print_func(const char *format, ...) H5_ATTR_FORMAT(printf, 1, 2);
|
2020-09-30 22:27:10 +08:00
|
|
|
H5TEST_DLL int h5_make_local_copy(const char *origfilename, const char *local_copy_name);
|
|
|
|
H5TEST_DLL herr_t h5_verify_cached_stabs(const char *base_name[], hid_t fapl);
|
2022-07-27 05:45:46 +08:00
|
|
|
H5TEST_DLL H5FD_class_t *h5_get_dummy_vfd_class(void);
|
|
|
|
H5TEST_DLL H5VL_class_t *h5_get_dummy_vol_class(void);
|
|
|
|
H5TEST_DLL const char *h5_get_version_string(H5F_libver_t libver);
|
|
|
|
H5TEST_DLL int h5_compare_file_bytes(char *fname1, char *fname2);
|
|
|
|
H5TEST_DLL int h5_duplicate_file_by_bytes(const char *orig, const char *dest);
|
|
|
|
H5TEST_DLL herr_t h5_check_if_file_locking_enabled(hbool_t *are_enabled);
|
|
|
|
H5TEST_DLL hbool_t h5_using_default_driver(const char *drv_name);
|
|
|
|
H5TEST_DLL herr_t h5_using_parallel_driver(hid_t fapl_id, hbool_t *driver_is_parallel);
|
|
|
|
H5TEST_DLL herr_t h5_driver_is_default_vfd_compatible(hid_t fapl_id, hbool_t *default_vfd_compatible);
|
|
|
|
H5TEST_DLL hbool_t h5_driver_uses_multiple_files(const char *drv_name, unsigned flags);
|
2004-01-07 01:53:13 +08:00
|
|
|
|
2018-11-29 07:38:03 +08:00
|
|
|
/* Functions that will replace components of a FAPL */
|
|
|
|
H5TEST_DLL herr_t h5_get_libver_fapl(hid_t fapl_id);
|
2016-02-17 12:30:49 +08:00
|
|
|
|
|
|
|
/* h5_clean_files() replacements */
|
|
|
|
H5TEST_DLL void h5_delete_test_file(const char *base_name, hid_t fapl);
|
|
|
|
H5TEST_DLL void h5_delete_all_test_files(const char *base_name[], hid_t fapl);
|
|
|
|
|
|
|
|
/* h5_reset() replacement */
|
|
|
|
H5TEST_DLL void h5_test_init(void);
|
|
|
|
|
|
|
|
/* h5_cleanup() replacement */
|
|
|
|
H5TEST_DLL void h5_test_shutdown(void);
|
|
|
|
|
2004-03-23 12:43:12 +08:00
|
|
|
/* Routines for operating on the list of tests (for the "all in one" tests) */
|
2020-09-30 22:27:10 +08:00
|
|
|
H5TEST_DLL void TestUsage(void);
|
|
|
|
H5TEST_DLL void AddTest(const char *TheName, void (*TheCall)(void), void (*Cleanup)(void),
|
|
|
|
const char *TheDescr, const void *Parameters);
|
|
|
|
H5TEST_DLL void TestInfo(const char *ProgName);
|
|
|
|
H5TEST_DLL void TestParseCmdLine(int argc, char *argv[]);
|
|
|
|
H5TEST_DLL void PerformTests(void);
|
|
|
|
H5TEST_DLL void TestSummary(void);
|
|
|
|
H5TEST_DLL void TestCleanup(void);
|
|
|
|
H5TEST_DLL void TestShutdown(void);
|
|
|
|
H5TEST_DLL void TestInit(const char *ProgName, void (*private_usage)(void),
|
|
|
|
int (*private_parser)(int ac, char *av[]));
|
|
|
|
H5TEST_DLL int GetTestVerbosity(void);
|
|
|
|
H5TEST_DLL int SetTestVerbosity(int newval);
|
|
|
|
H5TEST_DLL int GetTestSummary(void);
|
|
|
|
H5TEST_DLL int GetTestCleanup(void);
|
|
|
|
H5TEST_DLL int SetTestNoCleanup(void);
|
|
|
|
H5TEST_DLL int GetTestExpress(void);
|
|
|
|
H5TEST_DLL int SetTestExpress(int newval);
|
|
|
|
H5TEST_DLL void ParseTestVerbosity(char *argv);
|
|
|
|
H5TEST_DLL int GetTestNumErrs(void);
|
|
|
|
H5TEST_DLL void IncTestNumErrs(void);
|
2004-08-08 10:26:44 +08:00
|
|
|
H5TEST_DLL const void *GetTestParameters(void);
|
2020-09-30 22:27:10 +08:00
|
|
|
H5TEST_DLL int TestErrPrintf(const char *format, ...) H5_ATTR_FORMAT(printf, 1, 2);
|
|
|
|
H5TEST_DLL void SetTest(const char *testname, int action);
|
|
|
|
H5TEST_DLL void TestAlarmOn(void);
|
|
|
|
H5TEST_DLL void TestAlarmOff(void);
|
2004-04-04 05:35:01 +08:00
|
|
|
|
2005-08-14 04:53:35 +08:00
|
|
|
#ifdef H5_HAVE_FILTER_SZIP
|
2004-11-03 03:12:06 +08:00
|
|
|
H5TEST_DLL int h5_szip_can_encode(void);
|
|
|
|
#endif /* H5_HAVE_FILTER_SZIP */
|
|
|
|
|
2002-06-13 02:24:25 +08:00
|
|
|
#ifdef H5_HAVE_PARALLEL
|
2020-09-30 22:27:10 +08:00
|
|
|
H5TEST_DLL int h5_set_info_object(void);
|
|
|
|
H5TEST_DLL void h5_dump_info_object(MPI_Info info);
|
|
|
|
H5TEST_DLL char *getenv_all(MPI_Comm comm, int root, const char *name);
|
2002-05-22 02:49:44 +08:00
|
|
|
#endif
|
1998-11-21 11:36:51 +08:00
|
|
|
|
2010-01-28 06:03:28 +08:00
|
|
|
/* Extern global variables */
|
|
|
|
H5TEST_DLLVAR int TestVerbosity;
|
|
|
|
|
2020-09-30 22:27:10 +08:00
|
|
|
H5TEST_DLL void h5_send_message(const char *file, const char *arg1, const char *arg2);
|
2016-12-20 12:44:54 +08:00
|
|
|
H5TEST_DLL herr_t h5_wait_message(const char *file);
|
|
|
|
|
1998-11-21 11:36:51 +08:00
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
#endif
|