summaryrefslogtreecommitdiffstats
path: root/test
diff options
context:
space:
mode:
Diffstat (limited to 'test')
-rw-r--r--test/.distdep46
-rw-r--r--test/Makefile.in5
-rw-r--r--test/big.c243
3 files changed, 215 insertions, 79 deletions
diff --git a/test/.distdep b/test/.distdep
index c348692..36186c3 100644
--- a/test/.distdep
+++ b/test/.distdep
@@ -283,29 +283,6 @@ shtype.o: \
../src/H5Ppublic.h \
../src/H5Zpublic.h \
../src/H5Spublic.h
-big.o: \
- big.c \
- ../src/hdf5.h \
- ../src/H5public.h \
- ../src/H5config.h \
- ../src/H5Ipublic.h \
- ../src/H5Apublic.h \
- ../src/H5ACpublic.h \
- ../src/H5Bpublic.h \
- ../src/H5Dpublic.h \
- ../src/H5Epublic.h \
- ../src/H5Fpublic.h \
- ../src/H5Gpublic.h \
- ../src/H5HGpublic.h \
- ../src/H5HLpublic.h \
- ../src/H5MFpublic.h \
- ../src/H5MMpublic.h \
- ../src/H5Opublic.h \
- ../src/H5Ppublic.h \
- ../src/H5Zpublic.h \
- ../src/H5Spublic.h \
- ../src/H5Tpublic.h \
- ../src/H5private.h
links.o: \
links.c \
../src/hdf5.h \
@@ -470,3 +447,26 @@ dsets.o: \
../src/H5Zpublic.h \
../src/H5Spublic.h \
../src/H5Tpublic.h
+big.o: \
+ big.c \
+ ../src/hdf5.h \
+ ../src/H5public.h \
+ ../src/H5config.h \
+ ../src/H5Ipublic.h \
+ ../src/H5Apublic.h \
+ ../src/H5ACpublic.h \
+ ../src/H5Bpublic.h \
+ ../src/H5Dpublic.h \
+ ../src/H5Epublic.h \
+ ../src/H5Fpublic.h \
+ ../src/H5Gpublic.h \
+ ../src/H5HGpublic.h \
+ ../src/H5HLpublic.h \
+ ../src/H5MFpublic.h \
+ ../src/H5MMpublic.h \
+ ../src/H5Opublic.h \
+ ../src/H5Ppublic.h \
+ ../src/H5Zpublic.h \
+ ../src/H5Spublic.h \
+ ../src/H5Tpublic.h \
+ ../src/H5private.h
diff --git a/test/Makefile.in b/test/Makefile.in
index d3aa02f..7c64e6e 100644
--- a/test/Makefile.in
+++ b/test/Makefile.in
@@ -12,7 +12,7 @@ CPPFLAGS=-I. -I../src @CPPFLAGS@
# These are our main targets. They should be listed in the order to be
# executed, generally most specific tests to least specific tests.
TESTS=testhdf5 gheap hyperslab istore bittests dtypes dsets cmpd_dset extend \
- external shtype links
+ external shtype links big
TIMINGS=iopipe chunk
# Temporary files
@@ -22,7 +22,8 @@ MOSTLYCLEAN=cmpd_dset.h5 dataset.h5 extend.h5 istore.h5 tfile1.h5 tfile2.h5 \
extern_2.raw extern_2b.raw extern_3.raw extern_3b.raw \
extern_4.raw extern_4b.raw iopipe.raw iopipe.h5 gheap0.h5 \
gheap1.h5 gheap2.h5 gheap3.h5 gheap4.h5 shtype0.h5 shtype1.h5 \
- shtype2a.h5 shtype2b.h5 shtype3.h5 links.h5 chunk.h5
+ shtype2a.h5 shtype2b.h5 shtype3.h5 links.h5 chunk.h5 big.data \
+ big[0-9][0-9][0-9][0-9][0-9].h5
# Source and object files for programs... The TEST_SRC list contains all the
# source files and is used for things like dependencies, archiving, etc. The
diff --git a/test/big.c b/test/big.c
index 6dd72bb..c5aadd6 100644
--- a/test/big.c
+++ b/test/big.c
@@ -7,16 +7,21 @@
*/
#include <assert.h>
#include <ctype.h>
+#include <fcntl.h>
#include <hdf5.h>
#include <math.h>
+#include <stdio.h>
#include <stdlib.h>
+#include <sys/stat.h>
#include <H5private.h> /*needed for HDfprintf() */
#define FNAME "big%05d.h5"
+#define DNAME "big.data"
#define WRT_N 50
#define WRT_SIZE 4*1024
#define FAMILY_SIZE 1024*1024*1024
+#define GB8LL ((unsigned long long)8*1024*1024*1024)
static hsize_t
randll (hsize_t limit)
@@ -27,35 +32,97 @@ randll (hsize_t limit)
return acc % limit;
}
+
+/*-------------------------------------------------------------------------
+ * Function: display_error_cb
+ *
+ * Purpose: Displays the error stack after printing "*FAILED*".
+ *
+ * Return: Success: 0
+ *
+ * Failure: -1
+ *
+ * Programmer: Robb Matzke
+ * Wednesday, March 4, 1998
+ *
+ * Modifications:
+ *
+ *-------------------------------------------------------------------------
+ */
+static herr_t
+display_error_cb (void __unused__ *client_data)
+{
+ puts ("*FAILED*");
+ H5Eprint (stdout);
+ return 0;
+}
/*-------------------------------------------------------------------------
- * Function: main
+ * Function: is_sparse
+ *
+ * Purpose: Determines if the file system of the current working
+ * directory supports holes.
+ *
+ * Return: Success: Non-zero if holes are supported; zero
+ * otherwise.
+ *
+ * Failure: zero
+ *
+ * Programmer: Robb Matzke
+ * Wednesday, July 15, 1998
+ *
+ * Modifications:
+ *
+ *-------------------------------------------------------------------------
+ */
+static int
+is_sparse(void)
+{
+ int fd;
+ struct stat sb;
+
+ if ((fd=open("x.h5", O_RDWR|O_TRUNC|O_CREAT, 0666))<0) return 0;
+ if (lseek(fd, 1024*1024, SEEK_SET)!=1024*1024) return 0;
+ if (5!=write(fd, "hello", 5)) return 0;
+ if (stat("x.h5", &sb)<0) return 0;
+ if (unlink("x.h5")<0) return 0;
+ return (sb.st_blocks*512 < (unsigned)sb.st_size);
+}
+
+
+/*-------------------------------------------------------------------------
+ * Function: writer
*
* Purpose: Creates a *big* dataset.
*
- * Return: Success:
+ * Return: Success: 0
*
- * Failure:
+ * Failure: >0
*
* Programmer: Robb Matzke
* Wednesday, April 8, 1998
*
* Modifications:
+ * Robb Matzke, 15 Jul 1998
+ * Addresses are written to the file DNAME instead of stdout.
*
*-------------------------------------------------------------------------
*/
-static void
+static int
writer (int wrt_n)
{
hsize_t size1[4] = {8, 1024, 1024, 1024};
- hsize_t size2[1] = {8589934592LL};
+ hsize_t size2[1] = {GB8LL};
hssize_t hs_start[1];
hsize_t hs_size[1];
hid_t plist, file, space1, space2, mem_space, d1, d2;
int *buf = malloc (sizeof(int) * WRT_SIZE);
int i, j;
+ FILE *out = fopen(DNAME, "w");
+ printf("%-70s", "Writing large dataset");
+
/*
* Make sure that `hsize_t' is large enough to represent the entire data
* space.
@@ -66,39 +133,53 @@ writer (int wrt_n)
* We might be on a machine that has 32-bit files, so create an HDF5 file
* which is a family of files. Each member of the family will be 1GB
*/
- plist = H5Pcreate (H5P_FILE_ACCESS);
- H5Pset_family (plist, FAMILY_SIZE, H5P_DEFAULT);
+ if ((plist = H5Pcreate (H5P_FILE_ACCESS))<0) goto error;
+ if (H5Pset_family (plist, FAMILY_SIZE, H5P_DEFAULT)<0) goto error;
file = H5Fcreate (FNAME, H5F_ACC_TRUNC|H5F_ACC_DEBUG, H5P_DEFAULT, plist);
- H5Pclose (plist);
+ if (file<0) goto error;
+ if (H5Pclose (plist)<0) goto error;
/* Create simple data spaces according to the size specified above. */
- space1 = H5Screate_simple (4, size1, size1);
- space2 = H5Screate_simple (1, size2, size2);
-
+ if ((space1 = H5Screate_simple (4, size1, size1))<0 ||
+ (space2 = H5Screate_simple (1, size2, size2))<0) {
+ goto error;
+ }
+
/* Create the datasets */
- d1 = H5Dcreate (file, "d1", H5T_NATIVE_INT, space1, H5P_DEFAULT);
- d2 = H5Dcreate (file, "d2", H5T_NATIVE_INT, space2, H5P_DEFAULT);
+ if ((d1=H5Dcreate (file, "d1", H5T_NATIVE_INT, space1, H5P_DEFAULT))<0 ||
+ (d2=H5Dcreate (file, "d2", H5T_NATIVE_INT, space2, H5P_DEFAULT))<0) {
+ goto error;
+ }
+
/* Write some things to them randomly */
hs_size[0] = WRT_SIZE;
- mem_space = H5Screate_simple (1, hs_size, hs_size);
+ if ((mem_space = H5Screate_simple (1, hs_size, hs_size))<0) goto error;
for (i=0; i<wrt_n; i++) {
hs_start[0] = randll (size2[0]);
- HDfprintf (stdout, "#%03d 0x%016Hx\n", i, hs_start[0]);
- H5Sselect_hyperslab (space2, H5S_SELECT_SET, hs_start, NULL, hs_size, NULL);
+ HDfprintf (out, "#%03d 0x%016Hx\n", i, hs_start[0]);
+ if (H5Sselect_hyperslab (space2, H5S_SELECT_SET, hs_start, NULL,
+ hs_size, NULL)<0) goto error;
for (j=0; j<WRT_SIZE; j++) {
buf[j] = i+1;
}
- H5Dwrite (d2, H5T_NATIVE_INT, mem_space, space2, H5P_DEFAULT, buf);
+ if (H5Dwrite (d2, H5T_NATIVE_INT, mem_space, space2,
+ H5P_DEFAULT, buf)<0) goto error;
}
- H5Dclose (d1);
- H5Dclose (d2);
- H5Sclose (mem_space);
- H5Sclose (space1);
- H5Sclose (space2);
- H5Fclose (file);
+ if (H5Dclose (d1)<0) goto error;
+ if (H5Dclose (d2)<0) goto error;
+ if (H5Sclose (mem_space)<0) goto error;
+ if (H5Sclose (space1)<0) goto error;
+ if (H5Sclose (space2)<0) goto error;
+ if (H5Fclose (file)<0) goto error;
free (buf);
+ fclose(out);
+ puts(" PASSED");
+ return 0;
+
+ error:
+ return 1;
}
@@ -107,7 +188,9 @@ writer (int wrt_n)
*
* Purpose: Reads some data from random locations in the dataset.
*
- * Return: void
+ * Return: Success: 0
+ *
+ * Failure: >0
*
* Programmer: Robb Matzke
* Friday, April 10, 1998
@@ -116,43 +199,48 @@ writer (int wrt_n)
*
*-------------------------------------------------------------------------
*/
-static void
-reader (const char *script_name)
+static int
+reader (void)
{
FILE *script;
hid_t plist, file, mspace, fspace, d2;
- char ln[64], *s;
+ char ln[128], *s;
hssize_t hs_offset[1];
hsize_t hs_size[1] = {WRT_SIZE};
int *buf = malloc (sizeof(int) * WRT_SIZE);
- int i, j, zero, wrong;
+ int i, j, zero, wrong, nerrors=0;
/* Open script file */
- script = fopen (script_name, "r");
+ script = fopen (DNAME, "r");
/* Open HDF5 file */
- plist = H5Pcreate (H5P_FILE_ACCESS);
- H5Pset_family (plist, FAMILY_SIZE, H5P_DEFAULT);
- file = H5Fopen (FNAME, H5F_ACC_RDONLY|H5F_ACC_DEBUG, plist);
- H5Pclose (plist);
+ if ((plist = H5Pcreate (H5P_FILE_ACCESS))<0) goto error;
+ if (H5Pset_family (plist, FAMILY_SIZE, H5P_DEFAULT)<0) goto error;
+ if ((file = H5Fopen (FNAME, H5F_ACC_RDONLY|H5F_ACC_DEBUG, plist))<0) {
+ goto error;
+ }
+ if (H5Pclose (plist)<0) goto error;
/* Open the dataset */
- d2 = H5Dopen (file, "d2");
- fspace = H5Dget_space (d2);
+ if ((d2 = H5Dopen (file, "d2"))<0) goto error;
+ if ((fspace = H5Dget_space (d2))<0) goto error;
/* Describe `buf' */
- mspace = H5Screate_simple (1, hs_size, hs_size);
+ if ((mspace = H5Screate_simple (1, hs_size, hs_size))<0) goto error;
/* Read each region */
while (fgets (ln, sizeof(ln), script)) {
if ('#'!=ln[0]) break;
i = (int)strtol (ln+1, &s, 10);
hs_offset[0] = HDstrtoll (s, NULL, 0);
- HDfprintf (stdout, "#%03d 0x%016Hx", i, hs_offset[0]);
+ HDfprintf (stdout, "#%03d 0x%016Hx%47s", i, hs_offset[0], "");
fflush (stdout);
- H5Sselect_hyperslab (fspace, H5S_SELECT_SET, hs_offset, NULL, hs_size, NULL);
- H5Dread (d2, H5T_NATIVE_INT, mspace, fspace, H5P_DEFAULT, buf);
+ if (H5Sselect_hyperslab (fspace, H5S_SELECT_SET, hs_offset, NULL,
+ hs_size, NULL)<0) goto error;
+ if (H5Dread (d2, H5T_NATIVE_INT, mspace, fspace, H5P_DEFAULT, buf)<0) {
+ goto error;
+ }
/* Check */
for (j=zero=wrong=0; j<WRT_SIZE; j++) {
@@ -160,20 +248,57 @@ reader (const char *script_name)
else if (buf[j]!=i+1) wrong++;
}
if (zero) {
- printf (" *FAILED* (%d zeros)\n", zero);
+ puts("*FAILED*");
+ printf(" %d zero%s\n", zero, 1==zero?"":"s");
} else if (wrong) {
- printf (" *SKIPPED* (possible overlap with another region)\n");
+ puts("--SKIP--");
+ puts(" Possible overlap with another region.");
+ nerrors++;
} else {
- printf (" PASSED\n");
+ puts(" PASSED");
}
}
- H5Dclose (d2);
- H5Sclose (mspace);
- H5Sclose (fspace);
- H5Fclose (file);
+ if (H5Dclose (d2)<0) goto error;
+ if (H5Sclose (mspace)<0) goto error;
+ if (H5Sclose (fspace)<0) goto error;
+ if (H5Fclose (file)<0) goto error;
free (buf);
fclose (script);
+ return nerrors;
+
+ error:
+ return 1;
+}
+
+
+/*-------------------------------------------------------------------------
+ * Function: cleanup
+ *
+ * Purpose: Removes test files
+ *
+ * Return: void
+ *
+ * Programmer: Robb Matzke
+ * Thursday, June 4, 1998
+ *
+ * Modifications:
+ *
+ *-------------------------------------------------------------------------
+ */
+static void
+cleanup (void)
+{
+ int i;
+ char buf[256];
+
+ if (!getenv ("HDF5_NOCLEANUP")) {
+ for (i=0; i<512; i++) {
+ sprintf(buf, FNAME, i);
+ remove(buf);
+ }
+ remove(DNAME);
+ }
}
@@ -194,14 +319,24 @@ reader (const char *script_name)
*-------------------------------------------------------------------------
*/
int
-main (int argc, char *argv[])
+main (void)
{
- if (1==argc) {
- writer (WRT_N);
- } else if (isdigit (argv[1][0])) {
- writer ((int)strtol(argv[1], NULL, 0));
- } else {
- reader (argv[1]);
+ int nerrors = 0;
+
+ /*
+ * We shouldn't run this test if the file system doesn't support holes
+ * because we would generate multi-gigabyte files.
+ */
+ if (!is_sparse()) {
+ puts("Test skipped because file system does not support holes.");
+ exit(0);
}
- return 0;
+
+ /* Set the error handler */
+ H5Eset_auto (display_error_cb, NULL);
+
+ if ((nerrors=writer(WRT_N))>0) exit(nerrors);
+ nerrors = reader();
+ cleanup();
+ return nerrors;
}