2001-03-21 23:22:16 +00:00
|
|
|
/*
|
2004-06-04 16:56:12 +00:00
|
|
|
********************************************************************************
|
2000-01-18 02:12:32 +00:00
|
|
|
*
|
2004-03-23 06:37:36 +00:00
|
|
|
* Copyright (C) 1996-2004, International Business Machines
|
2000-01-18 02:12:32 +00:00
|
|
|
* Corporation and others. All Rights Reserved.
|
|
|
|
*
|
2004-06-04 16:56:12 +00:00
|
|
|
********************************************************************************
|
2000-01-18 02:12:32 +00:00
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef CTEST_H
|
|
|
|
#define CTEST_H
|
|
|
|
|
2004-03-23 06:37:36 +00:00
|
|
|
#include "unicode/testtype.h"
|
2003-09-20 01:21:23 +00:00
|
|
|
#include "unicode/utrace.h"
|
2000-01-18 02:12:32 +00:00
|
|
|
|
|
|
|
|
|
|
|
/* prototypes *********************************/
|
|
|
|
|
2004-06-04 16:56:12 +00:00
|
|
|
U_CDECL_BEGIN
|
2004-06-04 17:11:09 +00:00
|
|
|
typedef void (U_CALLCONV *TestFunctionPtr)(void);
|
2000-01-18 02:12:32 +00:00
|
|
|
typedef struct TestNode TestNode;
|
2004-06-04 16:56:12 +00:00
|
|
|
U_CDECL_END
|
2000-01-18 02:12:32 +00:00
|
|
|
|
|
|
|
/**
|
2002-01-16 04:33:33 +00:00
|
|
|
* Set this to zero to disable log_verbose() messages.
|
|
|
|
* Otherwise nonzero to see log_verbose() messages.
|
|
|
|
*
|
2000-05-30 21:11:39 +00:00
|
|
|
* @internal Internal APIs for testing purpose only
|
2000-01-18 02:12:32 +00:00
|
|
|
*/
|
2004-05-19 06:13:31 +00:00
|
|
|
extern T_CTEST_EXPORT_API int REPEAT_TESTS;
|
2000-01-18 02:12:32 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Set this to zero to disable log_verbose() messages.
|
|
|
|
* Otherwise nonzero to see log_verbose() messages.
|
|
|
|
*
|
2002-01-16 04:33:33 +00:00
|
|
|
* @internal Internal APIs for testing purpose only
|
2000-01-18 02:12:32 +00:00
|
|
|
*/
|
2004-05-19 06:13:31 +00:00
|
|
|
extern T_CTEST_EXPORT_API int VERBOSITY;
|
2000-01-18 02:12:32 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Set this to zero to disable log_verbose() messages.
|
|
|
|
* Otherwise nonzero to see log_verbose() messages.
|
|
|
|
*
|
2002-01-16 04:33:33 +00:00
|
|
|
* @internal Internal APIs for testing purpose only
|
2000-01-18 02:12:32 +00:00
|
|
|
*/
|
2004-05-19 06:13:31 +00:00
|
|
|
extern T_CTEST_EXPORT_API int ERR_MSG;
|
2000-01-18 02:12:32 +00:00
|
|
|
|
2002-01-16 04:33:33 +00:00
|
|
|
/**
|
|
|
|
* Set this to zero to disable some of the slower tests.
|
|
|
|
* Otherwise nonzero to run the slower tests.
|
|
|
|
*
|
|
|
|
* @internal Internal APIs for testing purpose only
|
|
|
|
*/
|
2004-05-19 06:13:31 +00:00
|
|
|
extern T_CTEST_EXPORT_API int QUICK;
|
2002-01-16 04:33:33 +00:00
|
|
|
|
2002-09-17 19:45:03 +00:00
|
|
|
/**
|
|
|
|
* Set this to nonzero to warn (not error) on missing data.
|
|
|
|
* Otherwise, zero will cause an error to be propagated when data is not available.
|
|
|
|
* Affects the behavior of log_dataerr.
|
|
|
|
*
|
|
|
|
* @see log_data_err
|
|
|
|
* @internal Internal APIs for testing purpose only
|
|
|
|
*/
|
2004-05-19 06:13:31 +00:00
|
|
|
extern T_CTEST_EXPORT_API int WARN_ON_MISSING_DATA;
|
2002-09-17 19:45:03 +00:00
|
|
|
|
2003-09-20 01:21:23 +00:00
|
|
|
/**
|
|
|
|
* ICU tracing level, is set by command line option
|
|
|
|
*
|
|
|
|
* @internal
|
|
|
|
*/
|
2004-05-19 06:13:31 +00:00
|
|
|
extern T_CTEST_EXPORT_API UTraceLevel ICU_TRACE;
|
2003-09-20 01:21:23 +00:00
|
|
|
|
2000-01-18 02:12:32 +00:00
|
|
|
/**
|
|
|
|
* Show the names of all nodes.
|
2001-03-21 23:22:16 +00:00
|
|
|
*
|
2000-01-18 02:12:32 +00:00
|
|
|
* @param root Subtree of tests.
|
2000-05-30 21:11:39 +00:00
|
|
|
* @internal Internal APIs for testing purpose only
|
2000-01-18 02:12:32 +00:00
|
|
|
*/
|
2004-07-16 15:05:14 +00:00
|
|
|
T_CTEST_API void T_CTEST_EXPORT2
|
|
|
|
showTests ( const TestNode *root);
|
2000-01-18 02:12:32 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Run a subtree of tests.
|
2001-03-21 23:22:16 +00:00
|
|
|
*
|
2000-01-18 02:12:32 +00:00
|
|
|
* @param root Subtree of tests.
|
2000-05-30 21:11:39 +00:00
|
|
|
* @internal Internal APIs for testing purpose only
|
2000-01-18 02:12:32 +00:00
|
|
|
*/
|
2004-07-16 15:05:14 +00:00
|
|
|
T_CTEST_API void T_CTEST_EXPORT2
|
|
|
|
runTests ( const TestNode* root);
|
2000-01-18 02:12:32 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Add a test to the subtree.
|
|
|
|
* Example usage:
|
|
|
|
* <PRE>
|
|
|
|
* TestNode* root=NULL;
|
|
|
|
* addTest(&root, &mytest, "/a/b/mytest" );
|
|
|
|
* </PRE>
|
|
|
|
* @param root Pointer to the root pointer.
|
|
|
|
* @param test Pointer to 'void function(void)' for actual test.
|
|
|
|
* @param path Path from root under which test will be placed. Ex. '/a/b/mytest'
|
2000-05-30 21:11:39 +00:00
|
|
|
* @internal Internal APIs for testing purpose only
|
2000-01-18 02:12:32 +00:00
|
|
|
*/
|
2004-07-16 15:05:14 +00:00
|
|
|
T_CTEST_API void T_CTEST_EXPORT2
|
|
|
|
addTest(TestNode** root,
|
|
|
|
TestFunctionPtr test,
|
|
|
|
const char *path);
|
2000-01-18 02:12:32 +00:00
|
|
|
|
2004-07-16 15:05:14 +00:00
|
|
|
/**
|
|
|
|
* Clean up any allocated memory.
|
|
|
|
* Conditions for calling this function are the same as u_cleanup().
|
|
|
|
* @see u_cleanup
|
|
|
|
* @internal Internal APIs for testing purpose only
|
|
|
|
*/
|
|
|
|
T_CTEST_API void T_CTEST_EXPORT2
|
|
|
|
cleanUpTestTree(TestNode *tn);
|
2000-07-06 23:01:50 +00:00
|
|
|
|
2000-01-18 02:12:32 +00:00
|
|
|
/**
|
|
|
|
* Retreive a specific subtest. (subtree).
|
|
|
|
*
|
|
|
|
* @param root Pointer to the root.
|
|
|
|
* @param path Path relative to the root, Ex. '/a/b'
|
|
|
|
* @return The subtest, or NULL on failure.
|
2000-05-30 21:11:39 +00:00
|
|
|
* @internal Internal APIs for testing purpose only
|
2000-01-18 02:12:32 +00:00
|
|
|
*/
|
2004-07-16 15:05:14 +00:00
|
|
|
T_CTEST_API const TestNode* T_CTEST_EXPORT2
|
|
|
|
getTest(const TestNode* root,
|
|
|
|
const char *path);
|
2000-01-18 02:12:32 +00:00
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Log an error message. (printf style)
|
|
|
|
* @param pattern printf-style format string
|
2000-05-30 21:11:39 +00:00
|
|
|
* @internal Internal APIs for testing purpose only
|
2000-01-18 02:12:32 +00:00
|
|
|
*/
|
2004-07-16 15:05:14 +00:00
|
|
|
T_CTEST_API void T_CTEST_EXPORT2
|
|
|
|
log_err(const char* pattern, ...);
|
2000-01-18 02:12:32 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Log an informational message. (printf style)
|
|
|
|
* @param pattern printf-style format string
|
2000-05-30 21:11:39 +00:00
|
|
|
* @internal Internal APIs for testing purpose only
|
2000-01-18 02:12:32 +00:00
|
|
|
*/
|
2004-07-16 15:05:14 +00:00
|
|
|
T_CTEST_API void T_CTEST_EXPORT2
|
|
|
|
log_info(const char* pattern, ...);
|
2000-01-18 02:12:32 +00:00
|
|
|
|
2003-11-19 01:05:25 +00:00
|
|
|
/**
|
|
|
|
* Log an informational message. (vprintf style)
|
|
|
|
* @param prefix a string that is output before the pattern and without formatting
|
|
|
|
* @param pattern printf-style format string
|
|
|
|
* @param ap variable-arguments list
|
|
|
|
* @internal Internal APIs for testing purpose only
|
|
|
|
*/
|
2004-07-16 15:05:14 +00:00
|
|
|
T_CTEST_API void T_CTEST_EXPORT2
|
|
|
|
vlog_info(const char *prefix, const char *pattern, va_list ap);
|
2003-11-19 01:05:25 +00:00
|
|
|
|
2000-01-18 02:12:32 +00:00
|
|
|
/**
|
|
|
|
* Log a verbose informational message. (printf style)
|
|
|
|
* This message will only appear if the global VERBOSITY is nonzero
|
|
|
|
* @param pattern printf-style format string
|
2000-05-30 21:11:39 +00:00
|
|
|
* @internal Internal APIs for testing purpose only
|
2000-01-18 02:12:32 +00:00
|
|
|
*/
|
2004-07-16 15:05:14 +00:00
|
|
|
T_CTEST_API void T_CTEST_EXPORT2
|
|
|
|
log_verbose(const char* pattern, ...);
|
2000-01-18 02:12:32 +00:00
|
|
|
|
2002-09-17 19:45:03 +00:00
|
|
|
/**
|
|
|
|
* Log an error message concerning missing data. (printf style)
|
|
|
|
* If WARN_ON_MISSING_DATA is nonzero, this will case a log_info (warning) to be
|
|
|
|
* printed, but if it is zero this will produce an error (log_err).
|
|
|
|
* @param pattern printf-style format string
|
|
|
|
* @internal Internal APIs for testing purpose only
|
|
|
|
*/
|
2004-07-16 15:05:14 +00:00
|
|
|
T_CTEST_API void T_CTEST_EXPORT2
|
|
|
|
log_data_err(const char *pattern, ...);
|
2002-09-17 19:45:03 +00:00
|
|
|
|
2000-01-18 02:12:32 +00:00
|
|
|
/**
|
|
|
|
* Processes the command line arguments.
|
|
|
|
* This is a sample implementation
|
|
|
|
* <PRE>Usage: %s [ -l ] [ -v ] [ -? ] [ /path/to/test ]
|
|
|
|
* -l List only, do not run\
|
|
|
|
* -v turn OFF verbosity
|
|
|
|
* -? print this message</PRE>
|
|
|
|
* @param root Testnode root with tests already attached to it
|
|
|
|
* @param argv argument list from main (stdio.h)
|
|
|
|
* @param argc argument list count from main (stdio.h)
|
|
|
|
* @return positive for error count, 0 for success, negative for illegal argument
|
2000-05-30 21:11:39 +00:00
|
|
|
* @internal Internal APIs for testing purpose only
|
2000-01-18 02:12:32 +00:00
|
|
|
*/
|
2004-07-16 15:05:14 +00:00
|
|
|
T_CTEST_API int T_CTEST_EXPORT2
|
|
|
|
processArgs(const TestNode* root,
|
|
|
|
int argc,
|
|
|
|
const char* const argv[]);
|
2000-01-18 02:12:32 +00:00
|
|
|
|
|
|
|
|
2004-07-16 15:05:14 +00:00
|
|
|
T_CTEST_API const char* T_CTEST_EXPORT2
|
|
|
|
getTestName(void);
|
2002-05-02 21:16:33 +00:00
|
|
|
|
2000-01-18 02:12:32 +00:00
|
|
|
|
|
|
|
|
|
|
|
#endif
|