summaryrefslogtreecommitdiffstats
path: root/test
diff options
context:
space:
mode:
authorRaymond Lu <songyulu@hdfgroup.org>2005-06-02 21:00:23 (GMT)
committerRaymond Lu <songyulu@hdfgroup.org>2005-06-02 21:00:23 (GMT)
commit769694294033cf2021b506cde1302af5fdb2ebff (patch)
tree6eb63c4e19e009f217164f91d16250cb21edbbc5 /test
parentc02d9c7c0d4e526837445306bb35eb108db92ff5 (diff)
downloadhdf5-769694294033cf2021b506cde1302af5fdb2ebff.zip
hdf5-769694294033cf2021b506cde1302af5fdb2ebff.tar.gz
hdf5-769694294033cf2021b506cde1302af5fdb2ebff.tar.bz2
[svn-r10847] Purpose: Bug fix
Description: See details from Bug #213. Family member file size wasn't saved anywhere in file. When family file is opened, the first member size determine the member size. Solution: This is the fourth step of checkin. A test suit is added for h5repart, including a program to generate the test files, a script file to run h5repart, and a program to verify repartitioned files can be opened by the library. There's a change from the first step of checkin. Family name template is no longer saved in the superblock because different pathname can make the name different. In the third step of checkin, h5repart has been modified. If h5repart is used to change the size of family member file, the new size(actual member size) is saved in the superblock. In the second step of checkin, multi driver is checked against the driver name saved in superblock. Wrong driver will result in a failure with an error message indicating multi driver should be used. This change includes split driver because it's a special case for multi driver. In the first step of checkin. Family member size and name template(unused at this stage) are saved in file superblock. When file is reopened,the size passed in thrin superblock. A different size will trigger a failure with an error message indicating the right size. Wrong driver to open family file will cause a failure, too. Platforms tested: h5committest and fuss. Misc. update: MANIFEST
Diffstat (limited to 'test')
-rw-r--r--test/file_handle.c19
1 files changed, 12 insertions, 7 deletions
diff --git a/test/file_handle.c b/test/file_handle.c
index 81b5934..ba54947 100644
--- a/test/file_handle.c
+++ b/test/file_handle.c
@@ -32,6 +32,8 @@ const char *FILENAME[] = {
"core_file",
"family_file",
"multi_file",
+ "fst_family",
+ "scd_family",
NULL
};
@@ -231,7 +233,7 @@ test_family_opens(char *fname, hid_t fa_pl)
} H5E_END_TRY;
/* Case 3: reopen file with wrong member size */
- if(H5Pset_fapl_family(fa_pl, 128, H5P_DEFAULT)<0)
+ if(H5Pset_fapl_family(fa_pl, (hsize_t)128, H5P_DEFAULT)<0)
goto error;
H5E_BEGIN_TRY {
@@ -247,7 +249,7 @@ test_family_opens(char *fname, hid_t fa_pl)
}
}
- if(H5Pset_fapl_family(fa_pl, FAMILY_SIZE, H5P_DEFAULT)<0)
+ if(H5Pset_fapl_family(fa_pl, (hsize_t)FAMILY_SIZE, H5P_DEFAULT)<0)
goto error;
H5E_BEGIN_TRY {
@@ -278,6 +280,11 @@ error:
* Wednesday, June 23, 2004
* Added test for H5Fget_filesize.
*
+ * Raymond Lu
+ * June 2, 2005
+ * Added a function test_family_opens() to test different
+ * wrong way to reopen family files.
+ *
*-------------------------------------------------------------------------
*/
static herr_t
@@ -297,6 +304,7 @@ test_family(void)
/* Set property list and file name for FAMILY driver */
fapl = h5_fileaccess();
+
if(H5Pset_fapl_family(fapl, (hsize_t)FAMILY_SIZE, H5P_DEFAULT)<0)
goto error;
h5_fixname(FILENAME[2], fapl, filename, sizeof filename);
@@ -313,7 +321,7 @@ test_family(void)
goto error;
/* Reopen the file with default member file size */
- if(H5Pset_fapl_family(fapl, H5F_FAMILY_DEFAULT, H5P_DEFAULT)<0)
+ if(H5Pset_fapl_family(fapl, (hsize_t)H5F_FAMILY_DEFAULT, H5P_DEFAULT)<0)
goto error;
if((file=H5Fopen(filename, H5F_ACC_RDWR, fapl))<0)
@@ -395,7 +403,7 @@ test_family(void)
goto error;
/* Reopen the file with correct member file size. */
- if(H5Pset_fapl_family(fapl, FAMILY_SIZE, H5P_DEFAULT)<0)
+ if(H5Pset_fapl_family(fapl, (hsize_t)FAMILY_SIZE, H5P_DEFAULT)<0)
goto error;
if((file=H5Fopen(filename, H5F_ACC_RDWR, fapl))<0)
@@ -413,7 +421,6 @@ error:
H5Sclose(space);
H5Dclose(dset);
H5Pclose (fapl2);
- H5Pclose (fapl2);
H5Fclose(file);
} H5E_END_TRY;
return -1;
@@ -452,8 +459,6 @@ test_multi_opens(char *fname, hid_t fa_pl)
} H5E_END_TRY;
return 0;
-error:
- return -1;
}