]> git.saurik.com Git - apple/icu.git/blobdiff - icuSources/tools/ctestfw/unicode/ctest.h
ICU-57166.0.1.tar.gz
[apple/icu.git] / icuSources / tools / ctestfw / unicode / ctest.h
index 4cb7457af999f9db270b57e5320b37a272624447..f078703d6eafbef8c6fe49d824d64ced833bf811 100644 (file)
@@ -1,7 +1,7 @@
 /*
  ********************************************************************************
  *
 /*
  ********************************************************************************
  *
- *   Copyright (C) 1996-2008, International Business Machines
+ *   Copyright (C) 1996-2013, International Business Machines
  *   Corporation and others.  All Rights Reserved.
  *
  ********************************************************************************
  *   Corporation and others.  All Rights Reserved.
  *
  ********************************************************************************
@@ -23,53 +23,61 @@ typedef struct TestNode TestNode;
 U_CDECL_END
 
 /**
 U_CDECL_END
 
 /**
- * Set this to zero to disable log_verbose() messages.
- * Otherwise nonzero to see log_verbose() messages.
+ * This is use to set or get the option value for REPEAT_TESTS.
+ * Use with set/getTestOption().
  *
  *
- * @internal Internal APIs for testing purpose only
+ * @internal
  */
  */
-extern T_CTEST_EXPORT_API int REPEAT_TESTS;
+#define REPEAT_TESTS_OPTION 1
 
 /**
 
 /**
- * Set this to zero to disable log_verbose() messages.
+ * This is use to set or get the option value for VERBOSITY.
+ * When option is set to zero to disable log_verbose() messages.
  * Otherwise nonzero to see log_verbose() messages.
  * Otherwise nonzero to see log_verbose() messages.
+ * Use with set/getTestOption().
  *
  *
- * @internal Internal APIs for testing purpose only
+ * @internal
  */
  */
-extern T_CTEST_EXPORT_API int VERBOSITY;
+#define VERBOSITY_OPTION 2
 
 /**
 
 /**
- * Set this to zero to disable log_verbose() messages.
- * Otherwise nonzero to see log_verbose() messages.
+ * This is use to set or get the option value for ERR_MSG.
+ * Use with set/getTestOption().
  *
  *
- * @internal Internal APIs for testing purpose only
+ * @internal
  */
  */
-extern T_CTEST_EXPORT_API int ERR_MSG;
+#define ERR_MSG_OPTION 3
 
 /**
 
 /**
- * Set this to zero to disable some of the slower tests.
+ * This is use to set or get the option value for QUICK.
+ * When option is zero, disable some of the slower tests.
  * Otherwise nonzero to run the slower tests.
  * Otherwise nonzero to run the slower tests.
+ * Use with set/getTestOption().
  *
  *
- * @internal Internal APIs for testing purpose only
+ * @internal
  */
  */
-extern T_CTEST_EXPORT_API int QUICK;
+#define QUICK_OPTION 4
 
 /**
 
 /**
- * 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.
+ * This is use to set or get the option value for WARN_ON_MISSING_DATA.
+ * When option is nonzero, warn on missing data.
+ * Otherwise, errors are propagated when data is not available.
  * Affects the behavior of log_dataerr.
  * Affects the behavior of log_dataerr.
+ * Use with set/getTestOption().
  *
  * @see log_data_err
  *
  * @see log_data_err
- * @internal Internal APIs for testing purpose only
+ * @internal
  */
  */
-extern T_CTEST_EXPORT_API int WARN_ON_MISSING_DATA;
+#define WARN_ON_MISSING_DATA_OPTION 5
 
 /**
 
 /**
- * ICU tracing level, is set by command line option
+ * This is use to set or get the option value for ICU_TRACE.
+ * ICU tracing level, is set by command line option.
+ * Use with set/getTestOption().
  *
  * @internal
  */
  *
  * @internal
  */
-extern T_CTEST_EXPORT_API UTraceLevel ICU_TRACE;
+#define ICU_TRACE_OPTION 6
 
 /**
  * Maximum amount of memory uprv_malloc should allocate before returning NULL.
 
 /**
  * Maximum amount of memory uprv_malloc should allocate before returning NULL.
@@ -85,6 +93,32 @@ extern T_CTEST_EXPORT_API size_t MAX_MEMORY_ALLOCATION;
  */
 extern T_CTEST_EXPORT_API int32_t ALLOCATION_COUNT;
 
  */
 extern T_CTEST_EXPORT_API int32_t ALLOCATION_COUNT;
 
