hdf5/test/API/H5_api_file_test.c
Larry Knox 145e962bce
Replace support.hdfgroup.org URLs for alternative COPYING file (#3228)
* Replace support.hdfgroup.org URLs for alternative COPYING file
locations in copyright headers with https://www.hdfgroup.org/licenses.
Replace  support.hdfgroup.org URL for alternative COPYING_LBNL_HDF5
with github URL.
Tweak chkcopyright script for change from UICOPYRIGHTSTR to
THGCOPYRIGHTSTR.
2023-07-12 17:33:58 -05:00

2540 lines
75 KiB
C

/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
* Copyright by The HDF Group. *
* 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://www.hdfgroup.org/licenses. *
* If you do not have access to either file, you may request a copy from *
* help@hdfgroup.org. *
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
#include "H5_api_file_test.h"
static int test_create_file(void);
static int test_create_file_invalid_params(void);
static int test_create_file_excl(void);
static int test_open_file(void);
static int test_open_file_invalid_params(void);
static int test_open_nonexistent_file(void);
static int test_file_open_overlap(void);
static int test_file_permission(void);
static int test_reopen_file(void);
static int test_close_file_invalid_id(void);
static int test_flush_file(void);
static int test_file_is_accessible(void);
static int test_file_property_lists(void);
static int test_get_file_intent(void);
static int test_get_file_obj_count(void);
static int test_file_mounts(void);
static int test_get_file_name(void);
/*
* The array of file tests to be performed.
*/
static int (*file_tests[])(void) = {
test_create_file,
test_create_file_invalid_params,
test_create_file_excl,
test_open_file,
test_open_file_invalid_params,
test_open_nonexistent_file,
test_file_open_overlap,
test_file_permission,
test_reopen_file,
test_close_file_invalid_id,
test_flush_file,
test_file_is_accessible,
test_file_property_lists,
test_get_file_intent,
test_get_file_obj_count,
test_file_mounts,
test_get_file_name,
};
/*
* Tests that a file can be created.
*/
static int
test_create_file(void)
{
hid_t file_id = H5I_INVALID_HID;
char *prefixed_filename = NULL;
TESTING("H5Fcreate");
/* Make sure the connector supports the API functions being tested */
if (!(vol_cap_flags_g & H5VL_CAP_FLAG_FILE_BASIC)) {
SKIPPED();
printf(" API functions for basic file aren't supported with this connector\n");
return 0;
}
if (prefix_filename(test_path_prefix, FILE_CREATE_TEST_FILENAME, &prefixed_filename) < 0) {
H5_FAILED();
printf(" couldn't prefix filename\n");
goto error;
}
if ((file_id = H5Fcreate(prefixed_filename, H5F_ACC_TRUNC, H5P_DEFAULT, H5P_DEFAULT)) < 0) {
H5_FAILED();
printf(" couldn't create file '%s'\n", prefixed_filename);
goto error;
}
if (H5Fclose(file_id) < 0)
TEST_ERROR;
free(prefixed_filename);
prefixed_filename = NULL;
PASSED();
return 0;
error:
H5E_BEGIN_TRY
{
H5Fclose(file_id);
}
H5E_END_TRY;
free(prefixed_filename);
return 1;
}
/*
* Tests that a file can't be created when H5Fcreate is passed
* invalid parameters.
*/
static int
test_create_file_invalid_params(void)
{
hid_t file_id = H5I_INVALID_HID;
char *prefixed_filename = NULL;
TESTING_MULTIPART("H5Fcreate with invalid parameters");
/* Make sure the connector supports the API functions being tested */
if (!(vol_cap_flags_g & H5VL_CAP_FLAG_FILE_BASIC)) {
SKIPPED();
printf(" API functions for basic file aren't supported with this connector\n");
return 0;
}
if (prefix_filename(test_path_prefix, FILE_CREATE_INVALID_PARAMS_FILE_NAME, &prefixed_filename) < 0) {
H5_FAILED();
printf(" couldn't prefix filename\n");
goto error;
}
BEGIN_MULTIPART
{
PART_BEGIN(H5Fcreate_invalid_name)
{
TESTING_2("H5Fcreate with invalid file name");
H5E_BEGIN_TRY
{
file_id = H5Fcreate(NULL, H5F_ACC_TRUNC, H5P_DEFAULT, H5P_DEFAULT);
}
H5E_END_TRY;
if (file_id >= 0) {
H5_FAILED();
printf(" file was created with a NULL name!\n");
H5Fclose(file_id);
PART_ERROR(H5Fcreate_invalid_name);
}
H5E_BEGIN_TRY
{
file_id = H5Fcreate("", H5F_ACC_TRUNC, H5P_DEFAULT, H5P_DEFAULT);
}
H5E_END_TRY;
if (file_id >= 0) {
H5_FAILED();
printf(" file was created with an invalid name of ''!\n");
H5Fclose(file_id);
PART_ERROR(H5Fcreate_invalid_name);
}
PASSED();
}
PART_END(H5Fcreate_invalid_name);
PART_BEGIN(H5Fcreate_invalid_flags)
{
TESTING_2("H5Fcreate with invalid flags");
H5E_BEGIN_TRY
{
file_id = H5Fcreate(prefixed_filename, H5F_ACC_RDWR, H5P_DEFAULT, H5P_DEFAULT);
}
H5E_END_TRY;
if (file_id >= 0) {
H5_FAILED();
printf(" file was created with invalid flag H5F_ACC_RDWR!\n");
H5Fclose(file_id);
PART_ERROR(H5Fcreate_invalid_flags);
}
H5E_BEGIN_TRY
{
file_id = H5Fcreate(prefixed_filename, H5F_ACC_CREAT, H5P_DEFAULT, H5P_DEFAULT);
}
H5E_END_TRY;
if (file_id >= 0) {
H5_FAILED();
printf(" file was created with invalid flag H5F_ACC_CREAT!\n");
H5Fclose(file_id);
PART_ERROR(H5Fcreate_invalid_flags);
}
H5E_BEGIN_TRY
{
file_id = H5Fcreate(prefixed_filename, H5F_ACC_SWMR_READ, H5P_DEFAULT, H5P_DEFAULT);
}
H5E_END_TRY;
if (file_id >= 0) {
H5_FAILED();
printf(" file was created with invalid flag H5F_ACC_SWMR_READ!\n");
H5Fclose(file_id);
PART_ERROR(H5Fcreate_invalid_flags);
}
PASSED();
}
PART_END(H5Fcreate_invalid_flags);
PART_BEGIN(H5Fcreate_invalid_fcpl)
{
TESTING_2("H5Fcreate with invalid FCPL");
H5E_BEGIN_TRY
{
file_id = H5Fcreate(prefixed_filename, H5F_ACC_TRUNC, H5I_INVALID_HID, H5P_DEFAULT);
}
H5E_END_TRY;
if (file_id >= 0) {
H5_FAILED();
printf(" file was created with invalid FCPL!\n");
H5Fclose(file_id);
PART_ERROR(H5Fcreate_invalid_fcpl);
}
PASSED();
}
PART_END(H5Fcreate_invalid_fcpl);
}
END_MULTIPART;
free(prefixed_filename);
prefixed_filename = NULL;
return 0;
error:
H5E_BEGIN_TRY
{
/* Attempt to remove the file if it ended up being created. */
H5Fdelete(prefixed_filename, H5P_DEFAULT);
H5Fclose(file_id);
}
H5E_END_TRY;
free(prefixed_filename);
return 1;
}
/*
* Tests that file creation will fail when a file is created
* using the H5F_ACC_EXCL flag while the file already exists.
*/
static int
test_create_file_excl(void)
{
hid_t file_id = H5I_INVALID_HID;
hid_t file_id2 = H5I_INVALID_HID;
char *prefixed_filename = NULL;
TESTING("H5Fcreate with H5F_ACC_EXCL/H5F_ACC_TRUNC flag");
/* Make sure the connector supports the API functions being tested */
if (!(vol_cap_flags_g & H5VL_CAP_FLAG_FILE_BASIC)) {
SKIPPED();
printf(" API functions for basic file aren't supported with this connector\n");
return 0;
}
if (prefix_filename(test_path_prefix, FILE_CREATE_EXCL_FILE_NAME, &prefixed_filename) < 0) {
H5_FAILED();
printf(" couldn't prefix filename\n");
goto error;
}
if ((file_id = H5Fcreate(prefixed_filename, H5F_ACC_EXCL, H5P_DEFAULT, H5P_DEFAULT)) < 0) {
H5_FAILED();
printf(" couldn't create first file\n");
goto error;
}
/* Close the file */
if (H5Fclose(file_id) < 0)
TEST_ERROR;
/* Try again with H5F_ACC_EXCL. This should fail because the file already
* exists on disk from the previous steps.
*/
H5E_BEGIN_TRY
{
file_id = H5Fcreate(prefixed_filename, H5F_ACC_EXCL, H5P_DEFAULT, H5P_DEFAULT);
}
H5E_END_TRY;
if (file_id >= 0) {
H5_FAILED();
printf(" created already existing file using H5F_ACC_EXCL flag!\n");
goto error;
}
/* Test creating with H5F_ACC_TRUNC. This will truncate the existing file on disk. */
if ((file_id = H5Fcreate(prefixed_filename, H5F_ACC_TRUNC, H5P_DEFAULT, H5P_DEFAULT)) < 0) {
H5_FAILED();
printf(" couldn't truncate the existing file\n");
goto error;
}
if (H5Fclose(file_id) < 0)
TEST_ERROR;
free(prefixed_filename);
prefixed_filename = NULL;
PASSED();
return 0;
error:
H5E_BEGIN_TRY
{
H5Fclose(file_id);
H5Fclose(file_id2);
}
H5E_END_TRY;
free(prefixed_filename);
return 1;
}
/*
* Tests that a file can be opened.
*/
static int
test_open_file(void)
{
hid_t file_id = H5I_INVALID_HID;
TESTING_MULTIPART("H5Fopen");
/* Make sure the connector supports the API functions being tested */
if (!(vol_cap_flags_g & H5VL_CAP_FLAG_FILE_BASIC)) {
SKIPPED();
printf(" API functions for basic file aren't supported with this connector\n");
return 0;
}
BEGIN_MULTIPART
{
PART_BEGIN(H5Fopen_rdonly)
{
TESTING_2("H5Fopen in read-only mode");
if ((file_id = H5Fopen(H5_api_test_filename, H5F_ACC_RDONLY, H5P_DEFAULT)) < 0) {
H5_FAILED();
printf(" unable to open file '%s' in read-only mode\n", H5_api_test_filename);
PART_ERROR(H5Fopen_rdonly);
}
PASSED();
}
PART_END(H5Fopen_rdonly);
if (file_id >= 0) {
H5E_BEGIN_TRY
{
H5Fclose(file_id);
}
H5E_END_TRY;
file_id = H5I_INVALID_HID;
}
PART_BEGIN(H5Fopen_rdwrite)
{
TESTING_2("H5Fopen in read-write mode");
if ((file_id = H5Fopen(H5_api_test_filename, H5F_ACC_RDWR, H5P_DEFAULT)) < 0) {
H5_FAILED();
printf(" unable to open file '%s' in read-write mode\n", H5_api_test_filename);
PART_ERROR(H5Fopen_rdwrite);
}
PASSED();
}
PART_END(H5Fopen_rdwrite);
if (file_id >= 0) {
H5E_BEGIN_TRY
{
H5Fclose(file_id);
}
H5E_END_TRY;
file_id = H5I_INVALID_HID;
}
/*
* XXX: SWMR open flags
*/
}
END_MULTIPART;
return 0;
error:
H5E_BEGIN_TRY
{
H5Fclose(file_id);
}
H5E_END_TRY;
return 1;
}
/*
* Tests that a file can't be opened when H5Fopen is given
* invalid parameters.
*/
static int
test_open_file_invalid_params(void)
{
hid_t file_id = H5I_INVALID_HID;
TESTING_MULTIPART("H5Fopen with invalid parameters");
/* Make sure the connector supports the API functions being tested */
if (!(vol_cap_flags_g & H5VL_CAP_FLAG_FILE_BASIC)) {
SKIPPED();
printf(" API functions for basic file aren't supported with this connector\n");
return 0;
}
BEGIN_MULTIPART
{
PART_BEGIN(H5Fopen_invalid_name)
{
TESTING_2("H5Fopen with invalid file name");
H5E_BEGIN_TRY
{
file_id = H5Fopen(NULL, H5F_ACC_RDWR, H5P_DEFAULT);
}
H5E_END_TRY;
if (file_id >= 0) {
H5_FAILED();
printf(" file was opened with a NULL name!\n");
H5Fclose(file_id);
PART_ERROR(H5Fopen_invalid_name);
}
H5E_BEGIN_TRY
{
file_id = H5Fopen("", H5F_ACC_RDWR, H5P_DEFAULT);
}
H5E_END_TRY;
if (file_id >= 0) {
H5_FAILED();
printf(" file was opened with an invalid name of ''!\n");
H5Fclose(file_id);
PART_ERROR(H5Fopen_invalid_name);
}
PASSED();
}
PART_END(H5Fopen_invalid_name);
PART_BEGIN(H5Fopen_invalid_flags)
{
TESTING_2("H5Fopen with invalid flags");
H5E_BEGIN_TRY
{
file_id = H5Fopen(H5_api_test_filename, H5F_ACC_TRUNC, H5P_DEFAULT);
}
H5E_END_TRY;
if (file_id >= 0) {
H5_FAILED();
printf(" file was opened with invalid flag H5F_ACC_TRUNC!\n");
H5Fclose(file_id);
PART_ERROR(H5Fopen_invalid_flags);
}
H5E_BEGIN_TRY
{
file_id = H5Fopen(H5_api_test_filename, H5F_ACC_EXCL, H5P_DEFAULT);
}
H5E_END_TRY;
if (file_id >= 0) {
H5_FAILED();
printf(" file was opened with invalid flag H5F_ACC_EXCL!\n");
H5Fclose(file_id);
PART_ERROR(H5Fopen_invalid_flags);
}
PASSED();
}
PART_END(H5Fopen_invalid_flags);
}
END_MULTIPART;
return 0;
error:
H5E_BEGIN_TRY
{
H5Fclose(file_id);
}
H5E_END_TRY;
return 1;
}
/*
* A test to ensure that opening a file which doesn't exist will fail.
*/
static int
test_open_nonexistent_file(void)
{
hid_t file_id = H5I_INVALID_HID;
char *prefixed_filename = NULL;
TESTING("for invalid opening of a non-existent file");
/* Make sure the connector supports the API functions being tested */
if (!(vol_cap_flags_g & H5VL_CAP_FLAG_FILE_BASIC)) {
SKIPPED();
printf(" API functions for basic file aren't supported with this connector\n");
return 0;
}
if (prefix_filename(test_path_prefix, NONEXISTENT_FILENAME, &prefixed_filename) < 0) {
H5_FAILED();
printf(" couldn't prefix filename\n");
goto error;
}
/* XXX: Make sure to first delete the file so we know for sure it doesn't exist */
H5E_BEGIN_TRY
{
file_id = H5Fopen(prefixed_filename, H5F_ACC_RDWR, H5P_DEFAULT);
}
H5E_END_TRY;
if (file_id >= 0) {
H5_FAILED();
printf(" non-existent file was opened!\n");
goto error;
}
free(prefixed_filename);
prefixed_filename = NULL;
PASSED();
return 0;
error:
H5E_BEGIN_TRY
{
H5Fclose(file_id);
}
H5E_END_TRY;
free(prefixed_filename);
return 1;
}
/*
* Tests that a file can be opened read-only or read-write
* and things are handled appropriately.
*/
static int
test_file_permission(void)
{
hid_t file_id = H5I_INVALID_HID;
hid_t dset_id = H5I_INVALID_HID;
hid_t dspace_id = H5I_INVALID_HID;
hid_t group_id = H5I_INVALID_HID;
hid_t attr_id = H5I_INVALID_HID;
hid_t dtype_id = H5I_INVALID_HID;
char *prefixed_filename = NULL;
herr_t h5_ret = FAIL;
TESTING_MULTIPART("file permissions (invalid creation of objects in read-only file)");
/* Make sure the connector supports the API functions being tested */
if (!(vol_cap_flags_g & (H5VL_CAP_FLAG_FILE_BASIC)) || !(vol_cap_flags_g & H5VL_CAP_FLAG_GROUP_BASIC) ||
!(vol_cap_flags_g & H5VL_CAP_FLAG_DATASET_BASIC) || !(vol_cap_flags_g & H5VL_CAP_FLAG_ATTR_BASIC) ||
!(vol_cap_flags_g & H5VL_CAP_FLAG_STORED_DATATYPES)) {
SKIPPED();
printf(" API functions for basic file, group, dataset, attribute, or stored datatype aren't "
"supported with this connector\n");
return 0;
}
TESTING_2("test setup");
if (prefix_filename(test_path_prefix, FILE_PERMISSION_TEST_FILENAME, &prefixed_filename) < 0) {
H5_FAILED();
printf(" couldn't prefix filename\n");
goto error;
}
if ((file_id = H5Fcreate(prefixed_filename, H5F_ACC_TRUNC, H5P_DEFAULT, H5P_DEFAULT)) < 0) {
H5_FAILED();
printf(" couldn't create file '%s'\n", prefixed_filename);
goto error;
}
if ((dspace_id = H5Screate(H5S_SCALAR)) < 0) {
H5_FAILED();
printf(" couldn't create data space\n");
goto error;
}
if ((dset_id = H5Dcreate2(file_id, FILE_PERMISSION_TEST_DSET_NAME, H5T_STD_U32LE, dspace_id, H5P_DEFAULT,
H5P_DEFAULT, H5P_DEFAULT)) < 0) {
H5_FAILED();
printf(" couldn't create data set: %s\n", FILE_PERMISSION_TEST_DSET_NAME);
goto error;
}
if (H5Dclose(dset_id) < 0)
TEST_ERROR;
if (H5Fclose(file_id) < 0)
TEST_ERROR;
/* Open the file (with read-only permission) */
if ((file_id = H5Fopen(prefixed_filename, H5F_ACC_RDONLY, H5P_DEFAULT)) < 0) {
H5_FAILED();
printf(" couldn't open file\n");
goto error;
}
PASSED();
BEGIN_MULTIPART
{
PART_BEGIN(H5Gcreate_rdonly_file)
{
TESTING_2("invalid creation of group in read-only file");
/* Create a group with the read-only file handle (should fail) */
H5E_BEGIN_TRY
{
group_id =
H5Gcreate2(file_id, FILE_PERMISSION_TEST_GRP_NAME, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT);
}
H5E_END_TRY;
if (group_id >= 0) {
H5_FAILED();
printf(" a group was created in a read-only file!\n");
PART_ERROR(H5Gcreate_rdonly_file);
}
H5E_BEGIN_TRY
{
group_id = H5Gcreate_anon(file_id, H5P_DEFAULT, H5P_DEFAULT);
}
H5E_END_TRY;
if (group_id >= 0) {
H5_FAILED();
printf(" a group was created in a read-only file!\n");
PART_ERROR(H5Gcreate_rdonly_file);
}
PASSED();
}
PART_END(H5Gcreate_rdonly_file);
PART_BEGIN(H5Dcreate_rdonly_file)
{
TESTING_2("invalid creation of dataset in read-only file");
/* Create a dataset with the read-only file handle (should fail) */
H5E_BEGIN_TRY
{
dset_id = H5Dcreate2(file_id, FILE_PERMISSION_TEST_DSET2_NAME, H5T_STD_U32LE, dspace_id,
H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT);
}
H5E_END_TRY;
if (dset_id >= 0) {
H5_FAILED();
printf(" a dataset was created in a read-only file!\n");
PART_ERROR(H5Dcreate_rdonly_file);
}
H5E_BEGIN_TRY
{
dset_id = H5Dcreate_anon(file_id, H5T_STD_U32LE, dspace_id, H5P_DEFAULT, H5P_DEFAULT);
}
H5E_END_TRY;
if (dset_id >= 0) {
H5_FAILED();
printf(" a dataset was created in a read-only file!\n");
PART_ERROR(H5Dcreate_rdonly_file);
}
PASSED();
}
PART_END(H5Dcreate_rdonly_file);
PART_BEGIN(H5Acreate_rdonly_file)
{
TESTING_2("invalid creation of attribute in read-only file");
/* Create an attribute with the read-only file handle (should fail) */
H5E_BEGIN_TRY
{
attr_id = H5Acreate2(file_id, FILE_PERMISSION_TEST_ATTR_NAME, H5T_NATIVE_INT, dspace_id,
H5P_DEFAULT, H5P_DEFAULT);
}
H5E_END_TRY;
if (attr_id >= 0) {
H5_FAILED();
printf(" an attribute was created in a read-only file!\n");
PART_ERROR(H5Acreate_rdonly_file);
}
PASSED();
}
PART_END(H5Acreate_rdonly_file);
PART_BEGIN(H5Tcommit_rdonly_file)
{
TESTING_2("invalid creation of committed datatype in read-only file");
if ((dtype_id = H5Tcopy(H5T_NATIVE_INT)) < 0) {
H5_FAILED();
printf(" couldn't copy a native datatype\n");
PART_ERROR(H5Tcommit_rdonly_file);
}
/* Commit a datatype with the read-only file handle (should fail) */
H5E_BEGIN_TRY
{
h5_ret = H5Tcommit2(file_id, FILE_PERMISSION_TEST_NAMED_DTYPE, dtype_id, H5P_DEFAULT,
H5P_DEFAULT, H5P_DEFAULT);
}
H5E_END_TRY;
if (h5_ret >= 0) {
H5_FAILED();
printf(" a named datatype was committed in a read-only file!\n");
PART_ERROR(H5Tcommit_rdonly_file);
}
H5E_BEGIN_TRY
{
h5_ret = H5Tcommit_anon(file_id, dtype_id, H5P_DEFAULT, H5P_DEFAULT);
}
H5E_END_TRY;
if (h5_ret >= 0) {
H5_FAILED();
printf(" a named datatype was committed in a read-only file!\n");
PART_ERROR(H5Tcommit_rdonly_file);
}
PASSED();
}
PART_END(H5Tcommit_rdonly_file);
}
END_MULTIPART;
TESTING_2("test cleanup");
if (H5Tclose(dtype_id) < 0)
TEST_ERROR;
if (H5Sclose(dspace_id) < 0)
TEST_ERROR;
if (H5Fclose(file_id) < 0)
TEST_ERROR;
free(prefixed_filename);
prefixed_filename = NULL;
PASSED();
return 0;
error:
H5E_BEGIN_TRY
{
H5Sclose(dspace_id);
H5Dclose(dset_id);
H5Aclose(attr_id);
H5Tclose(dtype_id);
H5Gclose(group_id);
H5Fclose(file_id);
}
H5E_END_TRY;
free(prefixed_filename);
return 1;
}
/*
* A test to check that a file can be re-opened with H5Freopen.
*/
static int
test_reopen_file(void)
{
hid_t file_id = H5I_INVALID_HID;
hid_t file_id2 = H5I_INVALID_HID;
TESTING("re-open of a file with H5Freopen");
/* Make sure the connector supports the API functions being tested */
if (!(vol_cap_flags_g & H5VL_CAP_FLAG_FILE_BASIC)) {
SKIPPED();
printf(" API functions for basic file aren't supported with this connector\n");
return 0;
}
if ((file_id = H5Fopen(H5_api_test_filename, H5F_ACC_RDWR, H5P_DEFAULT)) < 0) {
H5_FAILED();
printf(" couldn't open file\n");
goto error;
}
if ((file_id2 = H5Freopen(file_id)) < 0) {
H5_FAILED();
printf(" couldn't re-open file\n");
goto error;
}
if (H5Fclose(file_id) < 0)
TEST_ERROR;
if (H5Fclose(file_id2) < 0)
TEST_ERROR;
PASSED();
return 0;
error:
H5E_BEGIN_TRY
{
H5Fclose(file_id);
H5Fclose(file_id2);
}
H5E_END_TRY;
return 1;
}
/*
* A test to check that H5Fclose doesn't succeed for an
* invalid file ID */
static int
test_close_file_invalid_id(void)
{
herr_t err_ret = -1;
TESTING("H5Fclose with an invalid ID");
/* Make sure the connector supports the API functions being tested */
if (!(vol_cap_flags_g & H5VL_CAP_FLAG_FILE_BASIC)) {
SKIPPED();
printf(" API functions for basic file aren't supported with this connector\n");
return 0;
}
H5E_BEGIN_TRY
{
err_ret = H5Fclose(H5I_INVALID_HID);
}
H5E_END_TRY;
if (err_ret >= 0) {
H5_FAILED();
printf(" closed an invalid file ID!\n");
goto error;
}
PASSED();
return 0;
error:
return 1;
}
/*
* A test to check that a file can be flushed using H5Fflush.
*/
static int
test_flush_file(void)
{
hid_t file_id = H5I_INVALID_HID;
hid_t dspace_id = H5I_INVALID_HID;
hid_t dset_id = H5I_INVALID_HID;
char *prefixed_filename = NULL;
char dset_name[32];
unsigned u;
TESTING_MULTIPART("H5Fflush");
/* Make sure the connector supports the API functions being tested */
if (!(vol_cap_flags_g & (H5VL_CAP_FLAG_FILE_BASIC)) || !(vol_cap_flags_g & H5VL_CAP_FLAG_DATASET_BASIC) ||
!(vol_cap_flags_g & H5VL_CAP_FLAG_FLUSH_REFRESH)) {
SKIPPED();
printf(" API functions for basic file, dataset, or file flush aren't supported with this "
"connector\n");
return 0;
}
TESTING_2("test setup");
if (prefix_filename(test_path_prefix, FILE_FLUSH_TEST_FILENAME, &prefixed_filename) < 0) {
H5_FAILED();
printf(" couldn't prefix filename\n");
goto error;
}
if ((file_id = H5Fcreate(prefixed_filename, H5F_ACC_TRUNC, H5P_DEFAULT, H5P_DEFAULT)) < 0) {
H5_FAILED();
printf(" couldn't create file '%s'\n", prefixed_filename);
goto error;
}
/* Create multiple small datasets in file */
if ((dspace_id = H5Screate(H5S_SCALAR)) < 0) {
H5_FAILED();
printf(" couldn't create data space\n");
goto error;
}
for (u = 0; u < 10; u++) {
HDsprintf(dset_name, "Dataset %u", u);
if ((dset_id = H5Dcreate2(file_id, dset_name, H5T_STD_U32LE, dspace_id, H5P_DEFAULT, H5P_DEFAULT,
H5P_DEFAULT)) < 0) {
H5_FAILED();
printf(" couldn't create data set: %s\n", dset_name);
goto error;
}
if (H5Dclose(dset_id) < 0)
TEST_ERROR;
}
PASSED();
BEGIN_MULTIPART
{
PART_BEGIN(H5Fflush_local)
{
TESTING_2("file flushing at local scope");
if (H5Fflush(file_id, H5F_SCOPE_LOCAL) < 0) {
H5_FAILED();
printf(" unable to flush file with scope H5F_SCOPE_LOCAL\n");
PART_ERROR(H5Fflush_local);
}
PASSED();
}
PART_END(H5Fflush_local);
PART_BEGIN(H5Fflush_global)
{
TESTING_2("file flushing at global scope");
if (H5Fflush(file_id, H5F_SCOPE_GLOBAL) < 0) {
H5_FAILED();
printf(" unable to flush file with scope H5F_SCOPE_GLOBAL\n");
PART_ERROR(H5Fflush_global);
}
PASSED();
}
PART_END(H5Fflush_global);
}
END_MULTIPART;
TESTING_2("test cleanup");
if (H5Sclose(dspace_id) < 0)
TEST_ERROR;
if (H5Fclose(file_id) < 0)
TEST_ERROR;
free(prefixed_filename);
prefixed_filename = NULL;
PASSED();
return 0;
error:
H5E_BEGIN_TRY
{
H5Sclose(dspace_id);
H5Dclose(dset_id);
H5Fclose(file_id);
}
H5E_END_TRY;
free(prefixed_filename);
return 1;
}
/*
* A test for H5Fis_accessible.
*/
static int
test_file_is_accessible(void)
{
const char *const fake_filename = "nonexistent_file.h5";
char *prefixed_filename = NULL;
htri_t is_accessible = FAIL;
TESTING_MULTIPART("H5Fis_accessible");
/* Make sure the connector supports the API functions being tested */
if (!(vol_cap_flags_g & H5VL_CAP_FLAG_FILE_BASIC)) {
SKIPPED();
printf(" API functions for basic file aren't supported with this connector\n");
return 0;
}
if (prefix_filename(test_path_prefix, fake_filename, &prefixed_filename) < 0) {
H5_FAILED();
printf(" couldn't prefix filename\n");
goto error;
}
BEGIN_MULTIPART
{
PART_BEGIN(H5Fis_accessible_valid_file)
{
TESTING_2("H5Fis_accessible on existing file");
if ((is_accessible = H5Fis_accessible(H5_api_test_filename, H5P_DEFAULT)) < 0) {
H5_FAILED();
printf(" couldn't determine if file '%s' is accessible with default FAPL\n",
H5_api_test_filename);
PART_ERROR(H5Fis_accessible_valid_file);
}
if (!is_accessible) {
H5_FAILED();
printf(" file '%s' is not accessible with default FAPL\n", H5_api_test_filename);
PART_ERROR(H5Fis_accessible_valid_file);
}
PASSED();
}
PART_END(H5Fis_accessible_valid_file);
is_accessible = -1;
PART_BEGIN(H5Fis_accessible_invalid_file)
{
TESTING_2("H5Fis_accessible on non-existing file");
H5E_BEGIN_TRY
{
is_accessible = H5Fis_accessible(prefixed_filename, H5P_DEFAULT);
}
H5E_END_TRY;
if (is_accessible > 0) {
H5_FAILED();
printf(" non-existent file '%s' was accessible with default FAPL: is_accessible=%d!\n",
prefixed_filename, is_accessible);
PART_ERROR(H5Fis_accessible_invalid_file);
}
PASSED();
}
PART_END(H5Fis_accessible_invalid_file);
}
END_MULTIPART;
free(prefixed_filename);
prefixed_filename = NULL;
return 0;
error:
free(prefixed_filename);
return 1;
}
/*
* A test to check that a FCPL used for file creation can
* be persisted and that a valid copy of that FCPL can be
* retrieved later with a call to H5Fget_create_plist. Also
* tests that a valid copy of a FAPL used for file access
* can be retrieved with a call to H5Fget_access_plist.
*/
static int
test_file_property_lists(void)
{
hsize_t prop_val = 0;
hid_t file_id1 = H5I_INVALID_HID;
hid_t file_id2 = H5I_INVALID_HID;
hid_t fcpl_id1 = H5I_INVALID_HID;
hid_t fcpl_id2 = H5I_INVALID_HID;
hid_t fapl_id1 = H5I_INVALID_HID;
hid_t fapl_id2 = H5I_INVALID_HID;
char *prefixed_filename1 = NULL;
char *prefixed_filename2 = NULL;
TESTING_MULTIPART("file property list operations");
/* Make sure the connector supports the API functions being tested */
if (!(vol_cap_flags_g & H5VL_CAP_FLAG_FILE_BASIC) || !(vol_cap_flags_g & H5VL_CAP_FLAG_FILE_MORE) ||
!(vol_cap_flags_g & H5VL_CAP_FLAG_GET_PLIST)) {
SKIPPED();
printf(" API functions for basic or more file or get property list aren't supported with this "
"connector\n");
return 0;
}
TESTING_2("test setup");
if (prefix_filename(test_path_prefix, FILE_PROPERTY_LIST_TEST_FNAME1, &prefixed_filename1) < 0) {
H5_FAILED();
printf(" couldn't prefix filename\n");
goto error;
}
if (prefix_filename(test_path_prefix, FILE_PROPERTY_LIST_TEST_FNAME2, &prefixed_filename2) < 0) {
H5_FAILED();
printf(" couldn't prefix filename\n");
goto error;
}
if ((fcpl_id1 = H5Pcreate(H5P_FILE_CREATE)) < 0) {
H5_FAILED();
printf(" couldn't create FCPL\n");
goto error;
}
if (H5Pset_userblock(fcpl_id1, FILE_PROPERTY_LIST_TEST_FCPL_PROP_VAL) < 0) {
H5_FAILED();
printf(" failed to set test property on FCPL\n");
goto error;
}
if ((file_id1 = H5Fcreate(prefixed_filename1, H5F_ACC_TRUNC, fcpl_id1, H5P_DEFAULT)) < 0) {
H5_FAILED();
printf(" couldn't create file\n");
goto error;
}
if ((file_id2 = H5Fcreate(prefixed_filename2, H5F_ACC_TRUNC, H5P_DEFAULT, H5P_DEFAULT)) < 0) {
H5_FAILED();
printf(" couldn't create file\n");
goto error;
}
if (H5Pclose(fcpl_id1) < 0)
TEST_ERROR;
PASSED();
BEGIN_MULTIPART
{
PART_BEGIN(H5Fget_create_plist)
{
TESTING_2("H5Fget_create_plist");
/* Try to receive copies of the two property lists, one which has the property set and one which
* does not */
if ((fcpl_id1 = H5Fget_create_plist(file_id1)) < 0) {
H5_FAILED();
printf(" couldn't get FCPL\n");
PART_ERROR(H5Fget_create_plist);
}
if ((fcpl_id2 = H5Fget_create_plist(file_id2)) < 0) {
H5_FAILED();
printf(" couldn't get FCPL\n");
PART_ERROR(H5Fget_create_plist);
}
/* Ensure that property list 1 has the property set and property list 2 does not */
if (H5Pget_userblock(fcpl_id1, &prop_val) < 0) {
H5_FAILED();
printf(" failed to retrieve test property from FCPL\n");
PART_ERROR(H5Fget_create_plist);
}
if (prop_val != FILE_PROPERTY_LIST_TEST_FCPL_PROP_VAL) {
H5_FAILED();
printf(" retrieved test property value '%llu' did not match expected value '%llu'\n",
(long long unsigned)prop_val,
(long long unsigned)FILE_PROPERTY_LIST_TEST_FCPL_PROP_VAL);
PART_ERROR(H5Fget_create_plist);
}
if (H5Pget_userblock(fcpl_id2, &prop_val) < 0) {
H5_FAILED();
printf(" failed to retrieve test property from FCPL\n");
PART_ERROR(H5Fget_create_plist);
}
if (prop_val == FILE_PROPERTY_LIST_TEST_FCPL_PROP_VAL) {
printf(" retrieved test property value '%llu' matched control value '%llu' when it "
"shouldn't have\n",
(long long unsigned)prop_val,
(long long unsigned)FILE_PROPERTY_LIST_TEST_FCPL_PROP_VAL);
PART_ERROR(H5Fget_create_plist);
}
PASSED();
}
PART_END(H5Fget_create_plist);
PART_BEGIN(H5Fget_access_plist)
{
TESTING_2("H5Fget_access_plist");
/* Due to the nature of needing to supply a FAPL with the VOL connector having been set on it to
* the H5Fcreate() call, we cannot exactly test using H5P_DEFAULT as the FAPL for one of the
* create calls in this test. However, the use of H5Fget_access_plist() will still be used to
* check that the FAPL is correct after both creating and opening a file.
*/
if ((fapl_id1 = H5Fget_access_plist(file_id1)) < 0) {
H5_FAILED();
printf(" couldn't get FAPL\n");
PART_ERROR(H5Fget_access_plist);
}
if ((fapl_id2 = H5Fget_access_plist(file_id2)) < 0) {
H5_FAILED();
printf(" couldn't get FAPL\n");
PART_ERROR(H5Fget_access_plist);
}
PASSED();
}
PART_END(H5Fget_access_plist);
/* Now see if we can still retrieve copies of the property lists upon opening
* (instead of creating) a file. If they were reconstructed properly upon file
* open, the creation property lists should also have the same test values
* as set before.
*/
if (fcpl_id1 >= 0) {
H5E_BEGIN_TRY
{
H5Pclose(fcpl_id1);
}
H5E_END_TRY;
fcpl_id1 = H5I_INVALID_HID;
}
if (fcpl_id2 >= 0) {
H5E_BEGIN_TRY
{
H5Pclose(fcpl_id2);
}
H5E_END_TRY;
fcpl_id2 = H5I_INVALID_HID;
}
if (fapl_id1 >= 0) {
H5E_BEGIN_TRY
{
H5Pclose(fapl_id1);
}
H5E_END_TRY;
fapl_id1 = H5I_INVALID_HID;
}
if (fapl_id2 >= 0) {
H5E_BEGIN_TRY
{
H5Pclose(fapl_id2);
}
H5E_END_TRY;
fapl_id2 = H5I_INVALID_HID;
}
if (file_id1 >= 0) {
H5E_BEGIN_TRY
{
H5Fclose(file_id1);
}
H5E_END_TRY;
file_id1 = H5I_INVALID_HID;
}
if (file_id2 >= 0) {
H5E_BEGIN_TRY
{
H5Fclose(file_id2);
}
H5E_END_TRY;
file_id2 = H5I_INVALID_HID;
}
PART_BEGIN(H5Fget_create_plist_reopened)
{
TESTING_2("H5Fget_create_plist after re-opening file");
if ((file_id1 = H5Fopen(prefixed_filename1, H5F_ACC_RDWR, H5P_DEFAULT)) < 0) {
H5_FAILED();
printf(" couldn't open file\n");
PART_ERROR(H5Fget_create_plist_reopened);
}
if ((file_id2 = H5Fopen(prefixed_filename2, H5F_ACC_RDWR, H5P_DEFAULT)) < 0) {
H5_FAILED();
printf(" couldn't open file\n");
PART_ERROR(H5Fget_create_plist_reopened);
}
if ((fcpl_id1 = H5Fget_create_plist(file_id1)) < 0) {
H5_FAILED();
printf(" couldn't get FCPL\n");
PART_ERROR(H5Fget_create_plist_reopened);
}
if ((fcpl_id2 = H5Fget_create_plist(file_id2)) < 0) {
H5_FAILED();
printf(" couldn't get FCPL\n");
PART_ERROR(H5Fget_create_plist_reopened);
}
/* Check the values of the test property */
if (H5Pget_userblock(fcpl_id1, &prop_val) < 0) {
H5_FAILED();
printf(" failed to retrieve test property from FCPL\n");
PART_ERROR(H5Fget_create_plist_reopened);
}
if (prop_val != FILE_PROPERTY_LIST_TEST_FCPL_PROP_VAL) {
H5_FAILED();
printf(" retrieved test property value '%llu' did not match expected value '%llu'\n",
(long long unsigned)prop_val,
(long long unsigned)FILE_PROPERTY_LIST_TEST_FCPL_PROP_VAL);
PART_ERROR(H5Fget_create_plist_reopened);
}
if (H5Pget_userblock(fcpl_id2, &prop_val) < 0) {
H5_FAILED();
printf(" failed to retrieve test property from FCPL\n");
PART_ERROR(H5Fget_create_plist_reopened);
}
if (prop_val == FILE_PROPERTY_LIST_TEST_FCPL_PROP_VAL) {
printf(" retrieved test property value '%llu' matched control value '%llu' when it "
"shouldn't have\n",
(long long unsigned)prop_val,
(long long unsigned)FILE_PROPERTY_LIST_TEST_FCPL_PROP_VAL);
PART_ERROR(H5Fget_create_plist_reopened);
}
PASSED();
}
PART_END(H5Fget_create_plist_reopened);
}
END_MULTIPART;
TESTING_2("test cleanup");
if (H5Pclose(fcpl_id1) < 0)
TEST_ERROR;
if (H5Pclose(fcpl_id2) < 0)
TEST_ERROR;
if (H5Fclose(file_id1) < 0)
TEST_ERROR;
if (H5Fclose(file_id2) < 0)
TEST_ERROR;
free(prefixed_filename1);
prefixed_filename1 = NULL;
free(prefixed_filename2);
prefixed_filename2 = NULL;
PASSED();
return 0;
error:
H5E_BEGIN_TRY
{
H5Pclose(fcpl_id1);
H5Pclose(fcpl_id2);
H5Pclose(fapl_id1);
H5Pclose(fapl_id2);
H5Fclose(file_id1);
H5Fclose(file_id2);
}
H5E_END_TRY;
free(prefixed_filename1);
free(prefixed_filename2);
return 1;
}
/*
* A test to check that the file intent flags can be retrieved.
*/
static int
test_get_file_intent(void)
{
unsigned file_intent;
hid_t file_id = H5I_INVALID_HID;
char *prefixed_filename = NULL;
TESTING_MULTIPART("retrieval of file intent with H5Fget_intent");
/* Make sure the connector supports the API functions being tested */
if (!(vol_cap_flags_g & H5VL_CAP_FLAG_FILE_BASIC) || !(vol_cap_flags_g & H5VL_CAP_FLAG_FILE_MORE)) {
SKIPPED();
printf(" API functions for basic or more file aren't supported with this connector\n");
return 0;
}
TESTING_2("test setup");
if (prefix_filename(test_path_prefix, FILE_INTENT_TEST_FILENAME, &prefixed_filename) < 0) {
H5_FAILED();
printf(" couldn't prefix filename\n");
goto error;
}
/* Test that file intent retrieval works correctly for file create */
if ((file_id = H5Fcreate(prefixed_filename, H5F_ACC_TRUNC, H5P_DEFAULT, H5P_DEFAULT)) < 0) {
H5_FAILED();
printf(" couldn't create file '%s'\n", prefixed_filename);
goto error;
}
PASSED();
BEGIN_MULTIPART
{
PART_BEGIN(H5Fget_intent_file_creation)
{
TESTING_2("H5Fget_intent on newly-created file");
if (H5Fget_intent(file_id, &file_intent) < 0) {
H5_FAILED();
printf(" failed to retrieve file intent\n");
PART_ERROR(H5Fget_intent_file_creation);
}
if (H5F_ACC_RDWR != file_intent) {
H5_FAILED();
printf(" received incorrect file intent for file creation\n");
PART_ERROR(H5Fget_intent_file_creation);
}
PASSED();
}
PART_END(H5Fget_intent_file_creation);
if (file_id >= 0) {
H5E_BEGIN_TRY
{
H5Fclose(file_id);
}
H5E_END_TRY;
file_id = H5I_INVALID_HID;
}
PART_BEGIN(H5Fget_intent_rdonly_file_open)
{
TESTING_2("H5Fget_intent for file opened read-only");
/* Test that file intent retrieval works correctly for file open */
if ((file_id = H5Fopen(H5_api_test_filename, H5F_ACC_RDONLY, H5P_DEFAULT)) < 0) {
H5_FAILED();
printf(" couldn't open file '%s'\n", H5_api_test_filename);
PART_ERROR(H5Fget_intent_rdonly_file_open);
}
if (H5Fget_intent(file_id, &file_intent) < 0) {
H5_FAILED();
printf(" failed to retrieve file intent\n");
PART_ERROR(H5Fget_intent_rdonly_file_open);
}
if (H5F_ACC_RDONLY != file_intent) {
H5_FAILED();
printf(" received incorrect file intent for read-only file open\n");
PART_ERROR(H5Fget_intent_rdonly_file_open);
}
PASSED();
}
PART_END(H5Fget_intent_rdonly_file_open);
if (file_id >= 0) {
H5E_BEGIN_TRY
{
H5Fclose(file_id);
}
H5E_END_TRY;
file_id = H5I_INVALID_HID;
}
PART_BEGIN(H5Fget_intent_rdwrite_file_open)
{
TESTING_2("H5Fget_intent for file opened read-write");
if ((file_id = H5Fopen(H5_api_test_filename, H5F_ACC_RDWR, H5P_DEFAULT)) < 0) {
H5_FAILED();
printf(" couldn't open file '%s'\n", H5_api_test_filename);
PART_ERROR(H5Fget_intent_rdwrite_file_open);
}
if (H5Fget_intent(file_id, &file_intent) < 0) {
H5_FAILED();
printf(" failed to retrieve file intent\n");
PART_ERROR(H5Fget_intent_rdwrite_file_open);
}
if (H5F_ACC_RDWR != file_intent) {
H5_FAILED();
printf(" received incorrect file intent\n");
PART_ERROR(H5Fget_intent_rdwrite_file_open);
}
PASSED();
}
PART_END(H5Fget_intent_rdwrite_file_open);
if (file_id >= 0) {
H5E_BEGIN_TRY
{
H5Fclose(file_id);
}
H5E_END_TRY;
file_id = H5I_INVALID_HID;
}
}
END_MULTIPART;
free(prefixed_filename);
prefixed_filename = NULL;
return 0;
error:
H5E_BEGIN_TRY
{
H5Fclose(file_id);
}
H5E_END_TRY;
free(prefixed_filename);
return 1;
}
/*
* A test to check that the number of open objects and IDs of objects in a file
* can be retrieved.
*/
static int
test_get_file_obj_count(void)
{
ssize_t obj_count;
hid_t file_id = H5I_INVALID_HID;
hid_t file_id2 = H5I_INVALID_HID;
hid_t group_id = H5I_INVALID_HID;
hid_t object_id = H5I_INVALID_HID;
hid_t named_dtype_id = H5I_INVALID_HID;
hid_t attr_id = H5I_INVALID_HID;
hid_t dspace_id = H5I_INVALID_HID;
hid_t dset_id = H5I_INVALID_HID;
char *prefixed_filename1 = NULL;
char *prefixed_filename2 = NULL;
TESTING_MULTIPART("retrieval of open object number and IDs");
/* Make sure the connector supports the API functions being tested */
if (!(vol_cap_flags_g & H5VL_CAP_FLAG_FILE_BASIC) || !(vol_cap_flags_g & H5VL_CAP_FLAG_FILE_MORE) ||
!(vol_cap_flags_g & H5VL_CAP_FLAG_DATASET_BASIC) || !(vol_cap_flags_g & H5VL_CAP_FLAG_GROUP_BASIC) ||
!(vol_cap_flags_g & H5VL_CAP_FLAG_STORED_DATATYPES) ||
!(vol_cap_flags_g & H5VL_CAP_FLAG_ATTR_BASIC)) {
SKIPPED();
printf(
" API functions for basic or more file, basic dataset, group, stored datatypes, or attribute "
"aren't supported with this connector\n");
return 0;
}
TESTING_2("test setup");
if (prefix_filename(test_path_prefix, GET_OBJ_COUNT_TEST_FILENAME1, &prefixed_filename1) < 0) {
H5_FAILED();
printf(" couldn't prefix filename\n");
goto error;
}
if (prefix_filename(test_path_prefix, GET_OBJ_COUNT_TEST_FILENAME2, &prefixed_filename2) < 0) {
H5_FAILED();
printf(" couldn't prefix filename\n");
goto error;
}
if ((file_id = H5Fcreate(prefixed_filename1, H5F_ACC_TRUNC, H5P_DEFAULT, H5P_DEFAULT)) < 0) {
H5_FAILED();
printf(" couldn't create file '%s'\n", prefixed_filename1);
goto error;
}
if ((group_id = H5Gcreate2(file_id, GET_OBJ_COUNT_TEST_GRP_NAME, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) <
0) {
H5_FAILED();
printf(" couldn't create group '%s'\n", GET_OBJ_COUNT_TEST_GRP_NAME);
goto error;
}
/* Create a second file while keeping the first file open */
if ((file_id2 = H5Fcreate(prefixed_filename2, H5F_ACC_TRUNC, H5P_DEFAULT, H5P_DEFAULT)) < 0) {
H5_FAILED();
printf(" couldn't create file '%s'\n", prefixed_filename2);
goto error;
}
/* Create a named datatype */
if ((named_dtype_id = H5Tcopy(H5T_NATIVE_INT)) < 0) {
H5_FAILED();
printf(" couldn't copy a native datatype\n");
goto error;
}
if (H5Tcommit2(file_id2, GET_OBJ_COUNT_TEST_NAMED_DTYPE, named_dtype_id, H5P_DEFAULT, H5P_DEFAULT,
H5P_DEFAULT) < 0) {
H5_FAILED();
printf(" couldn't commit a named datatype\n");
goto error;
}
/* Create a dataspace for the attribute and dataset */
if ((dspace_id = H5Screate(H5S_SCALAR)) < 0) {
H5_FAILED();
printf(" couldn't create data space for attribute\n");
goto error;
}
/* Create an attribute for the second file */
if ((attr_id = H5Acreate2(file_id2, GET_OBJ_COUNT_TEST_ATTR_NAME, H5T_NATIVE_INT, dspace_id, H5P_DEFAULT,
H5P_DEFAULT)) < 0) {
H5_FAILED();
printf(" couldn't create the attribute '%s'\n", GET_OBJ_COUNT_TEST_ATTR_NAME);
goto error;
}
/* Create a dataset for the second file */
if ((dset_id = H5Dcreate2(file_id2, GET_OBJ_COUNT_TEST_DSET_NAME, H5T_NATIVE_INT, dspace_id, H5P_DEFAULT,
H5P_DEFAULT, H5P_DEFAULT)) < 0) {
H5_FAILED();
printf(" couldn't create the dataset '%s'\n", GET_OBJ_COUNT_TEST_DSET_NAME);
goto error;
}
PASSED();
BEGIN_MULTIPART
{
PART_BEGIN(H5Fget_obj_count_files)
{
TESTING_2("H5Fget_obj_count for files");
/* Get the number of files currently opened */
if ((obj_count = H5Fget_obj_count((hid_t)H5F_OBJ_ALL, H5F_OBJ_FILE)) < 0) {
H5_FAILED();
printf(" couldn't get the number of open files\n");
PART_ERROR(H5Fget_obj_count_files);
}
if (obj_count != 2) {
H5_FAILED();
printf(" number of open files (%ld) did not match expected number (2)\n", obj_count);
PART_ERROR(H5Fget_obj_count_files);
}
PASSED();
}
PART_END(H5Fget_obj_count_files);
PART_BEGIN(H5Fget_obj_count_grps_single_file)
{
TESTING_2("H5Fget_obj_count for groups in single file");
/* Get the number of groups */
if ((obj_count = H5Fget_obj_count(file_id, H5F_OBJ_GROUP)) < 0) {
H5_FAILED();
printf(" couldn't retrieve number of open groups\n");
PART_ERROR(H5Fget_obj_count_grps_single_file);
}
if (obj_count != 1) {
H5_FAILED();
printf(" number of open groups (%ld) did not match expected number (1)\n", obj_count);
PART_ERROR(H5Fget_obj_count_grps_single_file);
}
PASSED();
}
PART_END(H5Fget_obj_count_grps_single_file);
PART_BEGIN(H5Fget_obj_count_grps)
{
TESTING_2("H5Fget_obj_count for groups");
/* Get the number of groups in two opened files */
if ((obj_count = H5Fget_obj_count((hid_t)H5F_OBJ_ALL, H5F_OBJ_GROUP)) < 0) {
H5_FAILED();
printf(" couldn't get the number of open groups\n");
PART_ERROR(H5Fget_obj_count_grps);
}
if (obj_count != 1) {
H5_FAILED();
printf(" number of open groups (%ld) did not match expected number (1)\n", obj_count);
PART_ERROR(H5Fget_obj_count_grps);
}
PASSED();
}
PART_END(H5Fget_obj_count_grps);
PART_BEGIN(H5Fget_obj_count_types)
{
TESTING_2("H5Fget_obj_count for datatypes");
/* Get the number of named datatype in two opened files */
if ((obj_count = H5Fget_obj_count((hid_t)H5F_OBJ_ALL, H5F_OBJ_DATATYPE)) < 0) {
H5_FAILED();
printf(" couldn't get the number of open named datatypes\n");
PART_ERROR(H5Fget_obj_count_types);
}
if (obj_count != 1) {
H5_FAILED();
printf(" number of open named datatypes (%ld) did not match expected number (1)\n",
obj_count);
PART_ERROR(H5Fget_obj_count_types);
}
PASSED();
}
PART_END(H5Fget_obj_count_types);
PART_BEGIN(H5Fget_obj_count_attrs)
{
TESTING_2("H5Fget_obj_count for attributes");
/* Get the number of attribute in two opened files */
if ((obj_count = H5Fget_obj_count((hid_t)H5F_OBJ_ALL, H5F_OBJ_ATTR)) < 0) {
H5_FAILED();
printf(" couldn't get the number of open attributes\n");
PART_ERROR(H5Fget_obj_count_attrs);
}
if (obj_count != 1) {
H5_FAILED();
printf(" number of open attributes (%ld) did not match expected number (1)\n", obj_count);
PART_ERROR(H5Fget_obj_count_attrs);
}
PASSED();
}
PART_END(H5Fget_obj_count_attrs);
PART_BEGIN(H5Fget_obj_count_dsets)
{
TESTING_2("H5Fget_obj_count for datasets");
/* Get the number of dataset in two opened files */
if ((obj_count = H5Fget_obj_count((hid_t)H5F_OBJ_ALL, H5F_OBJ_DATASET)) < 0 || obj_count != 1) {
H5_FAILED();
printf(" couldn't get the number of open datasets\n");
PART_ERROR(H5Fget_obj_count_dsets);
}
if (obj_count != 1) {
H5_FAILED();
printf(" number of open datasets (%ld) did not match expected number (1)\n", obj_count);
PART_ERROR(H5Fget_obj_count_dsets);
}
PASSED();
}
PART_END(H5Fget_obj_count_dsets);
PART_BEGIN(H5Fget_obj_count_all_single_file)
{
TESTING_2("H5Fget_obj_count for all object types in single file");
/* Get the number of all open objects */
if ((obj_count = H5Fget_obj_count(file_id, H5F_OBJ_ALL)) < 0) {
H5_FAILED();
printf(" couldn't retrieve number of open objects\n");
PART_ERROR(H5Fget_obj_count_all_single_file);
}
/* One for the file and another for the group */
if (obj_count != 2) {
H5_FAILED();
printf(" number of open objects (%ld) did not match expected number (2)\n", obj_count);
PART_ERROR(H5Fget_obj_count_all_single_file);
}
PASSED();
}
PART_END(H5Fget_obj_count_all_single_file);
PART_BEGIN(H5Fget_obj_count_all)
{
TESTING_2("H5Fget_obj_count for all object types");
/* Get the number of all open objects */
if ((obj_count = H5Fget_obj_count(H5F_OBJ_ALL, H5F_OBJ_ALL)) < 0) {
H5_FAILED();
printf(" couldn't retrieve number of open objects\n");
PART_ERROR(H5Fget_obj_count_all);
}
if (obj_count != 6) {
H5_FAILED();
printf(" number of open objects (%ld) did not match expected number (6)\n", obj_count);
PART_ERROR(H5Fget_obj_count_all);
}
PASSED();
}
PART_END(H5Fget_obj_count_all);
PART_BEGIN(H5Fget_obj_ids_singular_grp)
{
TESTING_2("H5Fget_obj_ids for a singular group");
if (H5Fget_obj_ids(file_id, H5F_OBJ_GROUP, (size_t)obj_count, &object_id) < 0) {
H5_FAILED();
printf(" couldn't get opened group IDs\n");
PART_ERROR(H5Fget_obj_ids_singular_grp);
}
if (object_id != group_id) {
H5_FAILED();
printf(" opened object ID (%ld) did not match only currently open group ID (%ld)\n",
object_id, group_id);
PART_ERROR(H5Fget_obj_ids_singular_grp);
}
PASSED();
}
PART_END(H5Fget_obj_ids_singular_grp);
}
END_MULTIPART;
TESTING_2("test cleanup");
if (H5Gclose(group_id) < 0)
TEST_ERROR;
if (H5Sclose(dspace_id) < 0)
TEST_ERROR;
if (H5Aclose(attr_id) < 0)
TEST_ERROR;
if (H5Tclose(named_dtype_id) < 0)
TEST_ERROR;
if (H5Dclose(dset_id) < 0)
TEST_ERROR;
if (H5Fclose(file_id) < 0)
TEST_ERROR;
if (H5Fclose(file_id2) < 0)
TEST_ERROR;
free(prefixed_filename1);
prefixed_filename1 = NULL;
free(prefixed_filename2);
prefixed_filename2 = NULL;
PASSED();
return 0;
error:
H5E_BEGIN_TRY
{
H5Gclose(group_id);
H5Tclose(named_dtype_id);
H5Sclose(dspace_id);
H5Aclose(attr_id);
H5Dclose(dset_id);
H5Fclose(file_id);
H5Fclose(file_id2);
}
H5E_END_TRY;
free(prefixed_filename1);
free(prefixed_filename2);
return 1;
}
/*
* A test to check that opening files in an overlapping way
* works correctly.
*/
static int
test_file_open_overlap(void)
{
ssize_t obj_count;
hid_t file_id = H5I_INVALID_HID;
hid_t file_id2 = H5I_INVALID_HID;
hid_t group_id = H5I_INVALID_HID;
hid_t dspace_id = H5I_INVALID_HID;
hid_t dset_id = H5I_INVALID_HID;
char *prefixed_filename = NULL;
TESTING("overlapping file opens");
/* Make sure the connector supports the API functions being tested */
if (!(vol_cap_flags_g & H5VL_CAP_FLAG_FILE_BASIC) || !(vol_cap_flags_g & H5VL_CAP_FLAG_FILE_MORE) ||
!(vol_cap_flags_g & H5VL_CAP_FLAG_DATASET_BASIC) || !(vol_cap_flags_g & H5VL_CAP_FLAG_GROUP_BASIC)) {
SKIPPED();
printf(" API functions for basic or more file, dataset, or group aren't supported with this "
"connector\n");
return 0;
}
if (prefix_filename(test_path_prefix, OVERLAPPING_FILENAME, &prefixed_filename) < 0) {
H5_FAILED();
printf(" couldn't prefix filename\n");
goto error;
}
if ((file_id = H5Fcreate(prefixed_filename, H5F_ACC_TRUNC, H5P_DEFAULT, H5P_DEFAULT)) < 0) {
H5_FAILED();
printf(" couldn't create file '%s'\n", prefixed_filename);
goto error;
}
if ((file_id2 = H5Fopen(prefixed_filename, H5F_ACC_RDWR, H5P_DEFAULT)) < 0) {
H5_FAILED();
printf(" couldn't open file '%s'\n", prefixed_filename);
goto error;
}
if ((group_id = H5Gcreate2(file_id, OVERLAPPING_OPEN_TEST_GRP_NAME, H5P_DEFAULT, H5P_DEFAULT,
H5P_DEFAULT)) < 0) {
H5_FAILED();
printf(" couldn't create group '%s'\n", OVERLAPPING_OPEN_TEST_GRP_NAME);
goto error;
}
/* Create a dataspace for the dataset */
if ((dspace_id = H5Screate(H5S_SCALAR)) < 0) {
H5_FAILED();
printf(" couldn't create data space for dataset\n");
goto error;
}
/* Create a dataset in the group of the first file */
if ((dset_id = H5Dcreate2(group_id, OVERLAPPING_OPEN_TEST_DSET_NAME, H5T_NATIVE_INT, dspace_id,
H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0) {
H5_FAILED();
printf(" couldn't create the dataset '%s'\n", OVERLAPPING_OPEN_TEST_DSET_NAME);
goto error;
}
/* Get the number of objects opened in the first file: 3 == file + dataset + group */
if ((obj_count = H5Fget_obj_count(file_id, H5F_OBJ_LOCAL | H5F_OBJ_ALL)) < 0) {
H5_FAILED();
printf(" couldn't retrieve the number of objects opened in the file\n");
goto error;
}
if (obj_count != 3) {
H5_FAILED();
printf(" number of objects opened in file (%ld) did not match expected number (3)\n", obj_count);
goto error;
}
if (H5Gclose(group_id) < 0)
TEST_ERROR;
if (H5Dclose(dset_id) < 0)
TEST_ERROR;
if (H5Fclose(file_id) < 0)
TEST_ERROR;
/* Create a dataset in the second file */
if ((dset_id = H5Dcreate2(file_id2, OVERLAPPING_OPEN_TEST_DSET_NAME, H5T_NATIVE_INT, dspace_id,
H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0) {
H5_FAILED();
printf(" couldn't create the dataset '%s'\n", OVERLAPPING_OPEN_TEST_DSET_NAME);
goto error;
}
/* Get the number of objects opened in the first file: 2 == file + dataset */
if ((obj_count = H5Fget_obj_count(file_id2, H5F_OBJ_ALL)) < 0) {
H5_FAILED();
printf(" couldn't retrieve the number of objects opened in the file\n");
goto error;
}
if (obj_count != 2) {
H5_FAILED();
printf(" number of objects opened in the file (%ld) did not match expected number (2)\n",
obj_count);
goto error;
}
if (H5Sclose(dspace_id) < 0)
TEST_ERROR;
if (H5Dclose(dset_id) < 0)
TEST_ERROR;
if (H5Fclose(file_id2) < 0)
TEST_ERROR;
free(prefixed_filename);
prefixed_filename = NULL;
PASSED();
return 0;
error:
H5E_BEGIN_TRY
{
H5Gclose(group_id);
H5Sclose(dspace_id);
H5Dclose(dset_id);
H5Fclose(file_id);
H5Fclose(file_id2);
}
H5E_END_TRY;
free(prefixed_filename);
return 1;
}
/*
* A test to check that file mounting and unmounting works
* correctly.
*/
static int
test_file_mounts(void)
{
hid_t file_id = H5I_INVALID_HID;
hid_t child_fid = H5I_INVALID_HID;
hid_t group_id = H5I_INVALID_HID;
char *prefixed_filename = NULL;
TESTING("file mounting/unmounting");
/* Make sure the connector supports the API functions being tested */
if (!(vol_cap_flags_g & (H5VL_CAP_FLAG_FILE_BASIC)) || !(vol_cap_flags_g & H5VL_CAP_FLAG_MOUNT) ||
!(vol_cap_flags_g & H5VL_CAP_FLAG_GROUP_BASIC)) {
SKIPPED();
printf(" API functions for basic file, file mount, or basic group aren't supported with this "
"connector\n");
return 0;
}
if (prefix_filename(test_path_prefix, FILE_MOUNT_TEST_FILENAME, &prefixed_filename) < 0) {
H5_FAILED();
printf(" couldn't prefix filename\n");
goto error;
}
if ((file_id = H5Fcreate(prefixed_filename, H5F_ACC_TRUNC, H5P_DEFAULT, H5P_DEFAULT)) < 0) {
H5_FAILED();
printf(" couldn't create file '%s'\n", prefixed_filename);
goto error;
}
if ((group_id = H5Gcreate2(file_id, FILE_MOUNT_TEST_GRP_NAME, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) <
0) {
H5_FAILED();
printf(" couldn't create group '%s'\n", FILE_MOUNT_TEST_GRP_NAME);
goto error;
}
if ((child_fid = H5Fopen(H5_api_test_filename, H5F_ACC_RDWR, H5P_DEFAULT)) < 0) {
H5_FAILED();
printf(" couldn't open file '%s'\n", H5_api_test_filename);
goto error;
}
/* Mount one file (child_fid) to the group of another file (file_id) */
if (H5Fmount(file_id, FILE_MOUNT_TEST_GRP_NAME, child_fid, H5P_DEFAULT) < 0) {
H5_FAILED();
printf(" couldn't mount file\n");
goto error;
}
if (H5Funmount(file_id, FILE_MOUNT_TEST_GRP_NAME) < 0) {
H5_FAILED();
printf(" couldn't mount file\n");
goto error;
}
if (H5Gclose(group_id) < 0)
TEST_ERROR;
if (H5Fclose(file_id) < 0)
TEST_ERROR;
if (H5Fclose(child_fid) < 0)
TEST_ERROR;
free(prefixed_filename);
prefixed_filename = NULL;
PASSED();
return 0;
error:
H5E_BEGIN_TRY
{
H5Gclose(group_id);
H5Fclose(file_id);
H5Fclose(child_fid);
}
H5E_END_TRY;
free(prefixed_filename);
return 1;
}
/*
* A test to ensure that a file's name can be retrieved.
*/
static int
test_get_file_name(void)
{
ssize_t file_name_buf_len = 0;
hid_t file_id = H5I_INVALID_HID;
hid_t group_id = H5I_INVALID_HID;
hid_t dset_id = H5I_INVALID_HID;
hid_t dspace_id = H5I_INVALID_HID;
hid_t attr_id = H5I_INVALID_HID;
hid_t named_dtype_id = H5I_INVALID_HID;
char *prefixed_filename = NULL;
char *file_name_buf = NULL;
TESTING_MULTIPART("retrieval of file name");
/* Make sure the connector supports the API functions being tested */
if (!(vol_cap_flags_g & H5VL_CAP_FLAG_FILE_BASIC) || !(vol_cap_flags_g & H5VL_CAP_FLAG_FILE_MORE) ||
!(vol_cap_flags_g & H5VL_CAP_FLAG_DATASET_BASIC) || !(vol_cap_flags_g & H5VL_CAP_FLAG_GROUP_BASIC) ||
!(vol_cap_flags_g & H5VL_CAP_FLAG_STORED_DATATYPES) ||
!(vol_cap_flags_g & H5VL_CAP_FLAG_ATTR_BASIC)) {
SKIPPED();
printf(
" API functions for basic or more file, basic dataset, group, stored datatypes, or attribute "
"aren't supported with this connector\n");
return 0;
}
TESTING_2("test setup");
if (prefix_filename(test_path_prefix, GET_FILE_NAME_TEST_FNAME, &prefixed_filename) < 0) {
H5_FAILED();
printf(" couldn't prefix filename\n");
goto error;
}
if ((file_id = H5Fcreate(prefixed_filename, H5F_ACC_TRUNC, H5P_DEFAULT, H5P_DEFAULT)) < 0) {
H5_FAILED();
printf(" couldn't create file '%s'\n", prefixed_filename);
goto error;
}
/* Retrieve the size of the file name */
if ((file_name_buf_len = H5Fget_name(file_id, NULL, 0)) < 0)
TEST_ERROR;
/* Allocate buffer for file name */
if (NULL == (file_name_buf = (char *)malloc((size_t)file_name_buf_len + 1)))
TEST_ERROR;
PASSED();
BEGIN_MULTIPART
{
PART_BEGIN(H5Fget_name_file_id)
{
TESTING_2("H5Fget_name using file ID");
memset(file_name_buf, 0, (size_t)file_name_buf_len);
/* Retrieve the actual file name */
if (H5Fget_name(file_id, file_name_buf, (size_t)file_name_buf_len + 1) < 0) {
H5_FAILED();
printf(" couldn't get file name %s\n", prefixed_filename);
PART_ERROR(H5Fget_name_file_id);
}
if (HDstrncmp(file_name_buf, prefixed_filename, (size_t)file_name_buf_len)) {
H5_FAILED();
printf(" file name '%s' didn't match expected name '%s'\n", file_name_buf,
prefixed_filename);
PART_ERROR(H5Fget_name_file_id);
}
PASSED();
}
PART_END(H5Fget_name_file_id);
PART_BEGIN(H5Fget_name_grp_id)
{
TESTING_2("H5Fget_name using non-root group ID");
/* Attempt to retrieve the name of the file from an object that isn't the root group */
memset(file_name_buf, 0, (size_t)file_name_buf_len);
if ((group_id = H5Gcreate2(file_id, GET_FILE_NAME_TEST_GRP_NAME, H5P_DEFAULT, H5P_DEFAULT,
H5P_DEFAULT)) < 0) {
H5_FAILED();
printf(" failed to create group '%s'\n", GET_FILE_NAME_TEST_GRP_NAME);
PART_ERROR(H5Fget_name_grp_id);
}
if (H5Fget_name(group_id, file_name_buf, (size_t)file_name_buf_len + 1) < 0) {
H5_FAILED();
printf(" couldn't get file name %s\n", prefixed_filename);
PART_ERROR(H5Fget_name_grp_id);
}
if (HDstrncmp(file_name_buf, prefixed_filename, (size_t)file_name_buf_len)) {
H5_FAILED();
printf(" file name '%s' didn't match expected name '%s'\n", file_name_buf,
prefixed_filename);
PART_ERROR(H5Fget_name_grp_id);
}
if (group_id >= 0) {
H5E_BEGIN_TRY
{
H5Gclose(group_id);
}
H5E_END_TRY;
group_id = H5I_INVALID_HID;
}
PASSED();
}
PART_END(H5Fget_name_grp_id);
PART_BEGIN(H5Fget_name_dset_id)
{
TESTING_2("H5Fget_name using dataset ID");
if ((dspace_id = H5Screate(H5S_SCALAR)) < 0) {
H5_FAILED();
printf(" couldn't create dataspace\n");
PART_ERROR(H5Fget_name_dset_id);
}
/* Create a dataset in the file */
if ((dset_id = H5Dcreate2(file_id, GET_FILE_NAME_TEST_DSET_NAME, H5T_NATIVE_INT, dspace_id,
H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0) {
H5_FAILED();
printf(" couldn't create the dataset '%s'\n", GET_FILE_NAME_TEST_DSET_NAME);
PART_ERROR(H5Fget_name_dset_id);
}
/* Get and verify file name from the dataset */
if (H5Fget_name(dset_id, file_name_buf, (size_t)file_name_buf_len + 1) < 0) {
H5_FAILED();
printf(" couldn't get file name %s\n", prefixed_filename);
PART_ERROR(H5Fget_name_dset_id);
}
if (HDstrncmp(file_name_buf, prefixed_filename, (size_t)file_name_buf_len)) {
H5_FAILED();
printf(" file name '%s' didn't match expected name '%s'\n", file_name_buf,
prefixed_filename);
PART_ERROR(H5Fget_name_dset_id);
}
if (dspace_id >= 0) {
H5E_BEGIN_TRY
{
H5Sclose(dspace_id);
}
H5E_END_TRY;
dspace_id = H5I_INVALID_HID;
}
if (dset_id >= 0) {
H5E_BEGIN_TRY
{
H5Dclose(dset_id);
}
H5E_END_TRY;
dset_id = H5I_INVALID_HID;
}
PASSED();
}
PART_END(H5Fget_name_dset_id);
PART_BEGIN(H5Fget_name_attr_id)
{
TESTING_2("H5Fget_name using attribute ID");
if ((dspace_id = H5Screate(H5S_SCALAR)) < 0) {
H5_FAILED();
printf(" couldn't create dataspace\n");
PART_ERROR(H5Fget_name_attr_id);
}
/* Create an attribute for the dataset */
if ((attr_id = H5Acreate2(file_id, GET_FILE_NAME_TEST_ATTR_NAME, H5T_NATIVE_INT, dspace_id,
H5P_DEFAULT, H5P_DEFAULT)) < 0) {
H5_FAILED();
printf(" couldn't create the attribute '%s'\n", GET_FILE_NAME_TEST_ATTR_NAME);
PART_ERROR(H5Fget_name_attr_id);
}
/* Get and verify file name from the attribute */
if (H5Fget_name(attr_id, file_name_buf, (size_t)file_name_buf_len + 1) < 0) {
H5_FAILED();
printf(" couldn't get file name %s\n", prefixed_filename);
PART_ERROR(H5Fget_name_attr_id);
}
if (HDstrncmp(file_name_buf, prefixed_filename, (size_t)file_name_buf_len)) {
H5_FAILED();
printf(" file name '%s' didn't match expected name '%s'\n", file_name_buf,
prefixed_filename);
PART_ERROR(H5Fget_name_attr_id);
}
if (dspace_id >= 0) {
H5E_BEGIN_TRY
{
H5Sclose(dspace_id);
}
H5E_END_TRY;
dspace_id = H5I_INVALID_HID;
}
if (attr_id >= 0) {
H5E_BEGIN_TRY
{
H5Aclose(attr_id);
}
H5E_END_TRY;
attr_id = H5I_INVALID_HID;
}
PASSED();
}
PART_END(H5Fget_name_attr_id);
PART_BEGIN(H5Fget_name_dtype_id)
{
TESTING_2("H5Fget_name using committed datatype ID");
/* Create a named datatype */
if ((named_dtype_id = H5Tcopy(H5T_NATIVE_INT)) < 0) {
H5_FAILED();
printf(" couldn't copy a native datatype\n");
PART_ERROR(H5Fget_name_dtype_id);
}
if (H5Tcommit2(file_id, GET_FILE_NAME_TEST_NAMED_DTYPE, named_dtype_id, H5P_DEFAULT, H5P_DEFAULT,
H5P_DEFAULT) < 0) {
H5_FAILED();
printf(" couldn't commit a named datatype\n");
PART_ERROR(H5Fget_name_dtype_id);
}
/* Get and verify file name from the committed datatype */
if (H5Fget_name(named_dtype_id, file_name_buf, (size_t)file_name_buf_len + 1) < 0) {
H5_FAILED();
printf(" couldn't get file name %s\n", prefixed_filename);
PART_ERROR(H5Fget_name_dtype_id);
}
if (HDstrncmp(file_name_buf, prefixed_filename, (size_t)file_name_buf_len)) {
H5_FAILED();
printf(" file name '%s' didn't match expected name '%s'\n", file_name_buf,
prefixed_filename);
PART_ERROR(H5Fget_name_dtype_id);
}
if (named_dtype_id >= 0) {
H5E_BEGIN_TRY
{
H5Tclose(named_dtype_id);
}
H5E_END_TRY;
named_dtype_id = H5I_INVALID_HID;
}
PASSED();
}
PART_END(H5Fget_name_dtype_id);
PART_BEGIN(H5Fget_name_dspace_id)
{
ssize_t name_len = 0;
TESTING_2("invalid H5Fget_name using dataspace ID");
if ((dspace_id = H5Screate(H5S_SCALAR)) < 0) {
H5_FAILED();
printf(" couldn't create dataspace\n");
PART_ERROR(H5Fget_name_dspace_id);
}
/* Try get file name from data space. Supposed to fail because
* it's illegal operation. */
H5E_BEGIN_TRY
{
name_len = H5Fget_name(dspace_id, file_name_buf, (size_t)file_name_buf_len + 1);
}
H5E_END_TRY;
if (name_len >= 0) {
H5_FAILED();
printf(" retrieved file name using H5Fget_name on a dataspace ID!\n");
PART_ERROR(H5Fget_name_dspace_id);
}
if (dspace_id >= 0) {
H5E_BEGIN_TRY
{
H5Sclose(dspace_id);
}
H5E_END_TRY;
dspace_id = H5I_INVALID_HID;
}
PASSED();
}
PART_END(H5Fget_name_dspace_id);
}
END_MULTIPART;
TESTING_2("test cleanup");
if (file_name_buf) {
free(file_name_buf);
file_name_buf = NULL;
}
if (H5Fclose(file_id) < 0)
TEST_ERROR;
free(prefixed_filename);
prefixed_filename = NULL;
PASSED();
return 0;
error:
H5E_BEGIN_TRY
{
if (file_name_buf)
free(file_name_buf);
H5Tclose(named_dtype_id);
H5Sclose(dspace_id);
H5Dclose(dset_id);
H5Aclose(attr_id);
H5Gclose(group_id);
H5Fclose(file_id);
}
H5E_END_TRY;
free(prefixed_filename);
return 1;
}
/*
* Cleanup temporary test files
*/
static void
cleanup_files(void)
{
remove_test_file(test_path_prefix, FILE_CREATE_TEST_FILENAME);
remove_test_file(test_path_prefix, FILE_CREATE_EXCL_FILE_NAME);
/* The below file should not get created */
/* remove_test_file(test_path_prefix, FILE_CREATE_INVALID_PARAMS_FILE_NAME); */
remove_test_file(test_path_prefix, OVERLAPPING_FILENAME);
remove_test_file(test_path_prefix, FILE_PERMISSION_TEST_FILENAME);
remove_test_file(test_path_prefix, FILE_FLUSH_TEST_FILENAME);
remove_test_file(test_path_prefix, FILE_PROPERTY_LIST_TEST_FNAME1);
remove_test_file(test_path_prefix, FILE_PROPERTY_LIST_TEST_FNAME2);
remove_test_file(test_path_prefix, FILE_INTENT_TEST_FILENAME);
remove_test_file(test_path_prefix, GET_OBJ_COUNT_TEST_FILENAME1);
remove_test_file(test_path_prefix, GET_OBJ_COUNT_TEST_FILENAME2);
remove_test_file(test_path_prefix, FILE_MOUNT_TEST_FILENAME);
remove_test_file(test_path_prefix, GET_FILE_NAME_TEST_FNAME);
}
int
H5_api_file_test(void)
{
size_t i;
int nerrors;
printf("**********************************************\n");
printf("* *\n");
printf("* API File Tests *\n");
printf("* *\n");
printf("**********************************************\n\n");
for (i = 0, nerrors = 0; i < ARRAY_LENGTH(file_tests); i++) {
nerrors += (*file_tests[i])() ? 1 : 0;
}
printf("\n");
printf("Cleaning up testing files\n");
cleanup_files();
return nerrors;
}