summaryrefslogtreecommitdiffstats
path: root/test/file_handle.c
diff options
context:
space:
mode:
authorRaymond Lu <songyulu@hdfgroup.org>2005-06-07 19:38:53 (GMT)
committerRaymond Lu <songyulu@hdfgroup.org>2005-06-07 19:38:53 (GMT)
commit55fbd2aaac6e51bcf292d105ed84f77935c2d747 (patch)
tree19d1e4fecf32a14cce8057b3b760ad940038e7ac /test/file_handle.c
parent1a4401ca4cfdc412903d65d926aa47e109e33f7f (diff)
downloadhdf5-55fbd2aaac6e51bcf292d105ed84f77935c2d747.zip
hdf5-55fbd2aaac6e51bcf292d105ed84f77935c2d747.tar.gz
hdf5-55fbd2aaac6e51bcf292d105ed84f77935c2d747.tar.bz2
[svn-r10869] Purpose: A feature
Description: For v1.7 library, family file driver has been changed. The family member size is saved in the superblock and compared to the size passed in through H5Pset_fapl_family(). Solution: Added test to check if we can open family file created with v1.7 library. Platforms tested: h5committest and fuss. Misc. update: MANIFEST
Diffstat (limited to 'test/file_handle.c')
-rw-r--r--test/file_handle.c72
1 files changed, 70 insertions, 2 deletions
diff --git a/test/file_handle.c b/test/file_handle.c
index 1db5e14..b957b15 100644
--- a/test/file_handle.c
+++ b/test/file_handle.c
@@ -23,15 +23,17 @@
#define KB 1024
#define FAMILY_NUMBER 4
-#define FAMILY_SIZE 1024
+#define FAMILY_SIZE (1*KB)
+#define FAMILY_SIZE2 (5*KB)
#define MULTI_SIZE 128
-#define CORE_INCREMENT 4096
+#define CORE_INCREMENT (4*KB)
const char *FILENAME[] = {
"sec2_file",
"core_file",
"family_file",
"multi_file",
+ "family_v1.7_",
NULL
};
@@ -335,6 +337,71 @@ error:
/*-------------------------------------------------------------------------
+ * Function: test_family_compat
+ *
+ * Purpose: Tests the forward compatibility for FAMILY driver.
+ * See if we can open files created with v1.7 library.
+ * The source file was created by the test/file_handle.c
+ * of the v1.7 library. Then tools/misc/h5repart.c was
+ * used to concantenated. The command was "h5repart -m 5k
+ * family_file%05d.h5 family_v1.7_%05d.h5".
+ *
+ * Return: Success: exit(0)
+ *
+ * Failure: exit(1)
+ *
+ * Programmer: Raymond Lu
+ * June 3, 2005
+ *
+ * Modifications:
+ *-------------------------------------------------------------------------
+ */
+static herr_t
+test_family_compat(void)
+{
+ hid_t file=(-1), fapl;
+ char filename[1024];
+ char pathname[1024];
+ char *srcdir = getenv("srcdir"); /*where the src code is located*/
+
+ TESTING("FAMILY file driver forward compatibility");
+
+ /* Set property list and file name for FAMILY driver */
+ fapl = h5_fileaccess();
+
+ if(H5Pset_fapl_family(fapl, (hsize_t)FAMILY_SIZE2, H5P_DEFAULT)<0)
+ goto error;
+
+ h5_fixname(FILENAME[4], fapl, filename, sizeof filename);
+
+ /* Generate correct name for test file by prepending the source path */
+ if(srcdir && ((strlen(srcdir) + strlen(filename) + 1) < sizeof(pathname))) {
+ strcpy(pathname, srcdir);
+ strcat(pathname, "/");
+ }
+ strcat(pathname, filename);
+
+ if((file=H5Fopen(pathname, H5F_ACC_RDONLY, fapl))<0)
+ goto error;
+
+ if(H5Fclose(file)<0)
+ goto error;
+
+ if(H5Pclose(fapl)<0)
+ goto error;
+
+ PASSED();
+ return 0;
+
+error:
+ H5E_BEGIN_TRY {
+ H5Fclose(file);
+ } H5E_END_TRY;
+ return -1;
+}
+
+
+/*-------------------------------------------------------------------------
* Function: test_multi
*
* Purpose: Tests the file handle interface for MUTLI driver
@@ -515,6 +582,7 @@ main(void)
nerrors += test_sec2()<0 ?1:0;
nerrors += test_core()<0 ?1:0;
nerrors += test_family()<0 ?1:0;
+ nerrors += test_family_compat()<0 ?1:0;
nerrors += test_multi()<0 ?1:0;
if (nerrors) goto error;