Cloned library HDF5-1.14.1 with extra build files for internal package management.
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 
lib 42a6d127a4 Initial commit 2 years ago
..
driver Initial commit 2 years ago
CMakeLists.txt Initial commit 2 years ago
H5_api_async_test.c Initial commit 2 years ago
H5_api_async_test.h Initial commit 2 years ago
H5_api_attribute_test.c Initial commit 2 years ago
H5_api_attribute_test.h Initial commit 2 years ago
H5_api_dataset_test.c Initial commit 2 years ago
H5_api_dataset_test.h Initial commit 2 years ago
H5_api_datatype_test.c Initial commit 2 years ago
H5_api_datatype_test.h Initial commit 2 years ago
H5_api_file_test.c Initial commit 2 years ago
H5_api_file_test.h Initial commit 2 years ago
H5_api_group_test.c Initial commit 2 years ago
H5_api_group_test.h Initial commit 2 years ago
H5_api_link_test.c Initial commit 2 years ago
H5_api_link_test.h Initial commit 2 years ago
H5_api_misc_test.c Initial commit 2 years ago
H5_api_misc_test.h Initial commit 2 years ago
H5_api_object_test.c Initial commit 2 years ago
H5_api_object_test.h Initial commit 2 years ago
H5_api_test.c Initial commit 2 years ago
H5_api_test.h Initial commit 2 years ago
H5_api_test_config.h.in Initial commit 2 years ago
H5_api_test_util.c Initial commit 2 years ago
H5_api_test_util.h Initial commit 2 years ago
H5_api_tests_disabled.h Initial commit 2 years ago
README.md Initial commit 2 years ago
tarray.c Initial commit 2 years ago
tattr.c Initial commit 2 years ago
tchecksum.c Initial commit 2 years ago
tconfig.c Initial commit 2 years ago
tcoords.c Initial commit 2 years ago
testhdf5.c Initial commit 2 years ago
testhdf5.h Initial commit 2 years ago
tfile.c Initial commit 2 years ago
tgenprop.c Initial commit 2 years ago
th5o.c Initial commit 2 years ago
th5s.c Initial commit 2 years ago
tid.c Initial commit 2 years ago
titerate.c Initial commit 2 years ago
tmisc.c Initial commit 2 years ago
trefer.c Initial commit 2 years ago
tselect.c Initial commit 2 years ago
ttime.c Initial commit 2 years ago
tunicode.c Initial commit 2 years ago
tvlstr.c Initial commit 2 years ago
tvltypes.c Initial commit 2 years ago

README.md

HDF5 API Tests

This directory contains several test applications that exercise HDF5's public API and serve as regression tests for HDF5 VOL Connectors.

Build Process and options

These HDF5 API tests are disabled by default, but can be enabled by passing the -DHDF5_TEST_API=ON option to CMake. The following build options are available to influence how the API tests get built:

CMake

To set an option, it should be prepended with -D when passed to the cmake command. For example,

cmake -DHDF5_TEST_API=OFF ..

HDF5_TEST_API (Default: ON) - Determines whether the API tests will be built.

HDF5_TEST_API_INSTALL (Default: ON) - Determines whether the API tests should be installed on the system.

HDF5_TEST_API_ENABLE_ASYNC (Default: OFF) - Determines whether tests for HDF5's asynchronous I/O capabilities should be enabled. Note that the "native" HDF5 VOL connector doesn't support this functionality, so these tests are directed towards VOL connectors that do.

HDF5_TEST_ENABLE_DRIVER (Default: OFF) - Determines whether the API test driver program should be built. This driver program is useful when a VOL connector relies upon a server executable (as well as possible additional executables) in order to function. The driver program can be supplied with a server executable and

HDF5_TEST_API_SERVER (Default: empty string) - If HDF5_TEST_ENABLE_DRIVER is set to ON, this option should be edited to point to the server executable that the driver program should attempt to launch before running the API tests.

Autotools

Currently unsupported

Usage

These API tests currently only support usage with the native HDF5 VOL connector and HDF5 VOL connectors that can be loaded dynamically as a plugin. For information on how to build a VOL connector in this manner, refer to section 2.3 of the HDF5 VOL Connector Author Guide.

TODO: section on building VOL connectors alongside HDF5 for use with tests

These API tests can also be used to test an HDF5 VOL connector that is external to the library. For convenience, the HDF5_TEST_API_INSTALL option can be used to install these tests on the system where other HDF5 executables (such as h5dump) are installed.

To run these tests with your VOL connector, set the following two environment variables:

HDF5_VOL_CONNECTOR - This environment variable should be set to the name chosen for the VOL connector to be used. For example, HDF5's DAOS VOL connector uses the name "daos" and would therefore set:

HDF5_VOL_CONNECTOR=daos

HDF5_PLUGIN_PATH - This environment variable should be set to the directory that contains the built library for the VOL connector to be used.

Once these are set, the HDF5 API tests will attempt to automatically load the specified VOL connector and use it when running tests. If HDF5 is unable to locate or load the VOL connector specified, it will fall back to running the tests with the native HDF5 VOL connector and an error similar to the following will appear in the test output:

HDF5-DIAG: Error detected in HDF5 (X.XX.X) MPI-process 0:
  #000: /home/user/git/hdf5/src/H5.c line 1010 in H5open(): library initialization failed
    major: Function entry/exit
    minor: Unable to initialize object
  #001: /home/user/git/hdf5/src/H5.c line 277 in H5_init_library(): unable to initialize vol interface
    major: Function entry/exit
    minor: Unable to initialize object
  #002: /home/user/git/hdf5/src/H5VLint.c line 199 in H5VL_init_phase2(): unable to set default VOL connector
    major: Virtual Object Layer
    minor: Can't set value
  #003: /home/user/git/hdf5/src/H5VLint.c line 429 in H5VL__set_def_conn(): can't register connector
    major: Virtual Object Layer
    minor: Unable to register new ID
  #004: /home/user/git/hdf5/src/H5VLint.c line 1321 in H5VL__register_connector_by_name(): unable to load VOL connector
    major: Virtual Object Layer
    minor: Unable to initialize object

Help and Support

For help with building or using the HDF5 API tests, please contact the HDF Help Desk.