mirror of
https://github.com/HDFGroup/hdf5.git
synced 2025-01-12 15:04:59 +08:00
89fbe00dec
* commit '54957d37f5aa73912763dbb6e308555e863c43f4': Commit copyright header change for src/H5PLpkg.c which was added after running script to make changes. Add new files in release_docs to MANIFEST. Cimmit changes to Makefile.in(s) and H5PL.c that resulted from running autogen.sh. Merge pull request #407 in HDFFV/hdf5 from ~LRKNOX/hdf5_lrk:hdf5_1_10_1 to hdf5_1_10_1 Change copyright headers to replace url referring to file to be removed and replace it with new url for COPYING file.
189 lines
6.0 KiB
C++
189 lines
6.0 KiB
C++
/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
|
|
* Copyright by The HDF Group. *
|
|
* Copyright by the Board of Trustees of the University of Illinois. *
|
|
* All rights reserved. *
|
|
* *
|
|
* This file is part of HDF5. The full HDF5 copyright notice, including *
|
|
* terms governing use, modification, and redistribution, is contained in *
|
|
* the COPYING file, which can be found at the root of the source code *
|
|
* distribution tree, or in https://support.hdfgroup.org/ftp/HDF5/releases. *
|
|
* If you do not have access to either file, you may request a copy from *
|
|
* help@hdfgroup.org. *
|
|
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
|
|
|
|
/*****************************************************************************
|
|
FILE
|
|
h5cpputil.h - Header file of the utilities/misc for HDF5 C++ tests.
|
|
|
|
EXTERNAL ROUTINES/VARIABLES:
|
|
|
|
***************************************************************************/
|
|
|
|
#ifndef _h5cpputil_h
|
|
#define _h5cpputil_h
|
|
|
|
#include "h5test.h"
|
|
|
|
using namespace H5;
|
|
using std::cerr;
|
|
using std::endl;
|
|
|
|
#define MESSAGE(V,A) {if (HDGetTestVerbosity()>(V)) print_func A;}
|
|
#define SUBTEST(TEST) {printf(" Subtest: %-52s",TEST); fflush(stdout);}
|
|
|
|
int check_values (hsize_t i, hsize_t j, int apoint, int acheck);
|
|
void check_values(const char *value, const char* msg, int line, const char* file_name);
|
|
int test_report (int, const H5std_string&);
|
|
void issue_fail_msg(const char* where, int line, const char* file_name,
|
|
const char* message="");
|
|
void issue_fail_msg(const char* where, int line, const char* file_name,
|
|
const char* func_name, const char* message);
|
|
|
|
class InvalidActionException : public Exception {
|
|
public:
|
|
InvalidActionException(const H5std_string func_name, const H5std_string message = DEFAULT_MSG);
|
|
InvalidActionException();
|
|
virtual ~InvalidActionException() throw();
|
|
};
|
|
|
|
class TestFailedException : public Exception {
|
|
public:
|
|
TestFailedException(const H5std_string func_name, const H5std_string message = DEFAULT_MSG);
|
|
TestFailedException();
|
|
virtual ~TestFailedException() throw();
|
|
};
|
|
|
|
// Overloaded/Template functions to verify values and display proper info
|
|
|
|
// Verifies
|
|
void verify_val(const char* x, const char* value, const char* where, int line, const char* file_name);
|
|
|
|
template <class Type1, class Type2>
|
|
void verify_val(Type1 x, Type2 value, const char* where, int line, const char* file_name)
|
|
{
|
|
if (GetTestVerbosity()>=VERBO_HI)
|
|
{
|
|
cerr << endl;
|
|
cerr << " Call to routine: " << where << " at line " << line
|
|
<< " in " << file_name << " had value " << x << endl;
|
|
}
|
|
if (x != value)
|
|
{
|
|
cerr << endl;
|
|
cerr << "*** UNEXPECTED VALUE from " << where << " should be "
|
|
<< value << ", but is " << x << " at line " << line
|
|
<< " in " << file_name << endl;
|
|
IncTestNumErrs();
|
|
throw TestFailedException(where, "");
|
|
}
|
|
}
|
|
|
|
template <class Type1, class Type2>
|
|
void verify_val(Type1 x, Type2 value, const char* msg, const char* file_name, int line)
|
|
{
|
|
if (x != value)
|
|
{
|
|
cerr << endl;
|
|
cerr << "*** UNEXPECTED VALUE: " << file_name << ":line " << line
|
|
<< ": " << msg << " different: " << x << ", should be " << value
|
|
<< endl;
|
|
IncTestNumErrs();
|
|
throw TestFailedException(file_name, msg);
|
|
}
|
|
}
|
|
|
|
template <class Type1, class Type2>
|
|
void verify_val_noteq(Type1 x, Type2 value, const char* where, int line, const char* file_name)
|
|
{
|
|
if (GetTestVerbosity()>=VERBO_HI)
|
|
{
|
|
cerr << endl;
|
|
cerr << " Call to routine: " << where << " at line " << line
|
|
<< " in " << file_name << " had value " << x << endl;
|
|
}
|
|
if (x == value)
|
|
{
|
|
cerr << endl;
|
|
cerr << "*** UNEXPECTED VALUE from " << where << " should not be "
|
|
<< value << " at line " << line << " in " << file_name << endl;
|
|
IncTestNumErrs();
|
|
throw TestFailedException(where, "");
|
|
}
|
|
}
|
|
|
|
template <class Type1, class Type2>
|
|
void CHECK(Type1 x, Type2 value, const char* msg, int line, const char* file_name)
|
|
{
|
|
if (x == value)
|
|
{
|
|
cerr << endl;
|
|
cerr << "*** Function " << msg << " FAILED at line " << line << endl;
|
|
IncTestNumErrs();
|
|
throw TestFailedException(file_name, msg);
|
|
}
|
|
}
|
|
|
|
template <class Type1, class Type2>
|
|
void verify_val(Type1 x, Type2 value, float epsilon, const char* msg, int line, const char* file_name)
|
|
{
|
|
if (x == value)
|
|
{
|
|
cerr << endl;
|
|
cerr << "*** UNEXPECTED FLOAT VALUE: " << file_name << ":line " << line
|
|
<< ": " << msg << " different: " << x << ", should be " << value
|
|
<< " (epsilon=" << epsilon << ")" << endl;
|
|
IncTestNumErrs();
|
|
throw TestFailedException(file_name, msg);
|
|
}
|
|
}
|
|
|
|
/* Prototypes for the test routines */
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
void test_array();
|
|
void test_attr();
|
|
void test_compound();
|
|
void test_dsproplist();
|
|
void test_file();
|
|
void test_filters();
|
|
void test_links();
|
|
void test_h5s();
|
|
void test_iterate();
|
|
void test_object();
|
|
void test_reference();
|
|
void test_types();
|
|
void test_vlstrings();
|
|
void test_dset();
|
|
|
|
/* Prototypes for the cleanup routines */
|
|
void cleanup_array();
|
|
void cleanup_attr();
|
|
void cleanup_compound();
|
|
void cleanup_dsproplist();
|
|
void cleanup_dsets();
|
|
void cleanup_file();
|
|
void cleanup_filters();
|
|
void cleanup_h5s();
|
|
void cleanup_iterate();
|
|
void cleanup_links();
|
|
void cleanup_object();
|
|
void cleanup_reference();
|
|
void cleanup_types();
|
|
void cleanup_vlstrings();
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif
|
|
|
|
/* not yet
|
|
void cleanup_select(void);
|
|
void cleanup_time(void);
|
|
void cleanup_vltypes(void);
|
|
void cleanup_array(void);
|
|
void cleanup_genprop(void);
|
|
void cleanup_misc(void);
|
|
*/
|
|
|
|
#endif
|