2014-04-07 06:36:15 +08:00
|
|
|
|
/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
|
|
|
|
|
* Copyright by The HDF Group. *
|
|
|
|
|
* Copyright by the Board of Trustees of the University of Illinois. *
|
|
|
|
|
* All rights reserved. *
|
|
|
|
|
* *
|
|
|
|
|
* This file is part of HDF5. The full HDF5 copyright notice, including *
|
|
|
|
|
* terms governing use, modification, and redistribution, is contained in *
|
2017-04-18 03:32:16 +08:00
|
|
|
|
* the COPYING file, which can be found at the root of the source code *
|
|
|
|
|
* distribution tree, or in https://support.hdfgroup.org/ftp/HDF5/releases. *
|
|
|
|
|
* If you do not have access to either file, you may request a copy from *
|
|
|
|
|
* help@hdfgroup.org. *
|
2014-04-07 06:36:15 +08:00
|
|
|
|
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
|
|
|
|
|
|
|
|
|
|
/*****************************************************************************
|
|
|
|
|
FILE
|
|
|
|
|
tobject.cpp - HDF5 C++ testing object related functionality
|
|
|
|
|
|
|
|
|
|
***************************************************************************/
|
|
|
|
|
#ifdef OLD_HEADER_FILENAME
|
|
|
|
|
#include <iostream.h>
|
|
|
|
|
#else
|
|
|
|
|
#include <iostream>
|
|
|
|
|
#endif
|
|
|
|
|
|
2016-10-20 04:50:17 +08:00
|
|
|
|
#include <string>
|
2014-04-07 06:36:15 +08:00
|
|
|
|
#include "H5Cpp.h" // C++ API header file
|
2016-10-20 04:50:17 +08:00
|
|
|
|
using namespace H5;
|
2014-04-07 06:36:15 +08:00
|
|
|
|
|
2016-10-20 04:50:17 +08:00
|
|
|
|
#include "h5test.h"
|
2014-04-07 06:36:15 +08:00
|
|
|
|
#include "h5cpputil.h" // C++ utilility header file
|
|
|
|
|
|
2017-03-03 22:45:57 +08:00
|
|
|
|
const H5std_string FILE_OBJECTS("tobjects.h5");
|
Purpose: Add new C++ wrappers
Description:
Added wrappers for H5Iis_valid, H5Ps/get_nlinks, H5Tget_create_plist,
H5Oopen, H5Oclose and H5Pset_virtual
// Checks if the given ID is valid.
static bool isValid(hid_t an_id);
// Sets the number of soft or user-defined links that can be
// traversed before a failure occurs.
void setNumLinks(size_t nlinks) const;
// Gets the number of soft or user-defined link traversals allowed
size_t getNumLinks() const;
// Returns a copy of the creation property list of a datatype.
PropList getCreatePlist() const;
// Opens an object within a group or a file, i.e., root group.
hid_t getObjId(const char* name,...);
hid_t getObjId(const H5std_string& name,...);
// Closes an object opened by getObjId().
void closeObjId(hid_t obj_id) const;
// Maps elements of a virtual dataset to elements of the source dataset.
void setVirtual(const DataSpace& vspace, const char *src_fname,...);
void setVirtual(const DataSpace& vspace, const H5std_string src_fname,...);
Platforms tested:
Linux/32 2.6 (jam)
Linux/64 (platypus)
Darwin (osx1010test)
2017-03-14 11:53:43 +08:00
|
|
|
|
const H5std_string FILE_OBJHDR("tobject_header.h5");
|
2017-03-03 22:45:57 +08:00
|
|
|
|
const H5std_string GROUP1("Top Group");
|
|
|
|
|
const H5std_string GROUP1_PATH("/Top Group");
|
|
|
|
|
const H5std_string GROUP1_1("Sub-Group 1.1");
|
|
|
|
|
const H5std_string GROUP1_1_PATH("/Top Group/Sub-Group 1.1");
|
|
|
|
|
const H5std_string GROUP1_2("Sub-Group 1.2");
|
|
|
|
|
const H5std_string GROUP1_2_PATH("/Top Group/Sub-Group 1.2");
|
|
|
|
|
const H5std_string DSET_DEFAULT_NAME("default");
|
|
|
|
|
const H5std_string DSET_IN_FILE("Dataset in File");
|
|
|
|
|
const H5std_string DSET_IN_FILE_PATH("/Dataset in File");
|
|
|
|
|
const H5std_string DSET_IN_GRP1("Dataset_in_Group_1");
|
|
|
|
|
const H5std_string DSET_IN_GRP1_PATH("/Top Group/Dataset_in_Group_1");
|
|
|
|
|
const H5std_string DSET_IN_GRP1_2("Dataset_in_Group_1.2");
|
|
|
|
|
const H5std_string DSET_IN_GRP1_2_PATH("/Top Group/Sub-Group 1.2/Dataset_in_Group_1.2");
|
2014-04-07 06:36:15 +08:00
|
|
|
|
|
|
|
|
|
/*-------------------------------------------------------------------------
|
2017-03-03 22:45:57 +08:00
|
|
|
|
* Function: test_get_objname
|
2014-04-07 06:36:15 +08:00
|
|
|
|
*
|
2017-03-03 22:45:57 +08:00
|
|
|
|
* Purpose Tests getting object name of groups and datasets.
|
2014-04-07 06:36:15 +08:00
|
|
|
|
*
|
2016-12-28 22:44:01 +08:00
|
|
|
|
* Description:
|
2017-03-03 22:45:57 +08:00
|
|
|
|
* File structure:
|
|
|
|
|
* GROUP1
|
|
|
|
|
* GROUP1_1
|
|
|
|
|
* GROUP1_2
|
|
|
|
|
* DSET_IN_GRP1_2
|
|
|
|
|
* DSET_IN_GRP1
|
|
|
|
|
* DSET_IN_FILE
|
2016-12-28 22:44:01 +08:00
|
|
|
|
*
|
|
|
|
|
*
|
2017-03-03 22:45:57 +08:00
|
|
|
|
* Return Success: 0
|
|
|
|
|
* Failure: -1
|
2014-04-07 06:36:15 +08:00
|
|
|
|
*
|
2017-03-03 22:45:57 +08:00
|
|
|
|
* Programmer Binh-Minh Ribler
|
|
|
|
|
* Friday, March 4, 2014
|
2014-04-07 06:36:15 +08:00
|
|
|
|
*
|
|
|
|
|
* Modifications:
|
|
|
|
|
*
|
|
|
|
|
*-------------------------------------------------------------------------
|
|
|
|
|
*/
|
|
|
|
|
static void test_get_objname()
|
|
|
|
|
{
|
|
|
|
|
SUBTEST("H5Object::getObjName on Groups and Datasets");
|
|
|
|
|
|
|
|
|
|
try {
|
2017-03-03 22:45:57 +08:00
|
|
|
|
// Create file
|
|
|
|
|
H5File file(FILE_OBJECTS, H5F_ACC_TRUNC);
|
2014-04-07 06:36:15 +08:00
|
|
|
|
|
2017-03-03 22:45:57 +08:00
|
|
|
|
// Create a top group and 2 subgroups
|
|
|
|
|
Group grp1 = file.createGroup(GROUP1, 0);
|
|
|
|
|
Group grp1_1 = grp1.createGroup(GROUP1_1, 0);
|
|
|
|
|
Group grp1_2 = grp1.createGroup(GROUP1_2, 0);
|
2014-04-07 06:36:15 +08:00
|
|
|
|
|
2017-03-03 22:45:57 +08:00
|
|
|
|
// Get part of the group's name, random length using
|
|
|
|
|
// ssize_t getObjName(char* comment, size_t buf_size)
|
2014-04-07 06:36:15 +08:00
|
|
|
|
|
2017-03-03 22:45:57 +08:00
|
|
|
|
// Get the length of the group's name first
|
|
|
|
|
ssize_t name_len = grp1.getObjName(NULL);
|
2014-04-07 06:36:15 +08:00
|
|
|
|
|
2017-03-03 22:45:57 +08:00
|
|
|
|
// Random length is 4
|
|
|
|
|
if (name_len > 4)
|
|
|
|
|
{
|
|
|
|
|
char* grp1_name = new char[5];
|
|
|
|
|
name_len = grp1.getObjName(grp1_name, 5);
|
|
|
|
|
verify_val((const char*)grp1_name, "/Top", "Group::getObjName", __LINE__, __FILE__);
|
|
|
|
|
delete []grp1_name;
|
|
|
|
|
}
|
2014-04-07 06:36:15 +08:00
|
|
|
|
|
2017-03-03 22:45:57 +08:00
|
|
|
|
// Create a data space
|
|
|
|
|
hsize_t dims[2];
|
|
|
|
|
dims[0] = 2;
|
|
|
|
|
dims[1] = 5;
|
|
|
|
|
DataSpace space (2, dims, NULL);
|
2014-04-07 06:36:15 +08:00
|
|
|
|
|
2017-03-03 22:45:57 +08:00
|
|
|
|
// Create a dataset in the file
|
|
|
|
|
DataSet dsinfile = file.createDataSet(DSET_IN_FILE,
|
|
|
|
|
PredType::NATIVE_DOUBLE, space);
|
2014-04-07 06:36:15 +08:00
|
|
|
|
|
2017-03-03 22:45:57 +08:00
|
|
|
|
// Create a dataset in the group
|
|
|
|
|
DataSet dsingrp = grp1.createDataSet(DSET_IN_GRP1,
|
|
|
|
|
PredType::NATIVE_INT, space);
|
2014-04-07 06:36:15 +08:00
|
|
|
|
|
2017-03-03 22:45:57 +08:00
|
|
|
|
// Get and verify the name of each dataset, using
|
|
|
|
|
// H5std_string getObjName() and
|
|
|
|
|
// ssize_t getObjName(H5std_string& obj_name, size_t len = 0)
|
|
|
|
|
H5std_string ds_name = dsinfile.getObjName();
|
|
|
|
|
verify_val(ds_name, DSET_IN_FILE_PATH, "DataSet::getObjName", __LINE__, __FILE__);
|
2014-04-07 06:36:15 +08:00
|
|
|
|
|
2017-03-03 22:45:57 +08:00
|
|
|
|
name_len = dsingrp.getObjName(ds_name); // default len
|
|
|
|
|
verify_val(ds_name, DSET_IN_GRP1_PATH, "DataSet::getObjName", __LINE__, __FILE__);
|
2014-04-07 06:36:15 +08:00
|
|
|
|
|
2017-03-03 22:45:57 +08:00
|
|
|
|
// Close dataset
|
|
|
|
|
dsingrp.close();
|
2014-04-07 06:36:15 +08:00
|
|
|
|
|
2017-03-03 22:45:57 +08:00
|
|
|
|
// Create a dataset in sub-group 1.2
|
|
|
|
|
dsingrp = grp1_2.createDataSet(DSET_IN_GRP1_2, PredType::NATIVE_INT, space);
|
2014-04-07 06:36:15 +08:00
|
|
|
|
|
2017-03-03 22:45:57 +08:00
|
|
|
|
// Get and verify the name of the dataset that belongs to subgroup
|
|
|
|
|
// 1.2, using H5std_string getObjName()
|
|
|
|
|
ds_name = dsingrp.getObjName();
|
|
|
|
|
verify_val(ds_name, DSET_IN_GRP1_2_PATH, "DataSet::getObjName", __LINE__, __FILE__);
|
2014-04-07 06:36:15 +08:00
|
|
|
|
|
2017-03-03 22:45:57 +08:00
|
|
|
|
// Close dataset
|
|
|
|
|
dsingrp.close();
|
2014-04-07 06:36:15 +08:00
|
|
|
|
|
2017-03-03 22:45:57 +08:00
|
|
|
|
// Reopen that same dataset then check the name again with another
|
|
|
|
|
// overload: ssize_t getObjName(H5std_string& obj_name, size_t len = 0)
|
|
|
|
|
dsingrp = grp1_2.openDataSet(DSET_IN_GRP1_2);
|
|
|
|
|
name_len = dsingrp.getObjName(ds_name);
|
|
|
|
|
verify_val(ds_name, DSET_IN_GRP1_2_PATH, "DataSet::getObjName", __LINE__, __FILE__);
|
2014-04-07 06:36:15 +08:00
|
|
|
|
|
2017-03-03 22:45:57 +08:00
|
|
|
|
// Everything will be closed as they go out of scope
|
2014-04-07 06:36:15 +08:00
|
|
|
|
|
2017-03-03 22:45:57 +08:00
|
|
|
|
PASSED();
|
|
|
|
|
} // try block
|
2014-04-07 06:36:15 +08:00
|
|
|
|
|
|
|
|
|
// catch all other exceptions
|
2016-04-22 19:22:34 +08:00
|
|
|
|
catch (Exception& E)
|
2014-04-07 06:36:15 +08:00
|
|
|
|
{
|
2017-03-03 22:45:57 +08:00
|
|
|
|
issue_fail_msg("test_get_objname", __LINE__, __FILE__);
|
2014-04-07 06:36:15 +08:00
|
|
|
|
}
|
|
|
|
|
} // test_get_objname
|
2017-01-03 21:53:54 +08:00
|
|
|
|
|
2016-12-28 22:44:01 +08:00
|
|
|
|
/*-------------------------------------------------------------------------
|
2017-03-03 22:45:57 +08:00
|
|
|
|
* Function: test_existance
|
2016-12-28 22:44:01 +08:00
|
|
|
|
*
|
2017-03-03 22:45:57 +08:00
|
|
|
|
* Purpose Tests getting object name of groups and datasets.
|
2016-12-28 22:44:01 +08:00
|
|
|
|
*
|
|
|
|
|
* Description:
|
2017-03-03 22:45:57 +08:00
|
|
|
|
* File structure:
|
|
|
|
|
* GROUP1
|
|
|
|
|
* GROUP1_1
|
|
|
|
|
* GROUP1_2
|
|
|
|
|
* DSET_IN_GRP1_2
|
|
|
|
|
* DSET_IN_GRP1
|
|
|
|
|
* DSET_IN_FILE
|
2016-12-28 22:44:01 +08:00
|
|
|
|
*
|
|
|
|
|
*
|
2017-03-03 22:45:57 +08:00
|
|
|
|
* Return Success: 0
|
|
|
|
|
* Failure: -1
|
2016-12-28 22:44:01 +08:00
|
|
|
|
*
|
2017-03-03 22:45:57 +08:00
|
|
|
|
* Programmer Binh-Minh Ribler
|
|
|
|
|
* Friday, March 4, 2014
|
2016-12-28 22:44:01 +08:00
|
|
|
|
*
|
|
|
|
|
* Modifications:
|
|
|
|
|
*
|
|
|
|
|
*-------------------------------------------------------------------------
|
|
|
|
|
*/
|
|
|
|
|
static void test_existance()
|
|
|
|
|
{
|
|
|
|
|
SUBTEST("H5File::exists and Group::exists");
|
|
|
|
|
|
|
|
|
|
try {
|
2017-03-03 22:45:57 +08:00
|
|
|
|
// Open file
|
|
|
|
|
H5File file(FILE_OBJECTS, H5F_ACC_RDONLY);
|
2016-12-28 22:44:01 +08:00
|
|
|
|
|
2017-03-03 22:45:57 +08:00
|
|
|
|
// Check if GROUP1 exists in the file
|
|
|
|
|
bool exists = file.exists(GROUP1);
|
2016-12-28 22:44:01 +08:00
|
|
|
|
|
2017-03-03 22:45:57 +08:00
|
|
|
|
// Open GROUP1
|
|
|
|
|
Group grp1 = file.openGroup(GROUP1);
|
2016-12-28 22:44:01 +08:00
|
|
|
|
|
2017-03-03 22:45:57 +08:00
|
|
|
|
// Check if GROUP1_1 and GROUP1_2 exist in GROUP1
|
|
|
|
|
exists = grp1.exists(GROUP1_1);
|
|
|
|
|
verify_val(exists, TRUE, "Group::exists GROUP1_1", __LINE__, __FILE__);
|
|
|
|
|
exists = grp1.exists(GROUP1_2);
|
|
|
|
|
verify_val(exists, TRUE, "Group::exists GROUP1_2", __LINE__, __FILE__);
|
2016-12-28 22:44:01 +08:00
|
|
|
|
|
2017-03-03 22:45:57 +08:00
|
|
|
|
// Check if DSET_IN_GRP1 exists in GROUP1
|
|
|
|
|
exists = grp1.exists(DSET_IN_GRP1);
|
|
|
|
|
verify_val(exists, TRUE, "Group::exists DSET_IN_GRP1", __LINE__, __FILE__);
|
2016-12-28 22:44:01 +08:00
|
|
|
|
|
2017-03-03 22:45:57 +08:00
|
|
|
|
// Open GROUP1_2
|
|
|
|
|
Group grp1_2 = grp1.openGroup(GROUP1_2);
|
2016-12-28 22:44:01 +08:00
|
|
|
|
|
2017-03-03 22:45:57 +08:00
|
|
|
|
// Check if DSET_IN_GRP1_2 exists in GROUP1_2
|
|
|
|
|
exists = grp1_2.exists(DSET_IN_GRP1_2);
|
|
|
|
|
verify_val(exists, TRUE, "Group::exists DSET_IN_GRP1_2", __LINE__, __FILE__);
|
2016-12-28 22:44:01 +08:00
|
|
|
|
|
2017-03-03 22:45:57 +08:00
|
|
|
|
// Check if a dataset exists given dataset as location with full path name
|
|
|
|
|
DataSet dset1 = file.openDataSet(DSET_IN_FILE);
|
|
|
|
|
exists = dset1.exists("/Top Group/Dataset_in_Group_1");
|
|
|
|
|
verify_val(exists, TRUE, "Group::exists given dataset with full path name", __LINE__, __FILE__);
|
2016-12-28 22:44:01 +08:00
|
|
|
|
|
2017-03-03 22:45:57 +08:00
|
|
|
|
exists = grp1_2.exists(DSET_IN_GRP1);
|
|
|
|
|
verify_val(exists, FALSE, "Group::exists DSET_IN_GRP1", __LINE__, __FILE__);
|
2016-12-28 22:44:01 +08:00
|
|
|
|
|
2017-03-03 22:45:57 +08:00
|
|
|
|
// Everything will be closed as they go out of scope
|
2016-12-28 22:44:01 +08:00
|
|
|
|
|
2017-03-03 22:45:57 +08:00
|
|
|
|
PASSED();
|
|
|
|
|
} // try block
|
2016-12-28 22:44:01 +08:00
|
|
|
|
|
|
|
|
|
// catch all other exceptions
|
|
|
|
|
catch (Exception& E)
|
|
|
|
|
{
|
2017-03-03 22:45:57 +08:00
|
|
|
|
issue_fail_msg("test_existance", __LINE__, __FILE__);
|
2016-12-28 22:44:01 +08:00
|
|
|
|
}
|
|
|
|
|
} // test_existance
|
2014-04-07 06:36:15 +08:00
|
|
|
|
|
|
|
|
|
/*-------------------------------------------------------------------------
|
2017-03-03 22:45:57 +08:00
|
|
|
|
* Function: test_get_objname_ontypes
|
2014-04-07 06:36:15 +08:00
|
|
|
|
*
|
2017-03-03 22:45:57 +08:00
|
|
|
|
* Purpose Test getting object name from various committed types.
|
2014-04-07 06:36:15 +08:00
|
|
|
|
*
|
2017-03-03 22:45:57 +08:00
|
|
|
|
* Return Success: 0
|
|
|
|
|
* Failure: -1
|
2014-04-07 06:36:15 +08:00
|
|
|
|
*
|
2017-03-03 22:45:57 +08:00
|
|
|
|
* Programmer Binh-Minh Ribler
|
|
|
|
|
* March 4, 2014
|
2014-04-07 06:36:15 +08:00
|
|
|
|
*
|
|
|
|
|
* Modifications:
|
|
|
|
|
*
|
|
|
|
|
*-------------------------------------------------------------------------
|
|
|
|
|
*/
|
|
|
|
|
static void test_get_objname_ontypes()
|
|
|
|
|
{
|
|
|
|
|
SUBTEST("H5Object::getObjName on Committed Datatypes");
|
|
|
|
|
|
|
|
|
|
try {
|
2017-03-03 22:45:57 +08:00
|
|
|
|
// Create a file with default prop lists
|
|
|
|
|
H5File file(FILE_OBJECTS, H5F_ACC_RDWR);
|
|
|
|
|
|
|
|
|
|
// Create a group
|
|
|
|
|
Group grp = file.createGroup ("typetests");
|
|
|
|
|
|
|
|
|
|
// Create a datatype and save it
|
|
|
|
|
IntType inttype(PredType::STD_B8LE);
|
|
|
|
|
inttype.commit(file, "INT type of STD_B8LE");
|
|
|
|
|
|
|
|
|
|
// Close the type then open it again to test getting its name
|
|
|
|
|
inttype.close();
|
|
|
|
|
inttype = file.openIntType("INT type of STD_B8LE"); // deprecated
|
|
|
|
|
|
|
|
|
|
// Get and verify its name
|
|
|
|
|
H5std_string inttype_name = inttype.getObjName();
|
|
|
|
|
verify_val(inttype_name, "/INT type of STD_B8LE", "DataType::getObjName", __LINE__, __FILE__);
|
|
|
|
|
|
|
|
|
|
// Close the type then open it again to test getting its name, but
|
|
|
|
|
// with the constructor this time
|
|
|
|
|
inttype.close();
|
|
|
|
|
IntType std_b8le(file, "INT type of STD_B8LE");
|
|
|
|
|
|
|
|
|
|
// Get and verify its name
|
|
|
|
|
H5std_string std_b8le_name = std_b8le.getObjName();
|
|
|
|
|
verify_val(std_b8le_name, "/INT type of STD_B8LE", "DataType::getObjName", __LINE__, __FILE__);
|
|
|
|
|
|
|
|
|
|
// Make copy of a predefined type and save it
|
|
|
|
|
DataType dtype(PredType::STD_B8LE);
|
|
|
|
|
dtype.commit(file, "STD_B8LE");
|
|
|
|
|
|
|
|
|
|
// Close the data type and file
|
|
|
|
|
dtype.close();
|
|
|
|
|
file.close();
|
|
|
|
|
|
|
|
|
|
// Re-open the file and the data type to test getting its name
|
|
|
|
|
file.openFile(FILE_OBJECTS, H5F_ACC_RDWR);
|
|
|
|
|
dtype = file.openDataType("STD_B8LE"); // deprecated
|
|
|
|
|
|
|
|
|
|
// Get and verify its name
|
|
|
|
|
H5std_string type_name = dtype.getObjName();
|
|
|
|
|
verify_val(type_name, "/STD_B8LE", "DataType::getObjName", __LINE__, __FILE__);
|
|
|
|
|
|
|
|
|
|
// Close the type and open it again with the constructor then test
|
|
|
|
|
// getting its name
|
|
|
|
|
dtype.close();
|
|
|
|
|
DataType dtype2(file, "STD_B8LE");
|
|
|
|
|
type_name = dtype2.getObjName();
|
|
|
|
|
verify_val(type_name, "/STD_B8LE", "DataType::getObjName", __LINE__, __FILE__);
|
|
|
|
|
|
|
|
|
|
// Test getting type's name from copied type
|
|
|
|
|
DataType copied_type;
|
|
|
|
|
copied_type.copy(dtype2);
|
|
|
|
|
copied_type.commit(file, "copy of STD_B8LE");
|
|
|
|
|
type_name = copied_type.getObjName();
|
|
|
|
|
verify_val(type_name, "/copy of STD_B8LE", "DataType::getObjName", __LINE__, __FILE__);
|
|
|
|
|
|
|
|
|
|
// Test copying an integer predefined type
|
|
|
|
|
IntType new_int_type(PredType::NATIVE_INT);
|
|
|
|
|
|
|
|
|
|
// Name this datatype
|
|
|
|
|
new_int_type.commit(grp, "IntType NATIVE_INT");
|
|
|
|
|
ssize_t name_len = new_int_type.getObjName(type_name); // default len
|
|
|
|
|
verify_val(name_len, (ssize_t)HDstrlen("/typetests/IntType NATIVE_INT"), "DataType::getObjName", __LINE__, __FILE__);
|
|
|
|
|
verify_val(type_name, "/typetests/IntType NATIVE_INT", "DataType::getObjName", __LINE__, __FILE__);
|
|
|
|
|
|
|
|
|
|
// Close everything or they can be closed when objects go out of scope
|
|
|
|
|
dtype2.close();
|
|
|
|
|
copied_type.close();
|
|
|
|
|
new_int_type.close();
|
|
|
|
|
grp.close();
|
|
|
|
|
|
|
|
|
|
PASSED();
|
2014-04-07 06:36:15 +08:00
|
|
|
|
} // end top try block
|
|
|
|
|
|
2016-04-22 19:22:34 +08:00
|
|
|
|
catch (Exception& E)
|
2014-04-07 06:36:15 +08:00
|
|
|
|
{
|
2017-03-03 22:45:57 +08:00
|
|
|
|
issue_fail_msg("test_get_objname_ontypes", __LINE__, __FILE__);
|
2014-04-07 06:36:15 +08:00
|
|
|
|
}
|
|
|
|
|
} // test_get_objname_ontypes
|
|
|
|
|
|
2014-04-08 04:08:59 +08:00
|
|
|
|
/*-------------------------------------------------------------------------
|
2017-03-03 22:45:57 +08:00
|
|
|
|
* Function: test_get_objtype
|
2014-04-08 04:08:59 +08:00
|
|
|
|
*
|
2017-03-03 22:45:57 +08:00
|
|
|
|
* Purpose Tests getting object type
|
2014-04-08 04:08:59 +08:00
|
|
|
|
*
|
2017-03-03 22:45:57 +08:00
|
|
|
|
* Return Success: 0
|
|
|
|
|
* Failure: -1
|
2014-04-08 04:08:59 +08:00
|
|
|
|
*
|
2017-03-03 22:45:57 +08:00
|
|
|
|
* Programmer Binh-Minh Ribler
|
|
|
|
|
* Friday, March 4, 2014
|
2014-04-08 04:08:59 +08:00
|
|
|
|
*
|
|
|
|
|
* Modifications:
|
|
|
|
|
*
|
|
|
|
|
*-------------------------------------------------------------------------
|
|
|
|
|
*/
|
|
|
|
|
static void test_get_objtype()
|
|
|
|
|
{
|
|
|
|
|
SUBTEST("H5File::childObjType and H5Group::childObjType");
|
|
|
|
|
|
|
|
|
|
try {
|
2017-03-03 22:45:57 +08:00
|
|
|
|
// Open file
|
|
|
|
|
H5File file(FILE_OBJECTS, H5F_ACC_RDWR);
|
2014-04-08 04:08:59 +08:00
|
|
|
|
|
2017-03-03 22:45:57 +08:00
|
|
|
|
// Open the top group
|
|
|
|
|
Group grp1 = file.openGroup(GROUP1);
|
2014-04-08 04:08:59 +08:00
|
|
|
|
|
2017-03-03 22:45:57 +08:00
|
|
|
|
// Create a datatype and save it
|
|
|
|
|
DataType dtype(PredType::STD_I32LE);
|
|
|
|
|
dtype.commit(grp1, "STD_I32LE");
|
2014-04-08 04:08:59 +08:00
|
|
|
|
|
2017-03-03 22:45:57 +08:00
|
|
|
|
// Get and verify object type with
|
|
|
|
|
// H5O_type_t childObjType(const H5std_string& objname)
|
|
|
|
|
H5O_type_t objtype = file.childObjType(DSET_IN_FILE);
|
|
|
|
|
verify_val(objtype, H5O_TYPE_DATASET, "DataSet::childObjType", __LINE__, __FILE__);
|
2014-04-08 04:08:59 +08:00
|
|
|
|
|
2017-03-03 22:45:57 +08:00
|
|
|
|
// Get and verify object type with
|
|
|
|
|
// H5O_type_t childObjType(const char* objname)
|
|
|
|
|
objtype = grp1.childObjType(GROUP1_1.c_str());
|
|
|
|
|
verify_val(objtype, H5O_TYPE_GROUP, "DataSet::childObjType", __LINE__, __FILE__);
|
2014-04-08 04:08:59 +08:00
|
|
|
|
|
2017-03-03 22:45:57 +08:00
|
|
|
|
// Get and verify object type with
|
|
|
|
|
// H5O_type_t childObjType(hsize_t index, H5_index_t index_type,
|
|
|
|
|
// H5_iter_order_t order, const char* objname=".")
|
|
|
|
|
objtype = grp1.childObjType((hsize_t)1, H5_INDEX_NAME, H5_ITER_INC);
|
|
|
|
|
verify_val(objtype, H5O_TYPE_NAMED_DATATYPE, "DataSet::childObjType", __LINE__, __FILE__);
|
2014-04-08 04:08:59 +08:00
|
|
|
|
|
2017-03-03 22:45:57 +08:00
|
|
|
|
// Get and verify object type with
|
|
|
|
|
// H5O_type_t childObjType(hsize_t index,
|
|
|
|
|
// H5_index_t index_type=H5_INDEX_NAME,
|
|
|
|
|
// H5_iter_order_t order=H5_ITER_INC, const char* objname=".")
|
|
|
|
|
objtype = grp1.childObjType((hsize_t)2);
|
|
|
|
|
verify_val(objtype, H5O_TYPE_GROUP, "DataSet::childObjType", __LINE__, __FILE__);
|
2014-04-08 04:08:59 +08:00
|
|
|
|
|
2017-03-03 22:45:57 +08:00
|
|
|
|
// Everything will be closed as they go out of scope
|
2014-04-08 04:08:59 +08:00
|
|
|
|
|
2017-03-03 22:45:57 +08:00
|
|
|
|
PASSED();
|
|
|
|
|
} // try block
|
2014-04-08 04:08:59 +08:00
|
|
|
|
|
|
|
|
|
// catch all other exceptions
|
2016-04-22 19:22:34 +08:00
|
|
|
|
catch (Exception& E)
|
2014-04-08 04:08:59 +08:00
|
|
|
|
{
|
2017-03-03 22:45:57 +08:00
|
|
|
|
issue_fail_msg("test_get_objtype", __LINE__, __FILE__);
|
2014-04-08 04:08:59 +08:00
|
|
|
|
}
|
|
|
|
|
} // test_get_objtype
|
Purpose: Add new C++ wrappers
Description:
Added wrappers for H5Iis_valid, H5Ps/get_nlinks, H5Tget_create_plist,
H5Oopen, H5Oclose and H5Pset_virtual
// Checks if the given ID is valid.
static bool isValid(hid_t an_id);
// Sets the number of soft or user-defined links that can be
// traversed before a failure occurs.
void setNumLinks(size_t nlinks) const;
// Gets the number of soft or user-defined link traversals allowed
size_t getNumLinks() const;
// Returns a copy of the creation property list of a datatype.
PropList getCreatePlist() const;
// Opens an object within a group or a file, i.e., root group.
hid_t getObjId(const char* name,...);
hid_t getObjId(const H5std_string& name,...);
// Closes an object opened by getObjId().
void closeObjId(hid_t obj_id) const;
// Maps elements of a virtual dataset to elements of the source dataset.
void setVirtual(const DataSpace& vspace, const char *src_fname,...);
void setVirtual(const DataSpace& vspace, const H5std_string src_fname,...);
Platforms tested:
Linux/32 2.6 (jam)
Linux/64 (platypus)
Darwin (osx1010test)
2017-03-14 11:53:43 +08:00
|
|
|
|
|
|
|
|
|
/*-------------------------------------------------------------------------
|
|
|
|
|
* Function: test_open_object_header
|
|
|
|
|
*
|
|
|
|
|
* Purpose Test Group::getObjId function.
|
|
|
|
|
*
|
|
|
|
|
* Return None
|
|
|
|
|
*
|
|
|
|
|
* Programmer Binh-Minh Ribler (use C version)
|
|
|
|
|
* March, 2017
|
|
|
|
|
*
|
|
|
|
|
* Modifications:
|
|
|
|
|
*
|
|
|
|
|
*-------------------------------------------------------------------------
|
|
|
|
|
*/
|
|
|
|
|
const H5std_string GROUPNAME("group");
|
|
|
|
|
const H5std_string DTYPENAME("group/datatype");
|
|
|
|
|
const H5std_string DTYPENAME_INGRP("datatype");
|
|
|
|
|
const H5std_string DSETNAME("dataset");
|
|
|
|
|
#define RANK 2
|
|
|
|
|
#define DIM0 5
|
|
|
|
|
#define DIM1 10
|
|
|
|
|
static void test_open_object_header()
|
|
|
|
|
{
|
|
|
|
|
hsize_t dims[2];
|
|
|
|
|
H5G_info_t ginfo; /* Group info struct */
|
|
|
|
|
|
|
|
|
|
// Output message about test being performed
|
|
|
|
|
SUBTEST("Group::getObjId");
|
|
|
|
|
|
|
|
|
|
try {
|
|
|
|
|
// Create file FILE1
|
|
|
|
|
H5File file1(FILE_OBJHDR, H5F_ACC_TRUNC);
|
|
|
|
|
/* Create a group, dataset, and committed datatype within the file */
|
|
|
|
|
|
|
|
|
|
// Create a group in the root group
|
|
|
|
|
Group grp(file1.createGroup(GROUPNAME));
|
|
|
|
|
grp.close();
|
2014-04-08 04:08:59 +08:00
|
|
|
|
|
Purpose: Add new C++ wrappers
Description:
Added wrappers for H5Iis_valid, H5Ps/get_nlinks, H5Tget_create_plist,
H5Oopen, H5Oclose and H5Pset_virtual
// Checks if the given ID is valid.
static bool isValid(hid_t an_id);
// Sets the number of soft or user-defined links that can be
// traversed before a failure occurs.
void setNumLinks(size_t nlinks) const;
// Gets the number of soft or user-defined link traversals allowed
size_t getNumLinks() const;
// Returns a copy of the creation property list of a datatype.
PropList getCreatePlist() const;
// Opens an object within a group or a file, i.e., root group.
hid_t getObjId(const char* name,...);
hid_t getObjId(const H5std_string& name,...);
// Closes an object opened by getObjId().
void closeObjId(hid_t obj_id) const;
// Maps elements of a virtual dataset to elements of the source dataset.
void setVirtual(const DataSpace& vspace, const char *src_fname,...);
void setVirtual(const DataSpace& vspace, const H5std_string src_fname,...);
Platforms tested:
Linux/32 2.6 (jam)
Linux/64 (platypus)
Darwin (osx1010test)
2017-03-14 11:53:43 +08:00
|
|
|
|
// Commit the type inside the file
|
|
|
|
|
IntType dtype(PredType::NATIVE_INT);
|
|
|
|
|
dtype.commit(file1, DTYPENAME);
|
|
|
|
|
dtype.close();
|
|
|
|
|
|
|
|
|
|
// Create a new dataset
|
|
|
|
|
dims[0] = DIM0;
|
|
|
|
|
dims[1] = DIM1;
|
|
|
|
|
DataSpace dspace(RANK, dims);
|
|
|
|
|
DataSet dset(file1.createDataSet(DSETNAME, PredType::NATIVE_INT, dspace));
|
|
|
|
|
|
|
|
|
|
// Close dataset and dataspace
|
|
|
|
|
dset.close();
|
|
|
|
|
dspace.close();
|
|
|
|
|
|
|
|
|
|
// Now make sure that getObjId can open all three types of objects
|
|
|
|
|
hid_t obj_grp = file1.getObjId(GROUPNAME);
|
|
|
|
|
hid_t obj_dtype = file1.getObjId(DTYPENAME);
|
|
|
|
|
hid_t obj_dset = file1.getObjId(DSETNAME);
|
|
|
|
|
|
|
|
|
|
// Make sure that each is the right kind of ID
|
|
|
|
|
H5I_type_t id_type = IdComponent::getHDFObjType(obj_grp);
|
|
|
|
|
verify_val(id_type, H5I_GROUP, "H5Iget_type for group ID", __LINE__, __FILE__);
|
|
|
|
|
id_type = IdComponent::getHDFObjType(obj_dtype);
|
|
|
|
|
verify_val(id_type, H5I_DATATYPE, "H5Iget_type for datatype ID", __LINE__, __FILE__);
|
|
|
|
|
id_type = IdComponent::getHDFObjType(obj_dset);
|
|
|
|
|
verify_val(id_type, H5I_DATASET, "H5Iget_type for dataset ID", __LINE__, __FILE__);
|
|
|
|
|
|
|
|
|
|
/* Do something more complex with each of the IDs to make sure */
|
|
|
|
|
|
|
|
|
|
Group grp2(obj_grp);
|
|
|
|
|
hsize_t num_objs = grp2.getNumObjs();
|
|
|
|
|
verify_val(num_objs, 1, "H5Gget_info", __LINE__, __FILE__);
|
|
|
|
|
// There should be one object, the datatype
|
|
|
|
|
|
|
|
|
|
// Close datatype object opened from the file
|
|
|
|
|
file1.closeObjId(obj_dtype);
|
|
|
|
|
|
|
|
|
|
dset.setId(obj_dset);
|
|
|
|
|
dspace = dset.getSpace();
|
|
|
|
|
bool is_simple = dspace.isSimple();
|
|
|
|
|
dspace.close();
|
|
|
|
|
|
|
|
|
|
// Open datatype object from the group
|
|
|
|
|
obj_dtype = grp2.getObjId(DTYPENAME_INGRP);
|
|
|
|
|
|
|
|
|
|
dtype.setId(obj_dtype);
|
|
|
|
|
H5T_class_t type_class = dtype.getClass();
|
|
|
|
|
verify_val(type_class, H5T_INTEGER, "H5Tget_class", __LINE__, __FILE__);
|
|
|
|
|
dtype.close();
|
|
|
|
|
|
|
|
|
|
// Close datatype object
|
|
|
|
|
grp2.closeObjId(obj_dtype);
|
|
|
|
|
|
|
|
|
|
// Close the group object
|
|
|
|
|
file1.closeObjId(obj_grp);
|
|
|
|
|
|
|
|
|
|
// Try doing something with group, the ID should still work
|
|
|
|
|
num_objs = grp2.getNumObjs();
|
|
|
|
|
verify_val(num_objs, 1, "H5Gget_info", __LINE__, __FILE__);
|
|
|
|
|
|
|
|
|
|
// Close the cloned group
|
|
|
|
|
grp2.close();
|
|
|
|
|
|
|
|
|
|
PASSED();
|
|
|
|
|
} // end of try block
|
|
|
|
|
// catch invalid action exception
|
|
|
|
|
catch (InvalidActionException& E)
|
|
|
|
|
{
|
|
|
|
|
cerr << " in InvalidActionException" << endl;
|
|
|
|
|
cerr << " *FAILED*" << endl;
|
|
|
|
|
cerr << " <<< " << E.getDetailMsg() << " >>>" << endl << endl;
|
|
|
|
|
}
|
|
|
|
|
// catch all other exceptions
|
|
|
|
|
catch (Exception& E)
|
|
|
|
|
{
|
|
|
|
|
cerr << " in Exception" << endl;
|
|
|
|
|
issue_fail_msg("test_file_name()", __LINE__, __FILE__, E.getCDetailMsg());
|
|
|
|
|
}
|
|
|
|
|
} /* test_open_object_header() */
|
|
|
|
|
|
2014-04-07 06:36:15 +08:00
|
|
|
|
/*-------------------------------------------------------------------------
|
2017-03-03 22:45:57 +08:00
|
|
|
|
* Function: test_objects
|
2014-04-07 06:36:15 +08:00
|
|
|
|
*
|
2017-03-03 22:45:57 +08:00
|
|
|
|
* Purpose Tests HDF5 object related functionality
|
2014-04-07 06:36:15 +08:00
|
|
|
|
*
|
2017-03-03 22:45:57 +08:00
|
|
|
|
* Return Success: 0
|
|
|
|
|
* Failure: -1
|
2014-04-07 06:36:15 +08:00
|
|
|
|
*
|
2017-03-03 22:45:57 +08:00
|
|
|
|
* Programmer Binh-Minh Ribler
|
|
|
|
|
* Friday, Mar 4, 2014
|
2014-04-07 06:36:15 +08:00
|
|
|
|
*
|
|
|
|
|
* Modifications:
|
|
|
|
|
*
|
|
|
|
|
*-------------------------------------------------------------------------
|
|
|
|
|
*/
|
|
|
|
|
extern "C"
|
|
|
|
|
void test_object()
|
|
|
|
|
{
|
|
|
|
|
// Output message about test being performed
|
|
|
|
|
MESSAGE(5, ("Testing Object Functions\n"));
|
|
|
|
|
|
|
|
|
|
test_get_objname(); // Test get object name from groups/datasets
|
2016-12-28 22:44:01 +08:00
|
|
|
|
test_existance(); // Test check for object existance
|
2017-03-03 22:45:57 +08:00
|
|
|
|
test_get_objname_ontypes(); // Test get object name from types
|
2014-04-08 04:08:59 +08:00
|
|
|
|
test_get_objtype(); // Test get object type
|
Purpose: Add new C++ wrappers
Description:
Added wrappers for H5Iis_valid, H5Ps/get_nlinks, H5Tget_create_plist,
H5Oopen, H5Oclose and H5Pset_virtual
// Checks if the given ID is valid.
static bool isValid(hid_t an_id);
// Sets the number of soft or user-defined links that can be
// traversed before a failure occurs.
void setNumLinks(size_t nlinks) const;
// Gets the number of soft or user-defined link traversals allowed
size_t getNumLinks() const;
// Returns a copy of the creation property list of a datatype.
PropList getCreatePlist() const;
// Opens an object within a group or a file, i.e., root group.
hid_t getObjId(const char* name,...);
hid_t getObjId(const H5std_string& name,...);
// Closes an object opened by getObjId().
void closeObjId(hid_t obj_id) const;
// Maps elements of a virtual dataset to elements of the source dataset.
void setVirtual(const DataSpace& vspace, const char *src_fname,...);
void setVirtual(const DataSpace& vspace, const H5std_string src_fname,...);
Platforms tested:
Linux/32 2.6 (jam)
Linux/64 (platypus)
Darwin (osx1010test)
2017-03-14 11:53:43 +08:00
|
|
|
|
test_open_object_header(); // Test object header functions (H5O)
|
2014-04-07 06:36:15 +08:00
|
|
|
|
|
|
|
|
|
} // test_objects
|
|
|
|
|
|
|
|
|
|
/*-------------------------------------------------------------------------
|
|
|
|
|
* Function: cleanup_objects
|
|
|
|
|
*
|
2017-03-03 22:45:57 +08:00
|
|
|
|
* Purpose Cleanup temporary test files
|
2014-04-07 06:36:15 +08:00
|
|
|
|
*
|
2017-03-03 22:45:57 +08:00
|
|
|
|
* Return none
|
2014-04-07 06:36:15 +08:00
|
|
|
|
*
|
2017-03-03 22:45:57 +08:00
|
|
|
|
* Programmer (use C version)
|
2014-04-07 06:36:15 +08:00
|
|
|
|
*
|
|
|
|
|
* Modifications:
|
|
|
|
|
*
|
|
|
|
|
*-------------------------------------------------------------------------
|
|
|
|
|
*/
|
|
|
|
|
extern "C"
|
|
|
|
|
void cleanup_object()
|
|
|
|
|
{
|
|
|
|
|
HDremove(FILE_OBJECTS.c_str());
|
|
|
|
|
} // cleanup_objects
|