You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
256 lines
9.2 KiB
256 lines
9.2 KiB
2 years ago
|
/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
|
||
|
* Copyright by The HDF Group. *
|
||
|
* 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://www.hdfgroup.org/licenses. *
|
||
|
* If you do not have access to either file, you may request a copy from *
|
||
|
* help@hdfgroup.org. *
|
||
|
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
|
||
|
|
||
|
/*****************************************************************************
|
||
|
FILE
|
||
|
util.cpp - Utility routines for HDF5 C++ tests.
|
||
|
|
||
|
EXTERNAL ROUTINES/VARIABLES:
|
||
|
|
||
|
***************************************************************************/
|
||
|
|
||
|
#include <iostream>
|
||
|
using std::cerr;
|
||
|
using std::endl;
|
||
|
|
||
|
#include <string>
|
||
|
#include "H5Cpp.h" // C++ API header file
|
||
|
using namespace H5;
|
||
|
|
||
|
#include "h5test.h"
|
||
|
#include "h5cpputil.h" // C++ utilility header file
|
||
|
|
||
|
/*-------------------------------------------------------------------------
|
||
|
* Function: test_report
|
||
|
*
|
||
|
* Purpose Prints out the number of errors for the tests indicated
|
||
|
* by 'testname,' if there were any failures occurred. If
|
||
|
* no failure, test_report prints out the tests passed message.
|
||
|
*
|
||
|
* Return if any failure has occurred: 1
|
||
|
*
|
||
|
* if no failure occurs: 0
|
||
|
*
|
||
|
* Programmer Binh-Minh Ribler (using C code segment for reporting tests)
|
||
|
* Friday, February 6, 2001
|
||
|
*-------------------------------------------------------------------------
|
||
|
*/
|
||
|
int
|
||
|
test_report(int nerrors, const H5std_string &testname)
|
||
|
{
|
||
|
if (nerrors) {
|
||
|
nerrors = MAX(1, nerrors);
|
||
|
if (1 == nerrors)
|
||
|
cerr << "***** " << nerrors << testname << " TEST FAILED! *****" << endl;
|
||
|
else
|
||
|
cerr << "***** " << nerrors << testname << " TESTS FAILED! *****" << endl;
|
||
|
return 1;
|
||
|
}
|
||
|
else {
|
||
|
cerr << "All" << testname << " tests passed." << endl;
|
||
|
return 0;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
/*-------------------------------------------------------------------------
|
||
|
* Function: issue_fail_msg
|
||
|
*
|
||
|
* Purpose Displays that a function has failed with its location.
|
||
|
*
|
||
|
* Return None
|
||
|
*
|
||
|
* Programmer Binh-Minh Ribler (copied and modified macro CHECK from C)
|
||
|
* Monday, December 20, 2004
|
||
|
*
|
||
|
*-------------------------------------------------------------------------
|
||
|
*/
|
||
|
void
|
||
|
issue_fail_msg(const char *where, int line, const char *file_name, const char *message)
|
||
|
{
|
||
|
if (GetTestVerbosity() >= VERBO_HI) {
|
||
|
cerr << endl;
|
||
|
cerr << ">>> FAILED in " << where << " at line " << line << " in " << file_name << " - " << message
|
||
|
<< endl
|
||
|
<< endl;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
/*-------------------------------------------------------------------------
|
||
|
* Function: issue_fail_msg
|
||
|
*
|
||
|
* Purpose Displays that a function has failed with its location.
|
||
|
*
|
||
|
* Return None
|
||
|
*
|
||
|
* Programmer Binh-Minh Ribler (copied and modified macro CHECK from C)
|
||
|
* Monday, December 20, 2004
|
||
|
*
|
||
|
*-------------------------------------------------------------------------
|
||
|
*/
|
||
|
void
|
||
|
issue_fail_msg(const char *where, int line, const char *file_name, const char *func_name, const char *message)
|
||
|
{
|
||
|
if (GetTestVerbosity() >= VERBO_HI) {
|
||
|
cerr << endl;
|
||
|
cerr << ">>> FAILED in " << where << ": " << func_name << endl
|
||
|
<< " at line " << line << " in " << file_name << endl
|
||
|
<< " C library detail: " << message << endl
|
||
|
<< endl;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
/*-------------------------------------------------------------------------
|
||
|
* Function: check_values
|
||
|
*
|
||
|
* Purpose Checks a read value against the written value. If they are
|
||
|
* different, the function will print out a message and the
|
||
|
* different values. This function is made to reuse the code
|
||
|
* segment that is used in various places throughout
|
||
|
* the test code. Where the C version of this code segment
|
||
|
* "goto error," this function will return -1.
|
||
|
*
|
||
|
* Return Success: 0
|
||
|
*
|
||
|
* Failure: -1
|
||
|
*
|
||
|
* Programmer Binh-Minh Ribler (using C code segment for checking values)
|
||
|
* Friday, February 6, 2001
|
||
|
*-------------------------------------------------------------------------
|
||
|
*/
|
||
|
int
|
||
|
check_values(hsize_t i, hsize_t j, int apoint, int acheck)
|
||
|
{
|
||
|
if (apoint != acheck) {
|
||
|
cerr << " Read different values than written.\n" << endl;
|
||
|
cerr << " At index " << static_cast<unsigned long>(i) << "," << static_cast<unsigned long>(j)
|
||
|
<< endl;
|
||
|
return -1;
|
||
|
}
|
||
|
return 0;
|
||
|
} // check_values
|
||
|
|
||
|
/*-------------------------------------------------------------------------
|
||
|
* Function: check_values
|
||
|
*
|
||
|
* Purpose Checks a char string pointer for NULL. If it is NULL,
|
||
|
* the function will print out a message
|
||
|
*
|
||
|
* Return Success: 0
|
||
|
*
|
||
|
* Failure: -1
|
||
|
*
|
||
|
* Programmer Binh-Minh Ribler (using C code segment for checking values)
|
||
|
* Friday, September 16, 2016
|
||
|
*
|
||
|
*-------------------------------------------------------------------------
|
||
|
*/
|
||
|
void
|
||
|
check_values(const char *value, const char *msg, int line, const char *file_name)
|
||
|
{
|
||
|
if (value == NULL) {
|
||
|
cerr << endl;
|
||
|
cerr << "*** ERROR: " << msg << ", at line " << line << endl;
|
||
|
IncTestNumErrs();
|
||
|
throw TestFailedException(file_name, msg);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
/*-------------------------------------------------------------------------
|
||
|
* Function: verify_val (const char*, const char*,...)
|
||
|
*
|
||
|
* Purpose Compares two character strings. If they are
|
||
|
* different, the function will print out a message and the
|
||
|
* different values.
|
||
|
*
|
||
|
* Return Success: 0
|
||
|
*
|
||
|
* Failure: -1
|
||
|
*
|
||
|
* Programmer Binh-Minh Ribler
|
||
|
* May 2, 2010
|
||
|
*-------------------------------------------------------------------------
|
||
|
*/
|
||
|
void
|
||
|
verify_val(const char *x, const char *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 (strcmp(x, value) != 0) {
|
||
|
cerr << endl;
|
||
|
cerr << "*** UNEXPECTED VALUE from " << where << " should be " << value << ", but is " << x
|
||
|
<< " at line " << line << " in " << file_name << endl;
|
||
|
// IncTestNumErrs();
|
||
|
throw TestFailedException(where, "");
|
||
|
}
|
||
|
}
|
||
|
|
||
|
//--------------------------------------------------------------------------
|
||
|
// Function: InvalidActionException default constructor
|
||
|
//--------------------------------------------------------------------------
|
||
|
InvalidActionException::InvalidActionException() : Exception()
|
||
|
{
|
||
|
}
|
||
|
|
||
|
//--------------------------------------------------------------------------
|
||
|
// Function: InvalidActionException overloaded constructor
|
||
|
//
|
||
|
// Purpose Creates an InvalidActionException with the name of the function,
|
||
|
// which the failure should have occurred but didn't, and a
|
||
|
// message explaining why it should fail.
|
||
|
// Parameters
|
||
|
// func - IN: Name of the function where failure should occur
|
||
|
// message - IN: Message
|
||
|
//--------------------------------------------------------------------------
|
||
|
InvalidActionException::InvalidActionException(const H5std_string &func, const H5std_string &message)
|
||
|
: Exception(func, message)
|
||
|
{
|
||
|
}
|
||
|
|
||
|
//--------------------------------------------------------------------------
|
||
|
// Function: InvalidActionException destructor
|
||
|
//--------------------------------------------------------------------------
|
||
|
InvalidActionException::~InvalidActionException() throw()
|
||
|
{
|
||
|
}
|
||
|
|
||
|
//--------------------------------------------------------------------------
|
||
|
// Function: TestFailedException default constructor
|
||
|
//--------------------------------------------------------------------------
|
||
|
TestFailedException::TestFailedException() : Exception()
|
||
|
{
|
||
|
}
|
||
|
|
||
|
//--------------------------------------------------------------------------
|
||
|
// Function: TestFailedException overloaded constructor
|
||
|
//
|
||
|
// Purpose Creates an TestFailedException with the name of the function,
|
||
|
// which the failure should have occurred but didn't, and a
|
||
|
// message explaining why it should fail.
|
||
|
// Parameters
|
||
|
// func - IN: Name of the function where failure should occur
|
||
|
// message - IN: Message
|
||
|
//--------------------------------------------------------------------------
|
||
|
TestFailedException::TestFailedException(const H5std_string &func, const H5std_string &message)
|
||
|
: Exception(func, message)
|
||
|
{
|
||
|
}
|
||
|
|
||
|
//--------------------------------------------------------------------------
|
||
|
// Function: TestFailedException destructor
|
||
|
//--------------------------------------------------------------------------
|
||
|
TestFailedException::~TestFailedException() throw()
|
||
|
{
|
||
|
}
|