diff options
Diffstat (limited to 'test/cork.c')
-rw-r--r-- | test/cork.c | 2092 |
1 files changed, 2092 insertions, 0 deletions
diff --git a/test/cork.c b/test/cork.c new file mode 100644 index 0000000..8a2fc8f --- /dev/null +++ b/test/cork.c @@ -0,0 +1,2092 @@ +/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * + * 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://hdfgroup.org/HDF5/doc/Copyright.html. If you do not have * + * access to either file, you may request a copy from help@hdfgroup.org. * + * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */ + +/* Programmer: Vailin Choi + * Feb 20, 2014 + * + * This file contains tests for: + * H5Odisable_mdc_flushes() + * H5Oenable_mdc_flushes() + * H5Oare_mdc_flushes_disabled() + */ +#include "h5test.h" + +/* + * This file needs to access private information from the H5C package. + * This file also needs to access the metadata cache testing code. + */ +#define H5C_FRIEND /*suppress error about including H5Cpkg */ +#define H5C_TESTING /*suppress warning about H5C testing funcs*/ +#include "H5Cpkg.h" /* Cache */ + + +/* ============ */ +/* Test Defines */ +/* ============ */ + +#define FILENAME "test_cork.h5" +#define ATTR "ATTR" +#define DSET "DSET" +#define DSET_BT1 "DSET_BT1" +#define DSET_COMPACT "DSET_COMPACT" +#define DSET_CONTIG "DSET_CONTIG" +#define DSET_EA "DSET_EA" +#define DSET_BT2 "DSET_BT2" +#define DSET_FA "DSET_FA" +#define DSET_NONE "DSET_NONE" +#define GRP "GRP" +#define GRP2 "GRP2" +#define GRP3 "GRP3" +#define DT "DT" +#define DT2 "DT2" +#define DT3 "DT3" +#define GRP_ATTR "GRP_ATTR" +#define DSET_ATTR "DSET_ATTR" +#define DT_ATTR "DT_ATTR" + +#define RANK 2 +#define DIM0 5 +#define DIM1 10 +#define DIMS0 50 +#define DIMS1 100 + + +/* ===================== */ +/* Function Declarations */ +/* ===================== */ + +/* Tests */ +static unsigned test_objs_cork(hbool_t new_format); +static unsigned test_dset_cork(hbool_t new_format); +static unsigned verify_old_dset_cork(void); +static unsigned verify_obj_dset_cork(void); +static unsigned verify_dset_cork(hbool_t new_format); +static unsigned verify_group_cork(void); +static unsigned verify_named_cork(void); +static unsigned verify_multiple_cork(void); + + +/*------------------------------------------------------------------------- + * Function: verify_old_dset_cork + * + * Purpose: This function verifies corking operation for datasets + * created with old library format. Cache entries associated with the + * object tag are checked for the correct cork status. + * + * Return: 0 on Success, 1 on Failure + * + * Programmer: Vailin Choi; Feb 2014 + * + *------------------------------------------------------------------------- + */ +static unsigned +verify_old_dset_cork(void) +{ + /* Variable Declarations */ + hid_t fid = -1; /* File ID */ + hid_t did = -1, did2 = -1, did3 = -1; /* Dataset IDs */ + hid_t dcpl = -1, dcpl2 = -1, dcpl3 = -1; /* Dataset creation property lists */ + hid_t sid = -1, sid2 = -1, sid3 = -1; /* Dataspace IDs */ + hsize_t dims[2] = {100, 20}; /* Dataset dimension sizes */ + hsize_t max_dims[2] = {100, H5S_UNLIMITED}; /* Dataset maximum dimension sizes */ + hsize_t chunk_dims[2] = {2, 5}; /* Dataset chunked dimension sizes */ + int buf[100][20]; /* Data buffer */ + int i = 0, j = 0; /* Local index variable */ + H5O_info_t oinfo, oinfo2, oinfo3; /* Object metadata information */ + hsize_t dims2[2] = {8, 16}; /* Dataset dimension sizes */ + + /* Testing Macro */ + TESTING("cork status for datasets with old format"); + + /* Create the file */ + if((fid = H5Fcreate(FILENAME, H5F_ACC_TRUNC, H5P_DEFAULT, H5P_DEFAULT)) < 0) + TEST_ERROR + + /* Create dcpl */ + if((dcpl = H5Pcreate(H5P_DATASET_CREATE)) < 0) + FAIL_STACK_ERROR + + /* Set to use chunked dataset */ + if(H5Pset_chunk(dcpl, 2, chunk_dims) < 0) + FAIL_STACK_ERROR + + /* Create chunked dataset with v1-btree indexing: DSET_BT1 */ + if((sid = H5Screate_simple(2, dims, max_dims)) < 0) + TEST_ERROR + if((did = H5Dcreate2(fid, DSET_BT1, H5T_NATIVE_INT, sid, H5P_DEFAULT, dcpl, H5P_DEFAULT)) < 0) + TEST_ERROR + + /* Get dataset object header address: DSET_BT1 */ + if(H5Oget_info(did, &oinfo) < 0) + TEST_ERROR + + /* Cork the dataset: DSET_BT1 */ + if(H5Odisable_mdc_flushes(did) < 0) + TEST_ERROR + + /* Verify cork status */ + if(H5C__verify_cork_tag_test(fid, oinfo.addr, TRUE) < 0) + TEST_ERROR + + /* Initialize data buffer */ + for(i = 0; i < (int)dims[0]; i++) + for(j = 0; j < (int)dims[1]; j++) + buf[i][j] = (i + 1) * (j + 1); + + /* Write to the dataset: DSET_BT1 */ + if(H5Dwrite(did, H5T_NATIVE_INT, H5S_ALL, H5S_ALL, H5P_DEFAULT, buf) < 0) + TEST_ERROR + + /* Verify the cork status for DSET_BT1 */ + if(H5C__verify_cork_tag_test(fid, oinfo.addr, TRUE) < 0) + TEST_ERROR + + /* Create compact dataset: DSET_COMPACT */ + if((sid2 = H5Screate_simple(2, dims2, NULL)) < 0) + FAIL_STACK_ERROR + if((dcpl2 = H5Pcreate(H5P_DATASET_CREATE)) < 0) + FAIL_STACK_ERROR + if(H5Pset_layout(dcpl2, H5D_COMPACT) < 0) + FAIL_STACK_ERROR + if(H5Pset_alloc_time(dcpl2, H5D_ALLOC_TIME_EARLY) < 0) + FAIL_STACK_ERROR + if((did2 = H5Dcreate2(fid, DSET_COMPACT, H5T_NATIVE_INT, sid2, H5P_DEFAULT, dcpl2, H5P_DEFAULT)) < 0) + FAIL_STACK_ERROR + + /* Get dataset object address */ + if(H5Oget_info(did2, &oinfo2) < 0) + TEST_ERROR + + /* Cork the dataset: DSET_COMPACT */ + if(H5Odisable_mdc_flushes(did2) < 0) + TEST_ERROR + + /* Verify cork status */ + if(H5C__verify_cork_tag_test(fid, oinfo2.addr, TRUE) < 0) + TEST_ERROR + + /* Closing */ + if(H5Dclose(did) < 0) + TEST_ERROR + if(H5Sclose(sid) < 0) + TEST_ERROR + if(H5Pclose(dcpl) < 0) + TEST_ERROR + + if(H5Dclose(did2) < 0) + TEST_ERROR + if(H5Sclose(sid2) < 0) + TEST_ERROR + if(H5Pclose(dcpl2) < 0) + TEST_ERROR + + if(H5Fclose(fid) < 0) + TEST_ERROR + + /* Reopen the file */ + if((fid = H5Fopen(FILENAME, H5F_ACC_RDWR, H5P_DEFAULT)) < 0) + TEST_ERROR + + /* Initialize data buffer */ + for(i = 0; i < (int)dims[0]; i++) + for(j = 0; j < (int)dims[1]; j++) + buf[i][j] = (i + 1) * (j + 1); + + /* Open and write to the dataset: DSET_BT1 */ + if((did = H5Dopen2(fid, DSET_BT1, H5P_DEFAULT)) < 0) + TEST_ERROR + + /* Create contiguous dataset: DSET_CONTIG */ + if((sid3 = H5Screate_simple(2, dims2, NULL)) < 0) + FAIL_STACK_ERROR + if((dcpl3 = H5Pcreate(H5P_DATASET_CREATE)) < 0) + FAIL_STACK_ERROR + if(H5Pset_layout(dcpl3, H5D_CONTIGUOUS) < 0) + FAIL_STACK_ERROR + if((did3 = H5Dcreate2(fid, DSET_CONTIG, H5T_NATIVE_INT, sid3, H5P_DEFAULT, dcpl3, H5P_DEFAULT)) < 0) + FAIL_STACK_ERROR + + /* Get dataset object address: DSET_CONTIG */ + if(H5Oget_info(did3, &oinfo3) < 0) + TEST_ERROR + + /* Cork the dataset: DSET_CONTIG */ + if(H5Odisable_mdc_flushes(did3) < 0) + TEST_ERROR + + /* Verify the cork status for DSET_CONTIG */ + if(H5C__verify_cork_tag_test(fid, oinfo3.addr, TRUE) < 0) + TEST_ERROR + + /* Verify the cork status for DSET_BT1 */ + if(H5C__verify_cork_tag_test(fid, oinfo.addr, FALSE) < 0) + TEST_ERROR + + /* Un-cork the dataset: DSET_CONTIG */ + if(H5Oenable_mdc_flushes(did3) < 0) + TEST_ERROR + + /* Verify the cork status for DSET_CONTIG */ + if(H5C__verify_cork_tag_test(fid, oinfo3.addr, FALSE) < 0) + TEST_ERROR + + /* Closing */ + if(H5Dclose(did3) < 0) + TEST_ERROR + if(H5Pclose(dcpl3) < 0) + TEST_ERROR + if(H5Dclose(did) < 0) + TEST_ERROR + if(H5Fclose(fid) < 0) + TEST_ERROR + + PASSED(); + return 0; + +error: + H5E_BEGIN_TRY { + H5Sclose(sid); + H5Sclose(sid2); + H5Sclose(sid3); + H5Dclose(did); + H5Dclose(did2); + H5Dclose(did3); + H5Pclose(dcpl); + H5Pclose(dcpl2); + H5Pclose(dcpl3); + H5Fclose(fid); + } H5E_END_TRY; + return 1; +} /* verify_old_dset_cork */ + + +/*------------------------------------------------------------------------- + * Function: verify_obj_dset_cork + * + * Purpose: This function verifies corking operations for dataset objects. + * Cache entries associated with the object tag are checked + * for the correct cork status. + * + * Return: 0 on Success, 1 on Failure + * + * Programmer: Vailin Choi; Feb 2014 + * + *------------------------------------------------------------------------- + */ +static unsigned +verify_obj_dset_cork(void) +{ + /* Variable Declarations */ + hid_t fid = -1; /* File ID */ + hid_t fapl = -1; /* File access property list */ + hid_t aid = -1; /* Attribute ID */ + hid_t sid = -1, sid2 = -1; /* Dataspace IDs */ + hid_t did = -1, did2 = -1; /* Dataset IDs */ + hid_t oid = -1; /* Object ID */ + hid_t dcpl2; /* Dataset creation property list */ + int i = 0; /* Local index variable */ + hsize_t dim[1] = {100}; /* Dataset dimension size */ + hsize_t chunk_dim[1] = {7}; /* Dataset chunk dimension size */ + H5O_info_t oinfo, oinfo2; /* Object metadata information */ + char attrname[500]; /* Name of attribute */ + unsigned flags; /* File access flags */ + + TESTING("cork status for dataset objects with attributes"); + + /* Create fapl */ + if((fapl = H5Pcreate(H5P_FILE_ACCESS)) < 0) + TEST_ERROR + /* Set to use latest format */ + if(H5Pset_libver_bounds(fapl, H5F_LIBVER_LATEST, H5F_LIBVER_LATEST) < 0) + TEST_ERROR + + /* Create the file with/without SWMR access */ + flags = H5F_ACC_TRUNC; + if((fid = H5Fcreate(FILENAME, flags, H5P_DEFAULT, fapl)) < 0) + TEST_ERROR + + /* Create dataspace */ + if((sid = H5Screate(H5S_SCALAR)) < 0) + TEST_ERROR + + /* Create dataset: DSET */ + if((did = H5Dcreate2(fid, DSET, H5T_NATIVE_UCHAR, sid, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0) + TEST_ERROR + + /* Get dataset object header address */ + if(H5Oget_info(did, &oinfo) < 0) + TEST_ERROR + + /* Verify cork status of the dataset: DSET */ + if(H5C__verify_cork_tag_test(fid, oinfo.addr, FALSE) < 0) + TEST_ERROR + + /* Cork the dataset: DSET */ + if(H5Odisable_mdc_flushes(did) < 0) + TEST_ERROR + + /* Attach and write to an attribute to the dataset: DSET */ + if((aid = H5Acreate2(did, ATTR, H5T_NATIVE_UINT, sid, H5P_DEFAULT, H5P_DEFAULT)) < 0) + TEST_ERROR + + /* Verify cork status of the dataset: DSET */ + if(H5C__verify_cork_tag_test(fid, oinfo.addr, TRUE) < 0) + TEST_ERROR + + /* Close the attribute */ + if(H5Aclose(aid) < 0) + TEST_ERROR + + /* Verify cork status of the dataset: DSET */ + if(H5C__verify_cork_tag_test(fid, oinfo.addr, TRUE) < 0) + TEST_ERROR + + /* Create dcpl */ + if((dcpl2 = H5Pcreate(H5P_DATASET_CREATE)) < 0) + TEST_ERROR + /* Set to early allocation for dataset space */ + if(H5Pset_alloc_time(dcpl2, H5D_ALLOC_TIME_EARLY) < 0) + TEST_ERROR + + /* Create chunked dataset with implicit indexing: DSET_NONE */ + if(H5Pset_chunk(dcpl2, 1, chunk_dim) < 0) + FAIL_STACK_ERROR + if((sid2 = H5Screate_simple(1, dim, NULL)) < 0) + TEST_ERROR + if((did2 = H5Dcreate2(fid, DSET_NONE, H5T_NATIVE_INT, sid2, H5P_DEFAULT, dcpl2, H5P_DEFAULT)) < 0) + TEST_ERROR + + /* Get dataset object header address */ + if(H5Oget_info(did2, &oinfo2) < 0) + TEST_ERROR + + /* Cork the dataset: DSET_NONE */ + if(H5Odisable_mdc_flushes(did2) < 0) + TEST_ERROR + + /* Attach 8 attributes to the dataset */ + for(i = 0;i < 8; i++) { + sprintf(attrname, "attr %d", i); + if((aid = H5Acreate2(did2, attrname, H5T_NATIVE_UINT, sid2, H5P_DEFAULT, H5P_DEFAULT)) < 0) + TEST_ERROR + if(H5Awrite(aid, H5T_NATIVE_UINT, &i) < 0) + TEST_ERROR + if(H5Aclose(aid) < 0) + TEST_ERROR + } /* end for */ + + /* Verify cork status of the dataset: DSET_NONE */ + if(H5C__verify_cork_tag_test(fid, oinfo2.addr, TRUE) < 0) + TEST_ERROR + + /* Closing */ + if(H5Oclose(did) < 0) + TEST_ERROR + if(H5Oclose(did2) < 0) + TEST_ERROR + if(H5Sclose(sid) < 0) + TEST_ERROR + if(H5Sclose(sid2) < 0) + TEST_ERROR + if(H5Pclose(dcpl2) < 0) + TEST_ERROR + if(H5Fclose(fid) < 0) + TEST_ERROR + + /* Re-open the file */ + flags = H5F_ACC_RDWR; + if((fid = H5Fopen(FILENAME, flags, fapl)) < 0) + TEST_ERROR + + /* Open the dataset object: DSET_NONE */ + if((oid = H5Oopen(fid, DSET_NONE, H5P_DEFAULT)) < 0) + TEST_ERROR + + /* Verify cork status of the dataset: DSET */ + if(H5C__verify_cork_tag_test(fid, oinfo2.addr, FALSE) < 0) + TEST_ERROR + + /* Open the attribute attached to the dataset object: DSET_NONE */ + if((aid = H5Aopen_by_idx(oid, ".", H5_INDEX_NAME, H5_ITER_INC, (hsize_t)4, H5P_DEFAULT, H5P_DEFAULT)) < 0) + TEST_ERROR + + /* Cork the dataset: DSET_NONE */ + if(H5Odisable_mdc_flushes(oid) < 0) + TEST_ERROR + + /* Verify cork status of the dataset: DSET_NONE */ + if(H5C__verify_cork_tag_test(fid, oinfo2.addr, TRUE) < 0) + TEST_ERROR + + /* Close the attribute */ + if(H5Aclose(aid) < 0) + TEST_ERROR + + /* Verify cork status of the dataset: DSET */ + if(H5C__verify_cork_tag_test(fid, oinfo.addr, TRUE) < 0) + TEST_ERROR + + /* Closing */ + if(H5Oclose(oid) < 0) + TEST_ERROR + if(H5Pclose(fapl) < 0) + TEST_ERROR + if(H5Fclose(fid) < 0) + TEST_ERROR + + PASSED(); + return 0; + +error: + H5E_BEGIN_TRY { + H5Aclose(aid); + H5Sclose(sid); + H5Sclose(sid2); + H5Dclose(did); + H5Dclose(did2); + H5Oclose(oid); + H5Pclose(dcpl2); + H5Pclose(fapl); + H5Fclose(fid); + } H5E_END_TRY; + return 1; +} /* verify_obj_dset_cork */ + + +/*------------------------------------------------------------------------- + * Function: verify_dset_cork + * + * Purpose: This function verifies corking operations for chunked datasets + * with different indexing types. + * Cache entries associated with the object tag are checked + * for the correct cork status. + * + * Return: 0 on Success, 1 on Failure + * + * Programmer: Vailin Choi; Feb 2014 + * + *------------------------------------------------------------------------- + */ +static unsigned +verify_dset_cork(hbool_t new_format) +{ + /* Variable Declarations */ + hid_t fid = -1; /* File ID */ + hid_t fapl = -1; /* File access property list */ + hid_t did = -1, did2 = -1, did3 = -1; /* Dataset IDs */ + hid_t dcpl = -1; /* Dataset creation property list */ + hid_t sid = -1, sid2 = -1, sid3 = -1; /* Dataspace IDs */ + hsize_t dims[2] = {100, 20}; /* Dataset dimension sizes */ + hsize_t max_dims[2] = {100, H5S_UNLIMITED}; /* Dataset maximum dimension sizes */ + hsize_t chunk_dims[2] = {2, 5}; /* Dataset chunked dimension sizes */ + int buf[100][20]; int i = 0, j = 0; /* Data buffer */ + H5O_info_t oinfo, oinfo2, oinfo3; /* Object metadata information */ + unsigned flags; /* File access flags */ + + /* Testing Macro */ + if(new_format) { + TESTING("cork status for chunked datasets with different indexing types (latest)"); + } else { + TESTING("cork status for chunked datasets with different indexing types (non-latest)"); + } /* end if */ + + /* Create fapl */ + if((fapl = H5Pcreate(H5P_FILE_ACCESS)) < 0) + TEST_ERROR + if(new_format) { + /* Set to use latest format */ + if(H5Pset_libver_bounds(fapl, H5F_LIBVER_LATEST, H5F_LIBVER_LATEST) < 0) + TEST_ERROR + } /* end if */ + + /* Create the file */ + flags = H5F_ACC_TRUNC; + if((fid = H5Fcreate(FILENAME, flags, H5P_DEFAULT, fapl)) < 0) + TEST_ERROR + + /* Create dcpl */ + if((dcpl = H5Pcreate(H5P_DATASET_CREATE)) < 0) + FAIL_STACK_ERROR + + /* Set to use chunked dataset */ + if(H5Pset_chunk(dcpl, 2, chunk_dims) < 0) + FAIL_STACK_ERROR + + /* Create chunked dataset with extensive array indexing: DSET_EA */ + if((sid = H5Screate_simple(2, dims, max_dims)) < 0) + TEST_ERROR + if((did = H5Dcreate2(fid, DSET_EA, H5T_NATIVE_INT, sid, H5P_DEFAULT, dcpl, H5P_DEFAULT)) < 0) + TEST_ERROR + + /* Get dataset object header address: DSET_EA */ + if(H5Oget_info(did, &oinfo) < 0) + TEST_ERROR + + /* Cork the dataset: DSET_EA */ + if(H5Odisable_mdc_flushes(did) < 0) + TEST_ERROR + + /* Verify cork status */ + if(H5C__verify_cork_tag_test(fid, oinfo.addr, TRUE) < 0) + TEST_ERROR + + /* Create chunked dataset with fixed array indexing: DSET_FA */ + if((sid2 = H5Screate_simple(2, dims, NULL)) < 0) + TEST_ERROR + if((did2 = H5Dcreate2(fid, DSET_FA, H5T_NATIVE_INT, sid2, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0) + TEST_ERROR + + /* Get dataset object header address: DSET_FA */ + if(H5Oget_info(did2, &oinfo2) < 0) + TEST_ERROR + + /* Cork the dataset: DSET_FA */ + if(H5Odisable_mdc_flushes(did2) < 0) + TEST_ERROR + + /* Uncork the dataset: DSET_EA */ + if(H5Oenable_mdc_flushes(did) < 0) + TEST_ERROR + + /* Verify the cork status for DSET_FA */ + if(H5C__verify_cork_tag_test(fid, oinfo2.addr, TRUE) < 0) + TEST_ERROR + + /* Verify the cork status for DSET_EA */ + if(H5C__verify_cork_tag_test(fid, oinfo.addr, FALSE) < 0) + TEST_ERROR + + /* Create chunked dataset with v2-Btree indexing */ + max_dims[0] = H5S_UNLIMITED; + if((sid3 = H5Screate_simple(2, dims, max_dims)) < 0) + TEST_ERROR + if((did3 = H5Dcreate2(fid, DSET_BT2, H5T_NATIVE_INT, sid3, H5P_DEFAULT, dcpl, H5P_DEFAULT)) < 0) + TEST_ERROR + + /* Get dataset object header address: DSET_BT2 */ + if(H5Oget_info(did3, &oinfo3) < 0) + TEST_ERROR + + /* Cork the dataset: DSET_BT2 */ + if(H5Odisable_mdc_flushes(did3) < 0) + TEST_ERROR + + /* Verify the cork status for DSET_BT2 */ + if(H5C__verify_cork_tag_test(fid, oinfo3.addr, TRUE) < 0) + TEST_ERROR + + /* Closing */ + if(H5Dclose(did3) < 0) + TEST_ERROR + if(H5Sclose(sid3) < 0) + TEST_ERROR + + if(H5Dclose(did2) < 0) + TEST_ERROR + if(H5Sclose(sid2) < 0) + TEST_ERROR + + if(H5Dclose(did) < 0) + TEST_ERROR + if(H5Sclose(sid) < 0) + TEST_ERROR + + if(H5Pclose(dcpl) < 0) + TEST_ERROR + if(H5Fclose(fid) < 0) + TEST_ERROR + + /* Reopen the file */ + flags = H5F_ACC_RDWR; + if((fid = H5Fopen(FILENAME, flags, fapl)) < 0) + TEST_ERROR + + /* Initialize data buffer */ + for(i = 0; i < (int)dims[0]; i++) + for(j = 0; j < (int)dims[1]; j++) + buf[i][j] = (i + 1) * (j + 1); + + /* Open and write to the dataset: DSET_EA */ + if((did = H5Dopen2(fid, DSET_EA, H5P_DEFAULT)) < 0) + TEST_ERROR + if(H5Dwrite(did, H5T_NATIVE_INT, H5S_ALL, H5S_ALL, H5P_DEFAULT, buf) < 0) + TEST_ERROR + + /* Verify the cork status for DSET_EA */ + if(H5C__verify_cork_tag_test(fid, oinfo.addr, FALSE) < 0) + TEST_ERROR + + /* Open and write to the dataset: DSET_FA */ + if((did2 = H5Dopen2(fid, DSET_FA, H5P_DEFAULT)) < 0) + TEST_ERROR + if(H5Dwrite(did2, H5T_NATIVE_INT, H5S_ALL, H5S_ALL, H5P_DEFAULT, buf) < 0) + TEST_ERROR + + /* Cork the dataset: DSET_FA */ + if(H5Odisable_mdc_flushes(did2) < 0) + TEST_ERROR + + /* Verify the cork status for DSET_FA */ + if(H5C__verify_cork_tag_test(fid, oinfo2.addr, TRUE) < 0) + TEST_ERROR + + /* Open and write to the dataset: DSET_BT2 */ + if((did3 = H5Dopen2(fid, DSET_BT2, H5P_DEFAULT)) < 0) + TEST_ERROR + if(H5Dwrite(did3, H5T_NATIVE_INT, H5S_ALL, H5S_ALL, H5P_DEFAULT, buf) < 0) + TEST_ERROR + + /* Verify the cork status for DSET_BT2 */ + if(H5C__verify_cork_tag_test(fid, oinfo3.addr, FALSE) < 0) + TEST_ERROR + + /* Cork the dataset: DSET_BT2 */ + if(H5Odisable_mdc_flushes(did3) < 0) + TEST_ERROR + + /* Verify the cork status for DSET_BT2 */ + if(H5C__verify_cork_tag_test(fid, oinfo3.addr, TRUE) < 0) + TEST_ERROR + + /* Closing */ + if(H5Dclose(did) < 0) + TEST_ERROR + if(H5Dclose(did2) < 0) + TEST_ERROR + if(H5Dclose(did3) < 0) + TEST_ERROR + if(H5Pclose(fapl) < 0) + TEST_ERROR + if(H5Fclose(fid) < 0) + TEST_ERROR + + PASSED(); + return 0; + +error: + H5E_BEGIN_TRY { + H5Sclose(sid); + H5Sclose(sid2); + H5Sclose(sid3); + H5Dclose(did); + H5Dclose(did2); + H5Dclose(did3); + H5Pclose(dcpl); + H5Pclose(fapl); + H5Fclose(fid); + } H5E_END_TRY; + return 1; +} /* verify_dset_cork */ + + + +/*------------------------------------------------------------------------- + * Function: verify_group_cork + * + * Purpose: This function verifies corking operations for groups. + * Cache entries associated with the object tag are checked + * for the correct cork status. + * + * Return: 0 on Success, 1 on Failure + * + * Programmer: Vailin Choi; Feb 2014 + * + *------------------------------------------------------------------------- + */ +static unsigned +verify_group_cork(void) +{ + /* Variable Declarations */ + hid_t fid = -1; /* File ID */ + hid_t fapl = -1; /* File access property list */ + hid_t gid = -1, gid2 = -1, gid3 = -1; /* Group IDs */ + H5O_info_t oinfo, oinfo2, oinfo3; /* Object metadata information */ + hid_t aid; /* Attribute ID */ + hid_t sid; /* Dataspace ID */ + char attrname[500]; /* Name of attribute */ + unsigned flags; /* File access flags */ + int i = 0; /* Local index variable */ + + /* Testing Macro */ + TESTING("cork status for groups"); + + /* Create fapl */ + if((fapl = H5Pcreate(H5P_FILE_ACCESS)) < 0) + TEST_ERROR + /* Set to use latest format */ + if(H5Pset_libver_bounds(fapl, H5F_LIBVER_LATEST, H5F_LIBVER_LATEST) < 0) + TEST_ERROR + + /* Create the file */ + flags = H5F_ACC_TRUNC; + if((fid = H5Fcreate(FILENAME, flags, H5P_DEFAULT, fapl)) < 0) + TEST_ERROR + + /* Create 3 groups */ + if((gid = H5Gcreate2(fid, GRP, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0) + TEST_ERROR + if((gid2 = H5Gcreate2(gid, GRP2, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0) + TEST_ERROR + if((gid3 = H5Gcreate2(gid2, GRP3, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0) + TEST_ERROR + + /* Cork the second group: GRP2 */ + if(H5Odisable_mdc_flushes(gid2) < 0) + TEST_ERROR + + /* Get group object header addresses */ + if(H5Oget_info(gid, &oinfo) < 0) + TEST_ERROR + if(H5Oget_info(gid2, &oinfo2) < 0) + TEST_ERROR + if(H5Oget_info(gid3, &oinfo3) < 0) + TEST_ERROR + + /* Verify cork status of the groups */ + if(H5C__verify_cork_tag_test(fid, oinfo.addr, FALSE) < 0) + TEST_ERROR + if(H5C__verify_cork_tag_test(fid, oinfo2.addr, TRUE) < 0) + TEST_ERROR + if(H5C__verify_cork_tag_test(fid, oinfo3.addr, FALSE) < 0) + TEST_ERROR + + /* Close the second group: GRP2 */ + if(H5Gclose(gid2) < 0) + TEST_ERROR + + /* Re-open the second group: GRP2 */ + if((gid2 = H5Gopen2(gid, GRP2, H5P_DEFAULT)) < 0) + FAIL_STACK_ERROR + + /* Verify cork status of the second group: GRP2 */ + if(H5C__verify_cork_tag_test(fid, oinfo2.addr, FALSE) < 0) + TEST_ERROR + + /* Closing */ + if(H5Gclose(gid) < 0) + TEST_ERROR + if(H5Gclose(gid2) < 0) + TEST_ERROR + if(H5Gclose(gid3) < 0) + TEST_ERROR + if(H5Fclose(fid) < 0) + TEST_ERROR + + /* Re-open the file and the three groups */ + flags = H5F_ACC_RDWR; + if((fid = H5Fopen(FILENAME, flags, fapl)) < 0) + FAIL_STACK_ERROR + if((gid = H5Gopen2(fid, GRP, H5P_DEFAULT)) < 0) + FAIL_STACK_ERROR + if((gid2 = H5Gopen2(gid, GRP2, H5P_DEFAULT)) < 0) + FAIL_STACK_ERROR + if((gid3 = H5Gopen2(gid2, GRP3, H5P_DEFAULT)) < 0) + FAIL_STACK_ERROR + + /* Create dataspace */ + if((sid = H5Screate(H5S_SCALAR)) < 0) + TEST_ERROR + + /* Attach 8 attributes to the third group: GRP3 */ + for(i = 0;i < 8; i++) { + sprintf(attrname, "attr %d", i); + if((aid = H5Acreate2(gid3, attrname, H5T_NATIVE_UINT, sid, H5P_DEFAULT, H5P_DEFAULT)) < 0) + TEST_ERROR + if(H5Awrite(aid, H5T_NATIVE_UINT, &i) < 0) + TEST_ERROR + /* Cork the third group while attaching attributes */ + if(i == 3) { + if(H5Odisable_mdc_flushes(gid3) < 0) + TEST_ERROR + if(H5C__verify_cork_tag_test(fid, oinfo3.addr, TRUE) < 0) + TEST_ERROR + } + if(H5Aclose(aid) < 0) + TEST_ERROR + } /* end for */ + + /* Verify cork status of the third group: GRP3 */ + if(H5C__verify_cork_tag_test(fid, oinfo3.addr, TRUE) < 0) + TEST_ERROR + + /* Closing */ + if(H5Gclose(gid) < 0) + TEST_ERROR + if(H5Gclose(gid2) < 0) + TEST_ERROR + if(H5Gclose(gid3) < 0) + TEST_ERROR + if(H5Sclose(sid) < 0) + TEST_ERROR + if(H5Pclose(fapl) < 0) + TEST_ERROR + if(H5Fclose(fid) < 0) + TEST_ERROR + + PASSED(); + return 0; + +error: + H5E_BEGIN_TRY { + H5Gclose(gid); + H5Gclose(gid2); + H5Gclose(gid3); + H5Sclose(sid); + H5Pclose(fapl); + H5Fclose(fid); + } H5E_END_TRY; + return 1; +} /* verify_group_cork */ + + +/*------------------------------------------------------------------------- + * Function: verify_named_cork + * + * Purpose: This function verifies corking operations for named datatypes. + * Cache entries associated with the object tag are checked + * for the correct cork status. + * + * Return: 0 on Success, 1 on Failure + * + * Programmer: Vailin Choi; Feb 2014 + * + *------------------------------------------------------------------------- + */ +static unsigned +verify_named_cork(void) +{ + /* Variable Declarations */ + hid_t fid = -1; /* File ID */ + hid_t fapl = -1; /* File access property list */ + hid_t tid = -1, tid2 = -1, tid3 = -1; /* Datatype IDs */ + hid_t gid = -1, gid2 = -1; /* Group IDs */ + H5O_info_t oinfo, oinfo2, oinfo3, oinfo4; /* Object metadata information */ + hid_t aid = -1; /* Attribute ID */ + hid_t sid; /* Dataspace ID */ + hid_t did; /* Dataset ID */ + char attrname[500]; /* Name of attribute */ + unsigned flags; /* File access flags */ + int i = 0; /* Local index variable */ + + /* Testing Macro */ + TESTING("cork status for named datatypes"); + + /* Create fapl */ + if((fapl = H5Pcreate(H5P_FILE_ACCESS)) < 0) + TEST_ERROR + /* Set to use latest format */ + if(H5Pset_libver_bounds(fapl, H5F_LIBVER_LATEST, H5F_LIBVER_LATEST) < 0) + TEST_ERROR + + /* Create the file */ + flags = H5F_ACC_TRUNC; + if((fid = H5Fcreate(FILENAME, flags, H5P_DEFAULT, fapl)) < 0) + TEST_ERROR + + /* Create 3 copies of datatypes */ + if((tid = H5Tcopy(H5T_NATIVE_INT)) < 0) + TEST_ERROR + if((tid2 = H5Tcopy(H5T_NATIVE_LONG)) < 0) + TEST_ERROR + if((tid3 = H5Tcopy(H5T_NATIVE_CHAR)) < 0) + TEST_ERROR + + /* Commit datatype /DT */ + if(H5Tcommit2(fid, DT, tid, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT) < 0) + TEST_ERROR + + /* Create /GRP */ + if((gid = H5Gcreate2(fid, GRP, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0) + TEST_ERROR + /* Commit datatype /GRP/DT2 */ + if(H5Tcommit2(gid, DT2, tid2, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT) < 0) + TEST_ERROR + + /* Create /GRP/GRP2 */ + if((gid2 = H5Gcreate2(gid, GRP2, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0) + TEST_ERROR + /* Commit datatype /GRP/GRP2/DT3 */ + if(H5Tcommit2(gid2, DT3, tid3, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT) < 0) + TEST_ERROR + + /* Cork 2 named datatypes: /DT and /GRP/GRP2/DT3 */ + if(H5Odisable_mdc_flushes(tid) < 0) + TEST_ERROR + if(H5Odisable_mdc_flushes(tid3) < 0) + TEST_ERROR + + /* Get named datatype object header addresses */ + if(H5Oget_info(tid, &oinfo) < 0) + TEST_ERROR + if(H5Oget_info(tid2, &oinfo2) < 0) + TEST_ERROR + if(H5Oget_info(tid3, &oinfo3) < 0) + TEST_ERROR + + /* Verify cork status of the named datatypes */ + if(H5C__verify_cork_tag_test(fid, oinfo.addr, TRUE) < 0) + TEST_ERROR + if(H5C__verify_cork_tag_test(fid, oinfo2.addr, FALSE) < 0) + TEST_ERROR + if(H5C__verify_cork_tag_test(fid, oinfo3.addr, TRUE) < 0) + TEST_ERROR + + /* Close the datatypes */ + if(H5Tclose(tid) < 0) + TEST_ERROR + if(H5Tclose(tid2) < 0) + TEST_ERROR + if(H5Tclose(tid3) < 0) + TEST_ERROR + + /* Re-open the named datatypes */ + if((tid = H5Topen2(fid, DT, H5P_DEFAULT)) < 0) + FAIL_STACK_ERROR + if((tid2 = H5Topen2(gid, DT2, H5P_DEFAULT)) < 0) + FAIL_STACK_ERROR + if((tid3 = H5Topen2(gid2, DT3, H5P_DEFAULT)) < 0) + FAIL_STACK_ERROR + + /* Verify cork status of the named datatypes */ + if(H5C__verify_cork_tag_test(fid, oinfo.addr, FALSE) < 0) + TEST_ERROR + if(H5C__verify_cork_tag_test(fid, oinfo2.addr, FALSE) < 0) + TEST_ERROR + if(H5C__verify_cork_tag_test(fid, oinfo3.addr, FALSE) < 0) + TEST_ERROR + + /* Closing */ + if(H5Tclose(tid) < 0) + TEST_ERROR + if(H5Tclose(tid2) < 0) + TEST_ERROR + if(H5Tclose(tid3) < 0) + TEST_ERROR + if(H5Gclose(gid) < 0) + TEST_ERROR + if(H5Gclose(gid2) < 0) + TEST_ERROR + if(H5Fclose(fid) < 0) + TEST_ERROR + + + /* Re-open the file and the three groups */ + flags = H5F_ACC_RDWR; + if((fid = H5Fopen(FILENAME, flags, fapl)) < 0) + FAIL_STACK_ERROR + if((gid = H5Gopen2(fid, GRP, H5P_DEFAULT)) < 0) + FAIL_STACK_ERROR + if((gid2 = H5Gopen2(gid, GRP2, H5P_DEFAULT)) < 0) + FAIL_STACK_ERROR + + /* Re-open the named datatypes */ + if((tid = H5Topen2(fid, DT, H5P_DEFAULT)) < 0) + FAIL_STACK_ERROR + if((tid2 = H5Topen2(gid, DT2, H5P_DEFAULT)) < 0) + FAIL_STACK_ERROR + if((tid3 = H5Topen2(gid2, DT3, H5P_DEFAULT)) < 0) + FAIL_STACK_ERROR + + /* Cork the datatype: DT2 */ + if(H5Odisable_mdc_flushes(tid2) < 0) + TEST_ERROR + + /* Create dataspace */ + if((sid = H5Screate(H5S_SCALAR)) < 0) + TEST_ERROR + + /* Attach 8 attributes to datatype: DT3 */ + for(i = 0;i < 8; i++) { + sprintf(attrname, "attr %d", i); + if((aid = H5Acreate2(tid3, attrname, H5T_NATIVE_UINT, sid, H5P_DEFAULT, H5P_DEFAULT)) < 0) + TEST_ERROR + if(H5Awrite(aid, H5T_NATIVE_UINT, &i) < 0) + TEST_ERROR + /* Cork the datatype while attaching attributes */ + if(i == 3) { + if(H5Odisable_mdc_flushes(tid3) < 0) + TEST_ERROR + if(H5C__verify_cork_tag_test(fid, oinfo3.addr, TRUE) < 0) + TEST_ERROR + } + if(H5Aclose(aid) < 0) + TEST_ERROR + } /* end for */ + + /* Create a dataset with named datatype: DT */ + if((did = H5Dcreate2(fid, DSET, tid, sid, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0) + FAIL_STACK_ERROR + + /* Get dataset object header address */ + if(H5Oget_info(did, &oinfo4) < 0) + TEST_ERROR + + /* Cork the dataset: DSET */ + if(H5Odisable_mdc_flushes(did) < 0) + TEST_ERROR + + /* Verify cork status of the datatype: DT */ + if(H5C__verify_cork_tag_test(fid, oinfo.addr, FALSE) < 0) + TEST_ERROR + /* Verify cork status of the datatype: DT2 */ + if(H5C__verify_cork_tag_test(fid, oinfo2.addr, TRUE) < 0) + TEST_ERROR + /* Verify cork status of the datatype: DT3 */ + if(H5C__verify_cork_tag_test(fid, oinfo3.addr, TRUE) < 0) + TEST_ERROR + + /* Un-cork the datatype: DT3 */ + if(H5Oenable_mdc_flushes(tid3) < 0) + TEST_ERROR + /* Verify cork status of the datatype: DT3 */ + if(H5C__verify_cork_tag_test(fid, oinfo3.addr, FALSE) < 0) + TEST_ERROR + + /* Cork the datatype: DT */ + if(H5Odisable_mdc_flushes(tid) < 0) + TEST_ERROR + + /* Verify cork status of the datatype: DT */ + if(H5C__verify_cork_tag_test(fid, oinfo.addr, TRUE) < 0) + TEST_ERROR + /* Verify cork status of the datatype: DT2 */ + if(H5C__verify_cork_tag_test(fid, oinfo2.addr, TRUE) < 0) + TEST_ERROR + + /* Verify cork status of the dataset: DSET */ + if(H5C__verify_cork_tag_test(fid, oinfo4.addr, TRUE) < 0) + TEST_ERROR + + /* Close the dataset */ + if(H5Dclose(did) < 0) + TEST_ERROR + + /* Verify cork status of the datatype: DT */ + if(H5C__verify_cork_tag_test(fid, oinfo.addr, TRUE) < 0) + TEST_ERROR + + /* Verify cork status of the dataset: DSET */ + if(H5C__verify_cork_tag_test(fid, oinfo4.addr, FALSE) < 0) + TEST_ERROR + + /* Closing */ + if(H5Tclose(tid) < 0) + TEST_ERROR + if(H5Tclose(tid2) < 0) + TEST_ERROR + if(H5Tclose(tid3) < 0) + TEST_ERROR + if(H5Gclose(gid) < 0) + TEST_ERROR + if(H5Gclose(gid2) < 0) + TEST_ERROR + if(H5Sclose(sid) < 0) + TEST_ERROR + if(H5Fclose(fid) < 0) + TEST_ERROR + if(H5Pclose(fapl) < 0) + TEST_ERROR + + PASSED(); + return 0; + +error: + H5E_BEGIN_TRY { + H5Tclose(tid); + H5Tclose(tid2); + H5Tclose(tid3); + H5Gclose(gid); + H5Gclose(gid2); + H5Dclose(did); + H5Pclose(fapl); + H5Fclose(fid); + } H5E_END_TRY; + return 1; +} /* verify_named_cork */ + + +/*------------------------------------------------------------------------- + * Function: verify_multiple_cork + * + * Purpose: This function verifies corking operations when there are + * multiple opens of files, objects, attributes. + * (based on test_attr_bug5() in tattr.c) + * Cache entries associated with the object tag are checked + * for the correct cork status. + * + * Return: 0 on Success, 1 on Failure + * + * Programmer: Vailin Choi; Feb 2014 + * + *------------------------------------------------------------------------- + */ +static unsigned +verify_multiple_cork(void) +{ + /* Variable Declarations */ + hid_t fid1 = -1, fid2 = -1; /* File ID */ + hid_t fapl = -1; /* File access property list */ + hid_t tid1 = -1, tid2 = -1; /* Datatype IDs */ + hid_t gid1 = -1, gid2 = -1; /* Group IDs */ + hid_t did1 = -1, did2 = -1; /* Dataset ID */ + hid_t aidg1 = -1, aidg2 = -1; /* Attribute ID */ + hid_t aidd1 = -1, aidd2 = -1; /* Attribute ID */ + hid_t aidt1 = -1, aidt2 = -1; /* Attribute ID */ + hid_t sid = -1; /* Dataspace ID */ + H5O_info_t oinfo1, oinfo2, oinfo3; /* Object metadata information */ + hsize_t dim[1] = {5}; /* Dimension sizes */ + unsigned flags; /* File access flags */ + hbool_t corked; /* Cork status */ + herr_t ret; /* Return value */ + + /* Testing Macro */ + TESTING("cork status for multiple opens"); + + /* Create fapl */ + if((fapl = H5Pcreate(H5P_FILE_ACCESS)) < 0) + TEST_ERROR + /* Set to use latest format */ + if(H5Pset_libver_bounds(fapl, H5F_LIBVER_LATEST, H5F_LIBVER_LATEST) < 0) + TEST_ERROR + + /* Create the file */ + flags = H5F_ACC_TRUNC; + if((fid1 = H5Fcreate(FILENAME, flags, H5P_DEFAULT, fapl)) < 0) + TEST_ERROR + + /* Open root group */ + if((gid1 = H5Gopen2(fid1, "/", H5P_DEFAULT)) < 0) + TEST_ERROR + + /* Create and commit datatype */ + if((tid1 = H5Tcopy(H5T_STD_I32LE)) < 0) + TEST_ERROR + if(H5Tcommit2(fid1, DT, tid1, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT) < 0) + TEST_ERROR + + /* Create dataset */ + if((sid = H5Screate_simple(1, dim, NULL)) < 0) + TEST_ERROR + if((did1 = H5Dcreate2(fid1, DSET, tid1, sid, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0) + TEST_ERROR + + /* Create attribute on root group */ + if((aidg1 = H5Acreate2(gid1, GRP_ATTR, tid1, sid, H5P_DEFAULT, H5P_DEFAULT)) < 0) + TEST_ERROR + + /* Create attribute on dataset */ + if((aidd1 = H5Acreate2(did1, DSET_ATTR, tid1, sid, H5P_DEFAULT, H5P_DEFAULT)) < 0) + TEST_ERROR + + /* Create attribute on datatype */ + if((aidt1 = H5Acreate2(tid1, DT_ATTR, tid1, sid, H5P_DEFAULT, H5P_DEFAULT)) < 0) + TEST_ERROR + + /* Closing */ + if(H5Aclose(aidt1) < 0) + TEST_ERROR + if(H5Aclose(aidd1) < 0) + TEST_ERROR + if(H5Aclose(aidg1) < 0) + TEST_ERROR + if(H5Dclose(did1) < 0) + TEST_ERROR + if(H5Tclose(tid1) < 0) + TEST_ERROR + if(H5Gclose(gid1) < 0) + TEST_ERROR + if(H5Fclose(fid1) < 0) + TEST_ERROR + if(H5Sclose(sid) < 0) + TEST_ERROR + + /* Open the file twice: fid1, fid2 */ + flags = H5F_ACC_RDWR; + if((fid1 = H5Fopen(FILENAME, flags, fapl)) < 0) + TEST_ERROR + if((fid2 = H5Fopen(FILENAME, flags, fapl)) < 0) + TEST_ERROR + + /* Open the root group twice: gid1, gid2 */ + if((gid1 = H5Gopen2(fid1, "/", H5P_DEFAULT)) < 0) + TEST_ERROR + if((gid2 = H5Gopen2(fid2, "/", H5P_DEFAULT)) < 0) + TEST_ERROR + + /* Open the root group attribute twice: aidg1, aidg2 */ + if((aidg1 = H5Aopen(gid1, GRP_ATTR, H5P_DEFAULT)) < 0) + TEST_ERROR + if((aidg2 = H5Aopen(gid2, GRP_ATTR, H5P_DEFAULT)) < 0) + TEST_ERROR + + /* Cork the group: gid2 */ + if(H5Odisable_mdc_flushes(gid2) < 0) + TEST_ERROR + + /* Verify cork status of the group: gid2 */ + if(H5Oget_info(gid2, &oinfo1) < 0) + TEST_ERROR + if(H5C__verify_cork_tag_test(fid2, oinfo1.addr, TRUE) < 0) + TEST_ERROR + + /* Check cork status of the group: gid1 */ + if(H5Oare_mdc_flushes_disabled(gid1, &corked) < 0) + TEST_ERROR + if(!corked) + TEST_ERROR + + /* Open the dataset twice: did1, did2 */ + if((did1 = H5Dopen2(fid1, DSET, H5P_DEFAULT)) < 0) + TEST_ERROR + if((did2 = H5Dopen2(fid2, DSET, H5P_DEFAULT)) < 0) + TEST_ERROR + + /* Open the dataset attribute twice: aidd1, aidd2 */ + if((aidd1 = H5Aopen(did1, DSET_ATTR, H5P_DEFAULT)) < 0) + TEST_ERROR + if((aidd2 = H5Aopen(did2, DSET_ATTR, H5P_DEFAULT)) < 0) + TEST_ERROR + + /* Cork the dataset: did1 */ + if(H5Odisable_mdc_flushes(did1) < 0) + TEST_ERROR + + /* Verify cork status of the dataset: did1 */ + if(H5Oget_info(did1, &oinfo2) < 0) + TEST_ERROR + if(H5C__verify_cork_tag_test(fid1, oinfo2.addr, TRUE) < 0) + TEST_ERROR + + /* Check cork status of the dataset: did2 */ + if(H5Oare_mdc_flushes_disabled(did2, &corked) < 0) + TEST_ERROR + if(!corked) + TEST_ERROR + + /* Open the datatype twice: tid1, tid2 */ + if((tid1 = H5Topen2(fid1, DT, H5P_DEFAULT)) < 0) + TEST_ERROR + if((tid2 = H5Topen2(fid2, DT, H5P_DEFAULT)) < 0) + TEST_ERROR + + /* Open the datatype attribute twice: aidt1, aidt2 */ + if((aidt1 = H5Aopen(tid1, DT_ATTR, H5P_DEFAULT)) < 0) + TEST_ERROR + if((aidt2 = H5Aopen(tid2, DT_ATTR, H5P_DEFAULT)) < 0) + TEST_ERROR + + /* Cork the datatype: tid2 */ + if(H5Odisable_mdc_flushes(tid2) < 0) + TEST_ERROR + + /* Verify cork status of the datatype: tid2 */ + if(H5Oget_info(tid2, &oinfo3) < 0) + TEST_ERROR + if(H5C__verify_cork_tag_test(fid2, oinfo3.addr, TRUE) < 0) + TEST_ERROR + + /* Check cork status of the datatype: tid1 */ + if(H5Oare_mdc_flushes_disabled(tid1, &corked) < 0) + TEST_ERROR + if(!corked) + TEST_ERROR + + /* Uncork the group: gid1 */ + if(H5Oenable_mdc_flushes(gid1) < 0) + TEST_ERROR + + /* Verify cork status of the group: gid1 */ + if(H5Oget_info(gid1, &oinfo1) < 0) + TEST_ERROR + if(H5C__verify_cork_tag_test(fid1, oinfo1.addr, FALSE) < 0) + TEST_ERROR + + /* Check cork status of the group: gid2 */ + if(H5Oare_mdc_flushes_disabled(gid2, &corked) < 0) + TEST_ERROR + if(corked) + TEST_ERROR + + /* Close the group: gid2 */ + if(H5Gclose(gid2) < 0) + TEST_ERROR + + /* Check cork status of the group: gid1 */ + if(H5Oare_mdc_flushes_disabled(gid1, &corked) < 0) + TEST_ERROR + if(corked) + TEST_ERROR + + /* Verify cork status of the group: gid1 */ + if(H5C__verify_cork_tag_test(fid1, oinfo1.addr, FALSE) < 0) + TEST_ERROR + + /* Close the group: gid1 */ + if(H5Gclose(gid1) < 0) + TEST_ERROR + + /* Uncork the dataset: gid2 */ + if(H5Oenable_mdc_flushes(did2) < 0) + TEST_ERROR + + /* Verify cork status of the dataset: did2 */ + if(H5Oget_info(did2, &oinfo2) < 0) + TEST_ERROR + if(H5C__verify_cork_tag_test(fid2, oinfo2.addr, FALSE) < 0) + TEST_ERROR + + /* Check cork status of the dataset: did1 */ + if(H5Oare_mdc_flushes_disabled(did1, &corked) < 0) + TEST_ERROR + if(corked) + TEST_ERROR + + /* Close the dataset: did2 */ + if(H5Dclose(did2) < 0) + TEST_ERROR + + /* Check cork status of the dataset: did1 */ + if(H5Oare_mdc_flushes_disabled(did1, &corked) < 0) + TEST_ERROR + if(corked) + TEST_ERROR + + /* Verify cork status of the dataset: did1 */ + if(H5C__verify_cork_tag_test(fid1, oinfo2.addr, FALSE) < 0) + TEST_ERROR + + /* Close the dataset: did1 */ + if(H5Dclose(did1) < 0) + TEST_ERROR + + /* Check cork status of the datatype: tid1 */ + if(H5Oare_mdc_flushes_disabled(tid1, &corked) < 0) + TEST_ERROR + if(!corked) + TEST_ERROR + + /* Close datatype: tid1 */ + if(H5Tclose(tid1) < 0) + TEST_ERROR + + /* Check cork status of the datatype: tid2 */ + if(H5Oare_mdc_flushes_disabled(tid2, &corked) < 0) + TEST_ERROR + if(!corked) + TEST_ERROR + + /* Close datatype: tid2 */ + if(H5Tclose(tid2) < 0) + TEST_ERROR + + /* Should fail to cork the attribute: aidg2; not an object */ + H5E_BEGIN_TRY { + ret = H5Odisable_mdc_flushes(aidg2); + } H5E_END_TRY; + if(ret >= 0) + TEST_ERROR + + /* Should fail to uncork the attribute: aidd1; not an object */ + H5E_BEGIN_TRY { + ret = H5Odisable_mdc_flushes(aidd1); + } H5E_END_TRY; + if(ret >= 0) + TEST_ERROR + + /* Should fail to check cork status of the attribute: aidt2; not an object */ + H5E_BEGIN_TRY { + ret = H5Oare_mdc_flushes_disabled(aidt2, &corked); + } H5E_END_TRY; + if(ret >= 0) + TEST_ERROR + + /* Close all attributes */ + if(H5Aclose(aidg1) < 0) + TEST_ERROR + if(H5Aclose(aidg2) < 0) + TEST_ERROR + if(H5Aclose(aidd1) < 0) + TEST_ERROR + if(H5Aclose(aidd2) < 0) + TEST_ERROR + if(H5Aclose(aidt1) < 0) + TEST_ERROR + if(H5Aclose(aidt2) < 0) + TEST_ERROR + + /* Should fail to cork the file: fid1; not an object */ + H5E_BEGIN_TRY { + ret = H5Oare_mdc_flushes_disabled(fid1, &corked); + ret = H5Odisable_mdc_flushes(fid1); + } H5E_END_TRY; + if(ret >= 0) + TEST_ERROR + + /* Should fail to uncork the file: fid2; not an object */ + H5E_BEGIN_TRY { + ret = H5Oenable_mdc_flushes(fid2); + } H5E_END_TRY; + if(ret >= 0) + TEST_ERROR + + /* Closing */ + if(H5Pclose(fapl) < 0) + TEST_ERROR + if(H5Fclose(fid1) < 0) + TEST_ERROR + if(H5Fclose(fid2) < 0) + TEST_ERROR + + PASSED(); + return 0; + +error: + H5E_BEGIN_TRY { + H5Tclose(tid1); + H5Tclose(tid2); + H5Gclose(gid1); + H5Gclose(gid2); + H5Dclose(did1); + H5Dclose(did2); + H5Aclose(aidg1); + H5Aclose(aidg2); + H5Aclose(aidd1); + H5Aclose(aidt1); + H5Aclose(aidt2); + H5Aclose(aidd2); + H5Pclose(fapl); + H5Fclose(fid1); + H5Fclose(fid1); + } H5E_END_TRY; + return 1; +} /* verify_multiple_cork */ + +/*------------------------------------------------------------------------- + * Function: test_objs_cork + * + * Purpose: This function verifies H5Odisable_mdc_flushes/H5Oenable_mdc_flushes/H5Oare_mdc_flushes_disabled public + * routines are working as specified. + * + * Return: 0 on Success, 1 on Failure + * + * Programmer: Vailin Choi; Feb 2014 + * + *------------------------------------------------------------------------- + */ +static unsigned +test_objs_cork(hbool_t new_format) +{ + hid_t fid; /* HDF5 File ID */ + hid_t fapl; /* File access property list */ + hid_t gid, did, tid; /* Object IDs */ + hid_t sid; /* Dataspace ID */ + hid_t aid; /* Attribute ID */ + hsize_t dims[RANK]; /* Dataset dimension sizes */ + hbool_t corked; /* Cork status of an object */ + herr_t ret; /* Return value */ + + /* Testing Macro */ + if(new_format) { + TESTING("H5Odisable_mdc_flushes/H5Oenable_mdc_flushes/H5Oare_mdc_flushes_disabled (new library format)"); + } else { + TESTING("H5Odisable_mdc_flushes/H5Oenable_mdc_flushes/H5Oare_mdc_flushes_disabled (old library format)"); + } /* end if */ + + /* Create fapl */ + if((fapl = H5Pcreate(H5P_FILE_ACCESS)) < 0) + TEST_ERROR + + /* Set to use latest format */ + if(new_format) { + if(H5Pset_libver_bounds(fapl, H5F_LIBVER_LATEST, H5F_LIBVER_LATEST) < 0) + TEST_ERROR + } /* end if */ + + /* Create an HDF5 file */ + if((fid = H5Fcreate(FILENAME, H5F_ACC_TRUNC, H5P_DEFAULT, fapl)) < 0) + TEST_ERROR + + /* Create group */ + if((gid = H5Gcreate2(fid, "group", H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0) + TEST_ERROR + + /* Check cork status of the group: not corked */ + if(H5Oare_mdc_flushes_disabled(gid, &corked) < 0) + TEST_ERROR + if(corked) + TEST_ERROR + + /* Cork the group: an object */ + if(H5Odisable_mdc_flushes(gid) < 0) + TEST_ERROR + + /* Check cork status of the group: corked */ + if(H5Oare_mdc_flushes_disabled(gid, &corked) < 0) + TEST_ERROR + if(!corked) + TEST_ERROR + + /* Close the group */ + if(H5Gclose(gid) < 0) + TEST_ERROR + + /* Create a transient copy of a native type */ + if((tid = H5Tcopy(H5T_NATIVE_INT)) < 0) + TEST_ERROR + + /* Should fail to cork the datatype: not an object */ + H5E_BEGIN_TRY { + ret = H5Odisable_mdc_flushes(tid); + } H5E_END_TRY; + if(ret >= 0) + TEST_ERROR + + /* Create a named datatype */ + if(H5Tcommit2(fid, "group/datatype", tid, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT) < 0) + TEST_ERROR + + /* Check cork status of the named datatype: not corked */ + if(H5Oare_mdc_flushes_disabled(tid, &corked) < 0) + TEST_ERROR + if(corked) + TEST_ERROR + + /* Cork the named datatype: an object */ + if(H5Odisable_mdc_flushes(tid) < 0) + TEST_ERROR + + /* Check cork status of the named datatype: corked */ + if(H5Oare_mdc_flushes_disabled(tid, &corked) < 0) + TEST_ERROR + if(!corked) + TEST_ERROR + + /* Close the named datatype */ + if(H5Tclose(tid) < 0) + TEST_ERROR + + /* Create dataspace */ + dims[0] = DIM0; + dims[1] = DIM1; + if((sid = H5Screate_simple(RANK, dims, NULL)) < 0) + TEST_ERROR + + /* Should fail to uncork the dataspace: not an object */ + H5E_BEGIN_TRY { + ret = H5Oenable_mdc_flushes(sid); + } H5E_END_TRY; + if(ret >= 0) + TEST_ERROR + + /* Create dataset. */ + if((did = H5Dcreate2(fid, "dataset", H5T_NATIVE_INT, sid, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0) + TEST_ERROR + + /* Create attribute on the dataset */ + if((aid = H5Acreate2(did, "attr", H5T_NATIVE_INT, sid, H5P_DEFAULT, H5P_DEFAULT)) < 0) + TEST_ERROR + + /* Should fail to check cork status of the attribute: not an object */ + H5E_BEGIN_TRY { + ret = H5Oare_mdc_flushes_disabled(aid, &corked); + } H5E_END_TRY; + if(ret >= 0) + TEST_ERROR + + /* Check cork status of the dataset: not corked */ + if(H5Oare_mdc_flushes_disabled(did, &corked) < 0) + TEST_ERROR + if(corked) + TEST_ERROR + + /* Cork the dataset: an object */ + if(H5Odisable_mdc_flushes(did) < 0) + TEST_ERROR + + /* Check cork status of the dataset: corked */ + if(H5Oare_mdc_flushes_disabled(did, &corked) < 0) + TEST_ERROR + if(!corked) + TEST_ERROR + + /* Close the dataset and dataspace */ + if(H5Dclose(did) < 0) + TEST_ERROR + + /* Open the group */ + if((gid = H5Oopen(fid, "group", H5P_DEFAULT)) < 0) + TEST_ERROR + + /* Check cork status of the group */ + if(H5Oare_mdc_flushes_disabled(gid, &corked) < 0) + TEST_ERROR + if(corked) + TEST_ERROR + + /* Cork the group */ + if(H5Odisable_mdc_flushes(gid) < 0) + TEST_ERROR + + /* Should fail to cork the group again */ + H5E_BEGIN_TRY { + ret = H5Odisable_mdc_flushes(gid); + } H5E_END_TRY; + if(ret >= 0) + TEST_ERROR + + /* Check cork status of the group */ + if(H5Oare_mdc_flushes_disabled(gid, &corked) < 0) + TEST_ERROR + if(!corked) + TEST_ERROR + + /* Open the named datatype */ + if((tid = H5Oopen(fid, "group/datatype", H5P_DEFAULT)) < 0) + TEST_ERROR + + /* Check cork status of the named datatype */ + if(H5Oare_mdc_flushes_disabled(tid, &corked) < 0) + TEST_ERROR + if(corked) + TEST_ERROR + + /* Should fail to un-cork the named datatype that is not corked yet */ + H5E_BEGIN_TRY { + ret = H5Oenable_mdc_flushes(tid); + } H5E_END_TRY; + if(ret >= 0) + TEST_ERROR + + /* Cork the named datatype */ + if(H5Odisable_mdc_flushes(tid) < 0) + TEST_ERROR + + /* Check cork status of the named datatype */ + if(H5Oare_mdc_flushes_disabled(tid, &corked) < 0) + TEST_ERROR + if(!corked) + TEST_ERROR + + /* Open the dataset */ + if((did = H5Oopen(fid, "/dataset", H5P_DEFAULT)) < 0) + TEST_ERROR + + /* Check cork status of the dataset */ + if(H5Oare_mdc_flushes_disabled(did, &corked) < 0) + TEST_ERROR + if(corked) + TEST_ERROR + + /* Cork the dataset */ + if(H5Odisable_mdc_flushes(did) < 0) + TEST_ERROR + + /* Check cork status of dataset */ + if(H5Oare_mdc_flushes_disabled(did, &corked) < 0) + TEST_ERROR + if(!corked) + TEST_ERROR + + /* Un-cork the dataset */ + if(H5Oenable_mdc_flushes(did) < 0) + TEST_ERROR + + /* Check cork status of the dataset */ + if(H5Oare_mdc_flushes_disabled(did, &corked) < 0) + TEST_ERROR + if(corked) + TEST_ERROR + + /* Closing */ + if(H5Tclose(tid) < 0) + TEST_ERROR + if(H5Gclose(gid) < 0) + TEST_ERROR + if(H5Dclose(did) < 0) + TEST_ERROR + if(H5Sclose(sid) < 0) + TEST_ERROR + if(H5Aclose(aid) < 0) + TEST_ERROR + if(H5Pclose(fapl) < 0) + TEST_ERROR + if(H5Fclose(fid) < 0) + TEST_ERROR + + PASSED(); + return 0; + +error: + H5E_BEGIN_TRY { + H5Sclose(sid); + H5Aclose(aid); + H5Dclose(did); + H5Gclose(gid); + H5Tclose(tid); + H5Pclose(fapl); + H5Fclose(fid); + } H5E_END_TRY; + return 1; +} /* test_objs_cork() */ + + +/*------------------------------------------------------------------------- + * Function: test_dset_cork + * + * Purpose: This function verifies H5Odisable_mdc_flushes/H5Oenable_mdc_flushes/H5Oare_mdc_flushes_disabled are + * working as specified when manipulating datasets. + * + * Return: 0 on Success, 1 on Failure + * + * Programmer: Vailin Choi; Feb 2014 + * + *------------------------------------------------------------------------- + */ +static unsigned +test_dset_cork(hbool_t new_format) +{ + hid_t fid; /* File ID */ + hid_t fapl; /* File access property list */ + hid_t gid; /* Groupd ID */ + hid_t did1, did2; /* Dataset IDs */ + hid_t tid1, tid2; /* Datatype IDs */ + hid_t sid; /* Dataspace ID */ + hid_t dcpl; /* Dataset creation property list */ + hsize_t dims[RANK]; /* Dataset dimensions */ + hsize_t maxdims[2] = {H5S_UNLIMITED, H5S_UNLIMITED}; /* Maximum dataset dimensions */ + hsize_t cdims[RANK] = {2,2}; /* Chunk dimensions */ + int fillval = 0; /* Fill value */ + int i, j, k = 0; /* Local index variables */ + int data[DIMS0][DIMS1]; /* Data buffer */ + int rbuf[DIMS0][DIMS1]; /* Data buffer */ + hbool_t corked; /* Cork status of an object */ + + /* Testing Macro */ + if(new_format) { + TESTING("H5Odisable_mdc_flushes/H5Oenable_mdc_flushes/H5Oare_mdc_flushes_disabled on datasets (new library format)"); + } else { + TESTING("H5Odisable_mdc_flushes/H5Oenable_mdc_flushes/H5Oare_mdc_flushes_disabled on datasets (old library format)"); + } /* end if */ + + /* Create fapl */ + if((fapl = H5Pcreate(H5P_FILE_ACCESS)) < 0) + TEST_ERROR + + /* Set to use latest format */ + if(new_format) { + if(H5Pset_libver_bounds(fapl, H5F_LIBVER_LATEST, H5F_LIBVER_LATEST) < 0) + TEST_ERROR + } /* end if */ + + /* Create a new HDF5 file */ + if((fid = H5Fcreate(FILENAME, H5F_ACC_TRUNC, H5P_DEFAULT, fapl)) < 0) + TEST_ERROR + + /* Create a group */ + if((gid = H5Gcreate2(fid, "group", H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0) + TEST_ERROR + + /* Commit the datatype with the group */ + if((tid1 = H5Tcopy(H5T_NATIVE_INT)) < 0) + TEST_ERROR + if(H5Tcommit2(gid, "datatype", tid1, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT) < 0) + TEST_ERROR + + /* Cork the named datatype */ + if(H5Odisable_mdc_flushes(tid1) < 0) + TEST_ERROR + + /* Set up dataset creation property list */ + if((dcpl = H5Pcreate(H5P_DATASET_CREATE)) < 0) + TEST_ERROR + + /* Enable chunking */ + if(H5Pset_chunk(dcpl, RANK, cdims) < 0) + TEST_ERROR + + /* Set up a fill value */ + if(H5Pset_fill_value(dcpl, H5T_NATIVE_INT, &fillval) < 0) + TEST_ERROR + + /* Create dataspace */ + dims[0] = DIMS0; + dims[1] = DIMS1; + if((sid = H5Screate_simple(RANK, dims, maxdims)) < 0) + TEST_ERROR + + /* Create the dataset inside the group with the named datatype */ + if((did1 = H5Dcreate2(gid, "dataset", tid1, sid, H5P_DEFAULT, dcpl, H5P_DEFAULT)) < 0) + TEST_ERROR + + /* Check cork status of the named datatype */ + if(H5Oare_mdc_flushes_disabled(tid1, &corked) < 0) + TEST_ERROR + if(!corked) + TEST_ERROR + + /* Cork the dataset */ + if(H5Odisable_mdc_flushes(did1) < 0) + TEST_ERROR + + /* Check cork status of the dataset */ + if(H5Oare_mdc_flushes_disabled(did1, &corked) < 0) + TEST_ERROR + if(!corked) + TEST_ERROR + + /* Check cork status of the group */ + if(H5Oare_mdc_flushes_disabled(gid, &corked) < 0) + TEST_ERROR + if(corked) + TEST_ERROR + + /* Initialize the buffer */ + for(i = 0; i < DIMS0;i++) + for(j = 0;j < DIMS1;j++) + data[i][j] = k++; + + /* Write to the dataset */ + if(H5Dwrite(did1, tid1, sid, sid, H5P_DEFAULT, data) < 0) + TEST_ERROR + + /* Check cork status of the dataset */ + if(H5Oare_mdc_flushes_disabled(did1, &corked) < 0) + TEST_ERROR + if(!corked) + TEST_ERROR + + /* Check cork status of the named datatype */ + if(H5Oare_mdc_flushes_disabled(tid1, &corked) < 0) + TEST_ERROR + if(!corked) + TEST_ERROR + + /* Close the dataset */ + if(H5Dclose(did1) < 0) + TEST_ERROR + + /* Open the dataset again */ + if((did1 = H5Dopen2(gid, "dataset", H5P_DEFAULT)) < 0) + TEST_ERROR + + /* Check cork status of dataset */ + if(H5Oare_mdc_flushes_disabled(did1, &corked) < 0) + TEST_ERROR + if(corked) + TEST_ERROR + + /* Read from the dataset */ + if(H5Dread(did1, tid1, H5S_ALL, H5S_ALL, H5P_DEFAULT, rbuf) < 0) + TEST_ERROR + + /* Cork the dataset */ + if(H5Odisable_mdc_flushes(did1) < 0) + TEST_ERROR + + /* Delete the dataset */ + if(H5Ldelete(gid, "dataset", H5P_DEFAULT) < 0) + TEST_ERROR + + /* Check cork status of the dataset */ + if(H5Oare_mdc_flushes_disabled(did1, &corked) < 0) + TEST_ERROR + if(!corked) + TEST_ERROR + + /* Close the dataset */ + if(H5Oclose(did1) < 0) + TEST_ERROR + + /* Create the dataset again */ + if((did1 = H5Dcreate2(gid, "dataset", tid1, sid, H5P_DEFAULT, dcpl, H5P_DEFAULT)) < 0) + TEST_ERROR + + /* Cork the dataset */ + if(H5Odisable_mdc_flushes(did1) < 0) + TEST_ERROR + + /* Write to the dataset */ + if(H5Dwrite(did1, tid1, sid, sid, H5P_DEFAULT, data) < 0) + TEST_ERROR + + /* Check cork status of the dataset */ + if(H5Oare_mdc_flushes_disabled(did1, &corked) < 0) + TEST_ERROR + if(!corked) + TEST_ERROR + + /* Close the dataset */ + if(H5Dclose(did1) < 0) + TEST_ERROR + + /* First open of the dataset */ + if((did1 = H5Dopen2(gid, "dataset", H5P_DEFAULT)) < 0) + TEST_ERROR + + /* Second open of the dataset */ + if((did2 = H5Dopen2(gid, "dataset", H5P_DEFAULT)) < 0) + TEST_ERROR + + /* Cork the first opened dataset */ + if(H5Odisable_mdc_flushes(did1) < 0) + TEST_ERROR + + /* Check cork status of the first opened dataset */ + if(H5Oare_mdc_flushes_disabled(did1, &corked) < 0) + TEST_ERROR + if(!corked) + TEST_ERROR + + /* Check cork status of the second opened dataset */ + if(H5Oare_mdc_flushes_disabled(did2, &corked) < 0) + TEST_ERROR + if(!corked) + TEST_ERROR + + /* Close the second opened dataset */ + if(H5Dclose(did2) < 0) + TEST_ERROR + + /* Check cork status of the first opened dataset */ + if(H5Oare_mdc_flushes_disabled(did1, &corked) < 0) + TEST_ERROR + if(!corked) + TEST_ERROR + + /* Close the first opened dastaset */ + if(H5Dclose(did1) < 0) + TEST_ERROR + + /* Check cork status of the named datatype */ + if(H5Oare_mdc_flushes_disabled(tid1, &corked) < 0) + TEST_ERROR + if(!corked) + TEST_ERROR + + /* Second open of the named datatype */ + if((tid2 = H5Topen2(gid, "datatype", H5P_DEFAULT)) < 0) + TEST_ERROR + + /* Check cork status of the second opened named datatype */ + if(H5Oare_mdc_flushes_disabled(tid2, &corked) < 0) + TEST_ERROR + if(!corked) + TEST_ERROR + + /* Uncork the second opened named datatype */ + if(H5Oenable_mdc_flushes(tid2) < 0) + TEST_ERROR + + /* Check cork status of the second opened named datatype */ + if(H5Oare_mdc_flushes_disabled(tid2, &corked) < 0) + TEST_ERROR + if(corked) + TEST_ERROR + + /* Check cork status of the first opened named datatype */ + if(H5Oare_mdc_flushes_disabled(tid1, &corked) < 0) + TEST_ERROR + if(corked) + TEST_ERROR + + /* Close the first opened datatype */ + if(H5Tclose(tid1) < 0) + TEST_ERROR + + /* Close the second opened datatype */ + if(H5Tclose(tid2) < 0) + TEST_ERROR + + /* Check cork status of the group */ + if(H5Oare_mdc_flushes_disabled(gid, &corked) < 0) + TEST_ERROR + if(corked) + TEST_ERROR + + /* Closing */ + if(H5Gclose(gid) < 0) + TEST_ERROR + if(H5Sclose(sid) < 0) + TEST_ERROR + if(H5Pclose(fapl) < 0) + TEST_ERROR + if(H5Fclose(fid) < 0) + TEST_ERROR + if(H5Pclose(dcpl) < 0) + TEST_ERROR + + PASSED(); + return 0; + +error: + H5E_BEGIN_TRY { + H5Sclose(sid); + H5Dclose(did1); + H5Dclose(did2); + H5Tclose(tid1); + H5Tclose(tid2); + H5Pclose(dcpl); + H5Gclose(gid); + H5Pclose(fapl); + H5Fclose(fid); + } H5E_END_TRY; + return 1; + +} /* test_dset_cork() */ + + + +/*------------------------------------------------------------------------- + * Function: main + * + * Purpose: Run tests to verify the library's corking operations. + * + * Return: Success: + * + * Failure: + * + * Programmer: Vailin Choi; Feb 2014 + * + *------------------------------------------------------------------------- + */ +int +main(void) +{ + unsigned nerrs = 0; /* Error Encountered */ + + /* Test for dataset created with old library format */ + nerrs += verify_old_dset_cork(); + + /* Tests with new/old library format */ + /* This is the test moved from th5o.c: test_h5o_cork() */ + nerrs += test_objs_cork(TRUE); + nerrs += test_objs_cork(FALSE); + /* This is the test moved from th5o.c: test_h5o_cork_dataset() */ + nerrs += test_dset_cork(TRUE); + nerrs += test_dset_cork(FALSE); + + /* Tests with/without SWMR access */ + nerrs += verify_obj_dset_cork(); + nerrs += verify_dset_cork(TRUE); + nerrs += verify_dset_cork(FALSE); + nerrs += verify_group_cork(); + nerrs += verify_named_cork(); + nerrs += verify_multiple_cork(); + + /* Delete test files */ + HDremove(FILENAME); + + /* Return Errors */ + return(nerrs > 0); +} /* main */ + |