1 // © 2016 and later: Unicode, Inc. and others. 2 // License & terms of use: http://www.unicode.org/copyright.html 3 /* 4 ******************************************************************************** 5 * 6 * Copyright (C) 1996-2013, International Business Machines 7 * Corporation and others. All Rights Reserved. 8 * 9 ******************************************************************************** 10 */ 11 12 #ifndef CTEST_H 13 #define CTEST_H 14 15 #include "unicode/testtype.h" 16 #include "unicode/utrace.h" 17 18 19 /* prototypes *********************************/ 20 21 U_CDECL_BEGIN 22 typedef void (U_CALLCONV *TestFunctionPtr)(void); 23 typedef int (U_CALLCONV *ArgHandlerPtr)(int arg, int argc, const char* const argv[], void *context); 24 typedef struct TestNode TestNode; 25 U_CDECL_END 26 27 /** 28 * This is use to set or get the option value for REPEAT_TESTS. 29 * Use with set/getTestOption(). 30 * 31 * @internal 32 */ 33 #define REPEAT_TESTS_OPTION 1 34 35 /** 36 * This is use to set or get the option value for VERBOSITY. 37 * When option is set to zero to disable log_verbose() messages. 38 * Otherwise nonzero to see log_verbose() messages. 39 * Use with set/getTestOption(). 40 * 41 * @internal 42 */ 43 #define VERBOSITY_OPTION 2 44 45 /** 46 * This is use to set or get the option value for ERR_MSG. 47 * Use with set/getTestOption(). 48 * 49 * @internal 50 */ 51 #define ERR_MSG_OPTION 3 52 53 /** 54 * This is use to set or get the option value for QUICK. 55 * When option is zero, disable some of the slower tests. 56 * Otherwise nonzero to run the slower tests. 57 * Use with set/getTestOption(). 58 * 59 * @internal 60 */ 61 #define QUICK_OPTION 4 62 63 /** 64 * This is use to set or get the option value for WARN_ON_MISSING_DATA. 65 * When option is nonzero, warn on missing data. 66 * Otherwise, errors are propagated when data is not available. 67 * Affects the behavior of log_dataerr. 68 * Use with set/getTestOption(). 69 * 70 * @see log_data_err 71 * @internal 72 */ 73 #define WARN_ON_MISSING_DATA_OPTION 5 74 75 /** 76 * This is use to set or get the option value for ICU_TRACE. 77 * ICU tracing level, is set by command line option. 78 * Use with set/getTestOption(). 79 * 80 * @internal 81 */ 82 #define ICU_TRACE_OPTION 6 83 84 /** 85 * Maximum amount of memory uprv_malloc should allocate before returning NULL. 86 * 87 * @internal 88 */ 89 extern T_CTEST_EXPORT_API size_t MAX_MEMORY_ALLOCATION; 90 91 /** 92 * If memory tracing was enabled, contains the number of unfreed allocations. 93 * 94 * @internal 95 */ 96 extern T_CTEST_EXPORT_API int32_t ALLOCATION_COUNT; 97 98 /** 99 * Pass to setTestOption to decrement the test option value. 100 * 101 * @internal 102 */ 103 #define DECREMENT_OPTION_VALUE -99 104 105 /** 106 * Gets the test option set on commandline. 107 * 108 * @param testOption macro definition for the individual test option 109 * @return value of test option, zero if option is not set or off 110 * @internal Internal APIs for testing purpose only 111 */ 112 T_CTEST_API int32_t T_CTEST_EXPORT2 113 getTestOption ( int32_t testOption ); 114 115 /** 116 * Sets the test option with value given on commandline. 117 * 118 * @param testOption macro definition for the individual test option 119 * @param value to set the test option to 120 * @internal Internal APIs for testing purpose only 121 */ 122 T_CTEST_API void T_CTEST_EXPORT2 123 setTestOption ( int32_t testOption, int32_t value); 124 125 /** 126 * Show the names of all nodes. 127 * 128 * @param root Subtree of tests. 129 * @internal Internal APIs for testing purpose only 130 */ 131 T_CTEST_API void T_CTEST_EXPORT2 132 showTests ( const TestNode *root); 133 134 /** 135 * Run a subtree of tests. 136 * 137 * @param root Subtree of tests. 138 * @internal Internal APIs for testing purpose only 139 */ 140 T_CTEST_API void T_CTEST_EXPORT2 141 runTests ( const TestNode* root); 142 143 /** 144 * Add a test to the subtree. 145 * Example usage: 146 * <PRE> 147 * TestNode* root=NULL; 148 * addTest(&root, &mytest, "/a/b/mytest" ); 149 * </PRE> 150 * @param root Pointer to the root pointer. 151 * @param test Pointer to 'void function(void)' for actual test. 152 * @param path Path from root under which test will be placed. Ex. '/a/b/mytest' 153 * @internal Internal APIs for testing purpose only 154 */ 155 T_CTEST_API void T_CTEST_EXPORT2 156 addTest(TestNode** root, 157 TestFunctionPtr test, 158 const char *path); 159 160 /** 161 * Clean up any allocated memory. 162 * Conditions for calling this function are the same as u_cleanup(). 163 * @see u_cleanup 164 * @internal Internal APIs for testing purpose only 165 */ 166 T_CTEST_API void T_CTEST_EXPORT2 167 cleanUpTestTree(TestNode *tn); 168 169 /** 170 * Retreive a specific subtest. (subtree). 171 * 172 * @param root Pointer to the root. 173 * @param path Path relative to the root, Ex. '/a/b' 174 * @return The subtest, or NULL on failure. 175 * @internal Internal APIs for testing purpose only 176 */ 177 T_CTEST_API const TestNode* T_CTEST_EXPORT2 178 getTest(const TestNode* root, 179 const char *path); 180 181 182 /** 183 * Log an error message. (printf style) 184 * @param pattern printf-style format string 185 * @internal Internal APIs for testing purpose only 186 */ 187 T_CTEST_API void T_CTEST_EXPORT2 188 log_err(const char* pattern, ...); 189 190 T_CTEST_API void T_CTEST_EXPORT2 191 log_err_status(UErrorCode status, const char* pattern, ...); 192 /** 193 * Log an informational message. (printf style) 194 * @param pattern printf-style format string 195 * @internal Internal APIs for testing purpose only 196 */ 197 T_CTEST_API void T_CTEST_EXPORT2 198 log_info(const char* pattern, ...); 199 200 /** 201 * Log an informational message. (vprintf style) 202 * @param prefix a string that is output before the pattern and without formatting 203 * @param pattern printf-style format string 204 * @param ap variable-arguments list 205 * @internal Internal APIs for testing purpose only 206 */ 207 T_CTEST_API void T_CTEST_EXPORT2 208 vlog_info(const char *prefix, const char *pattern, va_list ap); 209 210 /** 211 * Log a verbose informational message. (printf style) 212 * This message will only appear if the global VERBOSITY is nonzero 213 * @param pattern printf-style format string 214 * @internal Internal APIs for testing purpose only 215 */ 216 T_CTEST_API void T_CTEST_EXPORT2 217 log_verbose(const char* pattern, ...); 218 219 /** 220 * Log an error message concerning missing data. (printf style) 221 * If WARN_ON_MISSING_DATA is nonzero, this will case a log_info (warning) to be 222 * printed, but if it is zero this will produce an error (log_err). 223 * @param pattern printf-style format string 224 * @internal Internal APIs for testing purpose only 225 */ 226 T_CTEST_API void T_CTEST_EXPORT2 227 log_data_err(const char *pattern, ...); 228 229 /** 230 * Log a known issue. 231 * @param ticket ticket number such as "12345" for ICU tickets or "cldrbug:6636" for CLDR tickets. 232 * @param fmt ... sprintf-style format, optional message. can be NULL. 233 * @return TRUE if known issue test should be skipped, FALSE if it should be run 234 */ 235 T_CTEST_API UBool 236 T_CTEST_EXPORT2 237 log_knownIssue(const char *ticket, const char *fmt, ...); 238 239 /** 240 * Initialize the variables above. This allows the test to set up accordingly 241 * before running the tests. 242 * This must be called before runTests. 243 */ 244 T_CTEST_API int T_CTEST_EXPORT2 245 initArgs( int argc, const char* const argv[], ArgHandlerPtr argHandler, void *context); 246 247 /** 248 * Processes the command line arguments. 249 * This is a sample implementation 250 * <PRE>Usage: %s [ -l ] [ -v ] [ -? ] [ /path/to/test ] 251 * -l List only, do not run\ 252 * -v turn OFF verbosity 253 * -? print this message</PRE> 254 * @param root Testnode root with tests already attached to it 255 * @param argv argument list from main (stdio.h) 256 * @param argc argument list count from main (stdio.h) 257 * @return positive for error count, 0 for success, negative for illegal argument 258 * @internal Internal APIs for testing purpose only 259 */ 260 T_CTEST_API int T_CTEST_EXPORT2 261 runTestRequest(const TestNode* root, 262 int argc, 263 const char* const argv[]); 264 265 266 T_CTEST_API const char* T_CTEST_EXPORT2 267 getTestName(void); 268 269 /** 270 * Append a time delta to str if it is significant (>5 ms) otherwise no change 271 * @param delta a delta in millis 272 * @param str a string to append to. 273 */ 274 T_CTEST_API void T_CTEST_EXPORT2 275 str_timeDelta(char *str, UDate delta); 276 277 278 /* ======== XML (JUnit output) ========= */ 279 280 /** 281 * Set the filename for the XML output. 282 * @param fileName file name. Caller must retain storage. 283 * @return 0 on success, 1 on failure. 284 */ 285 T_CTEST_API int32_t T_CTEST_EXPORT2 286 ctest_xml_setFileName(const char *fileName); 287 288 289 /** 290 * Init XML subsystem. Call ctest_xml_setFileName first 291 * @param rootName the test root name to be written 292 * @return 0 on success, 1 on failure. 293 */ 294 T_CTEST_API int32_t T_CTEST_EXPORT2 295 ctest_xml_init(const char *rootName); 296 297 298 /** 299 * Set the filename for the XML output. Caller must retain storage. 300 * @return 0 on success, 1 on failure. 301 */ 302 T_CTEST_API int32_t T_CTEST_EXPORT2 303 ctest_xml_fini(void); 304 305 306 /** 307 * report a test case 308 * @return 0 on success, 1 on failure. 309 */ 310 T_CTEST_API int32_t 311 T_CTEST_EXPORT2 312 ctest_xml_testcase(const char *classname, const char *name, const char *time, const char *failMsg); 313 314 /** 315 * Returns the path to icu4c/source/data. 316 * 317 * @return The path to icu4c/source/data. Do not free this pointer. 318 */ 319 T_CTEST_API const char* T_CTEST_EXPORT2 320 ctest_dataSrcDir(void); 321 322 /** 323 * Returns the path to the ICU data. 324 * 325 * Uses, in order of preference: 326 * 327 * 1. The path in the ICU_DATA environment variable. 328 * 2. icu4c/source/data/out. 329 * 330 * @return The path to the ICU data. Do not free this pointer. 331 */ 332 T_CTEST_API const char* T_CTEST_EXPORT2 333 ctest_dataOutDir(void); 334 335 /** 336 * Returns the path to icu4c/source/test/testdata. 337 * 338 * @return The path to icu4c/source/test/testdata. Do not free this pointer. 339 */ 340 T_CTEST_API const char* T_CTEST_EXPORT2 341 ctest_testDataDir(void); 342 343 /** 344 * Returns the path to icu4c/source/test/testdata/out/testdata if it is 345 * loadable. 346 * 347 * @param err Out parameter for any errors. 348 * @return The path to icu4c/source/test/testdata/out/testdata if it can be 349 * loaded, or the empty string if it could not be loaded. Do not free 350 * this pointer. 351 */ 352 T_CTEST_API const char* T_CTEST_EXPORT2 353 ctest_loadTestData(UErrorCode* err); 354 355 #endif 356