From 8ea17935698f11f851a883f275bc4fe75c572f76 Mon Sep 17 00:00:00 2001 From: Raymond Lu Date: Wed, 26 May 2004 10:46:19 -0500 Subject: [svn-r8578] Purpose: new test Description: Add null dataspace test for dataset and attribute to h5diff Platforms tested: RH 8(fuss). Simple change, only h5diff is involved. --- tools/h5diff/testh5diff.sh | 2 ++ tools/h5diff/testh5diff_attr.c | 44 +++++++++++++++++++++++++++++++++++------- tools/h5diff/testh5diff_dset.c | 37 ++++++++++++++++++++++++++++++----- 3 files changed, 71 insertions(+), 12 deletions(-) diff --git a/tools/h5diff/testh5diff.sh b/tools/h5diff/testh5diff.sh index 23cbfaa..f9392fe 100755 --- a/tools/h5diff/testh5diff.sh +++ b/tools/h5diff/testh5diff.sh @@ -301,6 +301,8 @@ TOOLTEST h5diff_70.txt file5.h5 file6.h5 TOOLTEST h5diff_80.txt file7.h5 file8.h5 +TOOLTEST h5diff_81.txt file7.h5 file8.h5 -v + diff --git a/tools/h5diff/testh5diff_attr.c b/tools/h5diff/testh5diff_attr.c index fb6dc39..bc88431 100644 --- a/tools/h5diff/testh5diff_attr.c +++ b/tools/h5diff/testh5diff_attr.c @@ -27,8 +27,6 @@ * *------------------------------------------------------------------------- */ - - static void write_attr_in(hid_t loc_id, const char* dset_name, /* for saving reference to dataset*/ hid_t file_id, @@ -1027,7 +1025,42 @@ etc write_attr(loc_id,3,dims3,"float3D",H5T_NATIVE_FLOAT,buf83); } - +/*------------------------------------------------------------------------- + * Function: write_null_attr + * + * Purpose: write null attribute in LOC_ID (dataset, group, named datatype) + * + * Programmer: Raymond Lu, slu@ncsa.uiuc.edu + * + * Date: May 24, 2004 + * + *------------------------------------------------------------------------- + */ +static void write_null_attr(hid_t loc_id, + int make_diffs /* flag to modify data buffers */) +{ + hid_t sid, attr_id; + int val = 2; + unsigned uval = 7; + + /* Create the null attribute */ + sid = H5Screate(H5S_NULL); + if(make_diffs) { + attr_id = H5Acreate(loc_id, "null_attr", H5T_NATIVE_INT, sid, H5P_DEFAULT); + + /* Not supposed to write anything */ + H5Awrite(attr_id, H5T_NATIVE_INT, &val); + } else { + attr_id = H5Acreate(loc_id, "null_attr", H5T_NATIVE_UINT, sid, H5P_DEFAULT); + + /* Not supposed to write anything */ + H5Awrite(attr_id, H5T_NATIVE_INT, &uval); + } + + /* Close */ + H5Aclose(attr_id); + H5Sclose(sid); +} /*------------------------------------------------------------------------- * Check all HDF5 classes @@ -1036,8 +1069,6 @@ etc * H5T_ENUM, H5T_VLEN, H5T_ARRAY *------------------------------------------------------------------------- */ - - int test_attr(const char *file, int make_diffs /* flag to modify data buffers */) { @@ -1067,11 +1098,10 @@ int test_attr(const char *file, * write a series of attributes on the dataset, group, and root group *------------------------------------------------------------------------- */ - write_attr_in(dset_id,"dset",file_id,make_diffs); write_attr_in(group_id,NULL,0,make_diffs); write_attr_in(root_id,NULL,0,make_diffs); - + write_null_attr(root_id,make_diffs); /* Close */ status = H5Dclose(dset_id); diff --git a/tools/h5diff/testh5diff_dset.c b/tools/h5diff/testh5diff_dset.c index 8158c5e..8ea892b 100644 --- a/tools/h5diff/testh5diff_dset.c +++ b/tools/h5diff/testh5diff_dset.c @@ -602,6 +602,37 @@ static void write_dset_in(hid_t loc_id, write_dset(loc_id,3,dims3,"float3D",H5T_NATIVE_FLOAT,buf83); } +/*------------------------------------------------------------------------- + * Function: write_null_dset + * + * Purpose: write null dataset in LOC_ID + * + * Programmer: Raymond Lu, slu@ncsa.uiuc.edu + * + * Date: May 24, 2004 + * + *------------------------------------------------------------------------- + */ +static void write_null_dset(hid_t loc_id, int make_diffs) +{ + hid_t sid, dset_id; + int val = 2; + double dval = 7.8; + + /* Create the null attribute */ + sid = H5Screate(H5S_NULL); + if(make_diffs) { + dset_id = H5Dcreate(loc_id,"null_dset",H5T_NATIVE_INT,sid,H5P_DEFAULT); + H5Dwrite(dset_id,H5T_NATIVE_INT,H5S_ALL,H5S_ALL,H5P_DEFAULT,&val); + } else { + dset_id = H5Dcreate(loc_id,"null_dset",H5T_NATIVE_DOUBLE,sid,H5P_DEFAULT); + H5Dwrite(dset_id,H5T_NATIVE_DOUBLE,H5S_ALL,H5S_ALL,H5P_DEFAULT,&dval); + } + + /* Close */ + H5Dclose(dset_id); + H5Sclose(sid); +} /*------------------------------------------------------------------------- * Check all HDF5 classes @@ -610,8 +641,6 @@ static void write_dset_in(hid_t loc_id, * H5T_ENUM, H5T_VLEN, H5T_ARRAY *------------------------------------------------------------------------- */ - - int test_dsetall(const char *file, int make_diffs /* flag to modify data buffers */) { @@ -648,6 +677,7 @@ int test_dsetall(const char *file, */ write_dset_in(group_id,"/dset",file_id,make_diffs); + write_null_dset(file_id, make_diffs); /* Close */ status = H5Dclose(dset_id); @@ -660,6 +690,3 @@ int test_dsetall(const char *file, assert(status>=0); return status; } - - - -- cgit v0.12