+/**
+ * Pass to setTestOption to decrement the test option value.
+ *
+ * @internal
+ */
+#define DECREMENT_OPTION_VALUE -99
+
+/**
+ * Gets the test option set on commandline.
+ *
+ * @param testOption macro definition for the individual test option
+ * @return value of test option, zero if option is not set or off
+ * @internal Internal APIs for testing purpose only
+ */
+T_CTEST_API int32_t T_CTEST_EXPORT2
+getTestOption ( int32_t testOption );
+
+/**
+ * Sets the test option with value given on commandline.
+ *
+ * @param testOption macro definition for the individual test option
+ * @param value to set the test option to
+ * @internal Internal APIs for testing purpose only
+ */
+T_CTEST_API void T_CTEST_EXPORT2
+setTestOption ( int32_t testOption, int32_t value);
 
 /**
  * Show the names of all nodes.
 
 /**
  * Show the names of all nodes.
@@ -151,6 +185,8 @@ getTest(const TestNode* root,
 T_CTEST_API void T_CTEST_EXPORT2
 log_err(const char* pattern, ...);
 
 T_CTEST_API void T_CTEST_EXPORT2
 log_err(const char* pattern, ...);
 
+T_CTEST_API void T_CTEST_EXPORT2
+log_err_status(UErrorCode status, const char* pattern, ...);
 /**
  * Log an informational message. (printf style)
  * @param pattern printf-style format string
 /**
  * Log an informational message. (printf style)
  * @param pattern printf-style format string
@@ -188,6 +224,16 @@ log_verbose(const char* pattern, ...);
 T_CTEST_API void T_CTEST_EXPORT2
 log_data_err(const char *pattern, ...);
 
 T_CTEST_API void T_CTEST_EXPORT2
 log_data_err(const char *pattern, ...);
 
+/**
+ * Log a known issue.
+ * @param ticket ticket number such as "12345" for ICU tickets or "cldrbug:6636" for CLDR tickets.
+ * @param fmt ...  sprintf-style format, optional message. can be NULL.
+ * @return TRUE if known issue test should be skipped, FALSE if it should be run
+ */
+T_CTEST_API UBool
+T_CTEST_EXPORT2
+log_knownIssue(const char *ticket, const char *fmt, ...);
+
 /**
  * Initialize the variables above. This allows the test to set up accordingly
  * before running the tests.
 /**
  * Initialize the variables above. This allows the test to set up accordingly
  * before running the tests.
@@ -218,6 +264,49 @@ runTestRequest(const TestNode* root,
 T_CTEST_API const char* T_CTEST_EXPORT2
 getTestName(void);
 
 T_CTEST_API const char* T_CTEST_EXPORT2
 getTestName(void);
 
+/**
+ * Append a time delta to str if it is significant (>5 ms) otherwise no change
+ * @param delta a delta in millis
+ * @param str a string to append to.
+ */
+T_CTEST_API void T_CTEST_EXPORT2
+str_timeDelta(char *str, UDate delta);
+
 
 
+/* ======== XML (JUnit output) ========= */
+
+/**
+ * Set the filename for the XML output. 
+ * @param fileName file name. Caller must retain storage.
+ * @return 0 on success, 1 on failure.
+ */
+T_CTEST_API int32_t T_CTEST_EXPORT2
+ctest_xml_setFileName(const char *fileName);
+
+
+/**
+ * Init XML subsystem. Call ctest_xml_setFileName first
+ * @param rootName the test root name to be written
+ * @return 0 on success, 1 on failure.
+ */
+T_CTEST_API int32_t T_CTEST_EXPORT2
+ctest_xml_init(const char *rootName);
+
+
+/**
+ * Set the filename for the XML output. Caller must retain storage.
+ * @return 0 on success, 1 on failure.
+ */
+T_CTEST_API int32_t T_CTEST_EXPORT2
+ctest_xml_fini(void);
+
+
+/**
+ * report a test case
+ * @return 0 on success, 1 on failure.
+ */
+T_CTEST_API int32_t
+T_CTEST_EXPORT2
+ctest_xml_testcase(const char *classname, const char *name, const char *time, const char *failMsg);
 
 #endif
 
 #endif