summaryrefslogtreecommitdiffstats
path: root/test
diff options
context:
space:
mode:
authorRobb Matzke <matzke@llnl.gov>1998-06-05 03:35:31 (GMT)
committerRobb Matzke <matzke@llnl.gov>1998-06-05 03:35:31 (GMT)
commita63ccc0c6b02c232744a35ed6fbb8c3708f7a3aa (patch)
treeb7002279b63d901703df372a765d07e8619c3457 /test
parent15f2fb818498d5c1c377041493382a29e0d71a45 (diff)
downloadhdf5-a63ccc0c6b02c232744a35ed6fbb8c3708f7a3aa.zip
hdf5-a63ccc0c6b02c232744a35ed6fbb8c3708f7a3aa.tar.gz
hdf5-a63ccc0c6b02c232744a35ed6fbb8c3708f7a3aa.tar.bz2
[svn-r409] Changes since 19980604
---------------------- ./html/Datatypes.html Updated documentation for named data types and type sharing. ./src/H5Farray.c Split a couple long lines. ./src/H5T.c The H5T_copy() demotes immutable types to read-only types so they're cleaned up properly and memory is not leaked. ./test/dtypes.c Modified to be more consistent with other tests. Removed all internal header files, constants, types, and functions calls since the API is now complete enough to test everything. Temporary files are now removed.
Diffstat (limited to 'test')
-rw-r--r--test/.distdep149
-rw-r--r--test/dtypes.c239
2 files changed, 182 insertions, 206 deletions
diff --git a/test/.distdep b/test/.distdep
index 0e71c56..349d760 100644
--- a/test/.distdep
+++ b/test/.distdep
@@ -157,78 +157,6 @@ th5s.o: \
../src/H5Zpublic.h \
../src/H5Pprivate.h \
../src/H5Ppublic.h
-hyperslab.o: \
- hyperslab.c \
- ../src/H5private.h \
- ../src/H5public.h \
- ../src/H5config.h
-iopipe.o: \
- iopipe.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
-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
-chunk.o: \
- chunk.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
dtypes.o: \
dtypes.c \
../src/hdf5.h \
@@ -250,12 +178,12 @@ dtypes.o: \
../src/H5Ppublic.h \
../src/H5Zpublic.h \
../src/H5Spublic.h \
- ../src/H5Tpublic.h \
- ../src/H5Iprivate.h \
+ ../src/H5Tpublic.h
+hyperslab.o: \
+ hyperslab.c \
../src/H5private.h \
- ../src/H5Tprivate.h \
- ../src/H5Gprivate.h \
- ../src/H5Bprivate.h
+ ../src/H5public.h \
+ ../src/H5config.h
istore.o: \
istore.c \
../src/H5private.h \
@@ -368,6 +296,28 @@ external.o: \
../src/H5Zpublic.h \
../src/H5Spublic.h \
../src/H5Tpublic.h
+iopipe.o: \
+ iopipe.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
gheap.o: \
gheap.c \
../src/H5private.h \
@@ -406,6 +356,29 @@ 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 \
@@ -425,3 +398,25 @@ links.o: \
../src/H5MMpublic.h \
../src/H5Opublic.h \
../src/H5Ppublic.h
+chunk.o: \
+ chunk.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
diff --git a/test/dtypes.c b/test/dtypes.c
index 0ae39b3..88b0d63 100644
--- a/test/dtypes.c
+++ b/test/dtypes.c
@@ -11,29 +11,70 @@
#include <stdio.h>
#include <unistd.h>
-#include <H5Iprivate.h>
-#include <H5Tprivate.h>
-
-#ifndef HAVE_FUNCTION
-#undef __FUNCTION__
-#define __FUNCTION__ ""
-#endif
-#define AT() printf (" at %s:%d in %s()...\n", \
- __FILE__, __LINE__, __FUNCTION__);
+#define FILE_NAME_1 "dtypes1.h5"
+#define FILE_NAME_2 "dtypes2.h5"
typedef struct complex_t {
double re;
double im;
} complex_t;
+
+
+/*-------------------------------------------------------------------------
+ * Function: clean
+ *
+ * Purpose: Removes test files
+ *
+ * Return: void
+ *
+ * Programmer: Robb Matzke
+ * Thursday, June 4, 1998
+ *
+ * Modifications:
+ *
+ *-------------------------------------------------------------------------
+ */
+static void
+clean (void)
+{
+ remove (FILE_NAME_1);
+ remove (FILE_NAME_2);
+}
+
+
+/*-------------------------------------------------------------------------
+ * 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 *client_data)
+{
+ puts ("*FAILED*");
+ H5Eprint (stdout);
+ return 0;
+}
+
/*-------------------------------------------------------------------------
* Function: test_classes
*
* Purpose: Test type classes
*
- * Return: Success: SUCCEED
+ * Return: Success: 0
*
- * Failure: FAIL
+ * Failure: -1
*
* Programmer: Robb Matzke
* Tuesday, December 9, 1997
@@ -45,39 +86,38 @@ typedef struct complex_t {
static herr_t
test_classes(void)
{
+ H5T_class_t tcls;
+
printf("%-70s", "Testing H5Tget_class()");
- if (H5T_INTEGER != H5Tget_class(H5T_NATIVE_INT)) {
+ if ((tcls=H5Tget_class(H5T_NATIVE_INT))<0) goto error;
+ if (H5T_INTEGER!=tcls) {
puts("*FAILED*");
- if (!isatty(1)) {
- AT();
- printf(" Invalid type class for H5T_NATIVE_INT\n");
- }
+ puts(" Invalid type class for H5T_NATIVE_INT");
goto error;
}
- if (H5T_FLOAT != H5Tget_class(H5T_NATIVE_DOUBLE)) {
+ if ((tcls=H5Tget_class(H5T_NATIVE_DOUBLE))<0) goto error;
+ if (H5T_FLOAT!=tcls) {
puts("*FAILED*");
- if (!isatty(1)) {
- AT();
- printf(" Invalid type class for H5T_NATIVE_DOUBLE\n");
- }
+ puts(" Invalid type class for H5T_NATIVE_DOUBLE");
goto error;
}
puts(" PASSED");
- return SUCCEED;
+ return 0;
error:
- return FAIL;
+ return -1;
}
+
/*-------------------------------------------------------------------------
* Function: test_copy
*
* Purpose: Are we able to copy a data type?
*
- * Return: Success: SUCCEED
+ * Return: Success: 0
*
- * Failure: FAIL
+ * Failure: -1
*
* Programmer: Robb Matzke
* Tuesday, December 9, 1997
@@ -90,58 +130,37 @@ static herr_t
test_copy(void)
{
hid_t a_copy;
- herr_t status;
- herr_t (*func)(void*) = NULL;
- void *client_data = NULL;
printf("%-70s", "Testing H5Tcopy()");
- if ((a_copy = H5Tcopy(H5T_NATIVE_SHORT)) < 0) {
- puts("*FAILED*");
- if (!isatty(1)) {
- AT();
- printf(" Cannot copy a builtin type.\n");
- }
- goto error;
- }
- if (H5Tclose(a_copy) < 0) {
- puts("*FAILED*");
- if (!isatty(1)) {
- AT();
- printf(" Cannot close the copied type.\n");
- }
- goto error;
- }
+ if ((a_copy = H5Tcopy(H5T_NATIVE_SHORT)) < 0) goto error;
+ if (H5Tclose(a_copy) < 0) goto error;
- /* Temporarily turn off error reporting. */
- H5Eget_auto (&func, &client_data);
- H5Eset_auto (NULL, NULL);
- status = H5Tclose (H5T_NATIVE_CHAR);
- H5Eset_auto (func, client_data);
+ /* We should not be able to close a built-in byte */
+ H5E_BEGIN_TRY {
+ if (H5Tclose (H5T_NATIVE_CHAR)>=0) {
+ puts ("*FAILED*");
+ puts (" Should not be able to close a predefined type!");
+ goto error;
+ }
+ } H5E_END_TRY;
- if (status >= 0) {
- puts("*FAILED*");
- if (!isatty(1)) {
- AT();
- printf(" Was able to free a built-in type.\n");
- }
- goto error;
- }
puts(" PASSED");
- return SUCCEED;
+ return 0;
error:
- return FAIL;
+ return -1;
}
+
/*-------------------------------------------------------------------------
* Function: test_compound
*
* Purpose: Tests various things about compound data types.
*
- * Return: Success: SUCCEED
+ * Return: Success: 0
*
- * Failure: FAIL
+ * Failure: -1
*
* Programmer: Robb Matzke
* Wednesday, January 7, 1998
@@ -155,53 +174,24 @@ test_compound(void)
{
complex_t tmp;
hid_t complex_id;
- herr_t status;
printf("%-70s", "Testing compound data types");
/* Create the empty type */
- complex_id = H5Tcreate(H5T_COMPOUND, sizeof tmp);
- if (complex_id < 0) {
- puts("*FAILED*");
- if (!isatty(1)) {
- AT();
- printf(" Cannot create empty compound data type.\n");
- }
- goto error;
- }
+ if ((complex_id = H5Tcreate(H5T_COMPOUND, sizeof tmp))<0) goto error;
+
/* Add a couple fields */
- status = H5Tinsert(complex_id, "real", HOFFSET(complex_t, re),
- H5T_NATIVE_DOUBLE);
- if (status < 0) {
- puts("*FAILED*");
- if (!isatty(1)) {
- AT();
- printf(" Cannot insert real component.\n");
- }
- goto error;
- }
- status = H5Tinsert(complex_id, "imaginary", HOFFSET(complex_t, im),
- H5T_NATIVE_DOUBLE);
- if (status < 0) {
- puts("*FAILED*");
- if (!isatty(1)) {
- AT();
- printf(" Cannot insert imaginary component.\n");
- }
- goto error;
- }
- puts(" PASSED");
+ if (H5Tinsert(complex_id, "real", HOFFSET(complex_t, re),
+ H5T_NATIVE_DOUBLE)<0) goto error;
+ if (H5Tinsert(complex_id, "imaginary", HOFFSET(complex_t, im),
+ H5T_NATIVE_DOUBLE)<0) goto error;
-#if 0
- /* Just for debugging... */
- H5T_debug(H5I_object(complex_id), stdout);
- printf("\n");
-#endif
-
- return SUCCEED;
+ if (H5Tclose (complex_id)<0) goto error;
+ puts(" PASSED");
+ return 0;
error:
- return FAIL;
+ return -1;
}
@@ -210,9 +200,9 @@ test_compound(void)
*
* Purpose: Tests transient data types.
*
- * Return: Success: SUCCEED
+ * Return: Success: 0
*
- * Failure: FAIL
+ * Failure: -1
*
* Programmer: Robb Matzke
* Thursday, June 4, 1998
@@ -228,7 +218,7 @@ test_transient (void)
hid_t file, type, space, dset, t2;
printf ("%-70s", "Testing transient data types");
- if ((file=H5Fcreate ("dtypes1.h5", H5F_ACC_TRUNC|H5F_ACC_DEBUG,
+ if ((file=H5Fcreate (FILE_NAME_1, H5F_ACC_TRUNC|H5F_ACC_DEBUG,
H5P_DEFAULT, H5P_DEFAULT))<0) goto error;
space = H5Screate_simple (2, ds_size, ds_size);
@@ -298,7 +288,7 @@ test_transient (void)
H5Tclose (type);
H5Sclose (space);
puts (" PASSED");
- return SUCCEED;
+ return 0;
error:
H5E_BEGIN_TRY {
@@ -308,7 +298,7 @@ test_transient (void)
H5Dclose (dset);
H5Fclose (file);
} H5E_END_TRY;
- return FAIL;
+ return -1;
}
@@ -317,9 +307,9 @@ test_transient (void)
*
* Purpose: Tests named data types.
*
- * Return: Success: SUCCEED
+ * Return: Success: 0
*
- * Failure: FAIL
+ * Failure: -1
*
* Programmer: Robb Matzke
* Monday, June 1, 1998
@@ -336,7 +326,7 @@ test_named (void)
static hsize_t ds_size[2] = {100, 200};
printf ("%-70s", "Testing named data types");
- if ((file=H5Fcreate ("dtypes2.h5", H5F_ACC_TRUNC|H5F_ACC_DEBUG,
+ if ((file=H5Fcreate (FILE_NAME_2, H5F_ACC_TRUNC|H5F_ACC_DEBUG,
H5P_DEFAULT, H5P_DEFAULT))<0) goto error;
space = H5Screate_simple (2, ds_size, ds_size);
@@ -468,7 +458,7 @@ test_named (void)
if (H5Sclose (space)<0) goto error;
if (H5Fclose (file)<0) goto error;
puts (" PASSED");
- return SUCCEED;
+ return 0;
error:
H5E_BEGIN_TRY {
@@ -478,7 +468,7 @@ test_named (void)
H5Dclose (dset);
H5Fclose (file);
} H5E_END_TRY;
- return FAIL;
+ return -1;
}
@@ -501,33 +491,24 @@ test_named (void)
int
main(void)
{
- herr_t status;
- intn nerrors = 0;
-
- status = test_classes();
- nerrors += status < 0 ? 1 : 0;
-
- status = test_copy();
- nerrors += status < 0 ? 1 : 0;
-
- status = test_compound();
- nerrors += status < 0 ? 1 : 0;
+ int nerrors = 0;
- status = test_transient ();
- nerrors += status < 0 ? 1 : 0;
+ /* Set the error handler */
+ H5Eset_auto (display_error_cb, NULL);
- status = test_named ();
- nerrors += status < 0 ? 1 : 0;
+ /* Do the tests */
+ nerrors += test_classes()<0 ? 1 : 0;
+ nerrors += test_copy()<0 ? 1 : 0;
+ nerrors += test_compound()<0 ? 1 : 0;
+ nerrors += test_transient ()<0 ? 1 : 0;
+ nerrors += test_named ()<0 ? 1 : 0;
if (nerrors) {
printf("***** %d DATA TYPE TEST%s FAILED! *****\n",
nerrors, 1 == nerrors ? "" : "S");
- if (isatty(1)) {
- printf("(Redirect output to a pager or a file to see debug "
- "output)\n");
- }
exit(1);
}
printf("All data type tests passed.\n");
+ clean ();
return 0;
}