]> git.saurik.com Git - apple/icu.git/blame - icuSources/test/cintltst/cintltst.h
ICU-400.37.tar.gz
[apple/icu.git] / icuSources / test / cintltst / cintltst.h
CommitLineData
b75a7d8f
A
1/********************************************************************
2 * COPYRIGHT:
73c04bcf 3 * Copyright (c) 1997-2005, International Business Machines Corporation and
b75a7d8f
A
4 * others. All Rights Reserved.
5 ********************************************************************/
6/********************************************************************************
7*
8* File CINTLTST.H
9*
10* Madhu Katragadda Creation
11* Modification History:
12* Date Name Description
13* 07/13/99 helena HPUX 11 CC port.
14*********************************************************************************
15
16The main root for C API tests
17*/
18
19#ifndef _CINTLTST
20#define _CINTLTST
21
22#include "unicode/utypes.h"
374ca955 23#include "unicode/putil.h"
b75a7d8f 24#include "unicode/ctest.h"
73c04bcf 25#include <stdlib.h>
b75a7d8f
A
26
27#ifndef U_USE_DEPRECATED_API
28#define U_USE_DEPRECATED_API 1
29#endif
30
31U_CFUNC void addAllTests(TestNode** root);
32
33/**
34 * Return the path to the icu/source/data/out directory
35 */
36U_CFUNC const char* ctest_dataOutDir(void);
37
38/**
39 * Return the path to the icu/source/data/ directory
40 * for out of source builds too returns the source directory
41 */
42U_CFUNC const char* ctest_dataSrcDir(void);
43
b75a7d8f
A
44U_CFUNC UChar* CharsToUChars(const char* chars);
45
46/**
47 * Convert a const UChar* into a char*
48 * Caller owns storage, but in practice this function
49 * LEAKS so be aware of that.
50 * @param unichars UChars (null terminated) to be converted
51 * @return new char* to the unichars in host format
52 */
53
54U_CFUNC char *austrdup(const UChar* unichars);
55U_CFUNC char *aescstrdup(const UChar* unichars, int32_t length);
56U_CFUNC void *ctst_malloc(size_t size);
57U_CFUNC void ctst_freeAll(void);
58
59U_CFUNC const char* loadTestData(UErrorCode* err);
60
61/**
62 * function used to specify the error
63 * converts the errorcode to an error descriptive string(const char*)
64 * @param status the error code
65 */
66#define myErrorName(errorCode) u_errorName(errorCode)
67
68
374ca955
A
69/**
70 * Call this once to get a consistent timezone. Use ctest_resetTimeZone to set it back to the original value.
71 * @param optionalTimeZone Set this to a requested timezone.
72 * Set to NULL to use the standard test timezone (Pacific Time)
73 */
74U_CFUNC void ctest_setTimeZone(const char *optionalTimeZone, UErrorCode *status);
75/**
76 * Call this once get back the original timezone
77 */
78U_CFUNC void ctest_resetTimeZone(void);
79
46f4442e
A
80/**
81 * Call this once get ICU back to its original state with test arguments.
82 * This function calls u_cleanup.
83 */
84U_CFUNC UBool ctest_resetICU(void);
85
374ca955
A
86/**
87 * Assert that the given UErrorCode succeeds, and return TRUE if it does.
88 */
89U_CFUNC UBool assertSuccess(const char* msg, UErrorCode* ec);
90
91/**
92 * Assert that the UBool is TRUE, and return TRUE if it does.
93 *
94 * NOTE: Use 'int condition' rather than 'UBool condition' so the
95 * compiler doesn't complain about integral conversion of expressions
96 * like 'p != 0'.
97 */
98U_CFUNC UBool assertTrue(const char* msg, int condition);
99
100/**
101 * Assert that the actualString equals the expectedString, and return
102 * TRUE if it does.
103 */
104U_CFUNC UBool assertEquals(const char* msg, const char* expectedString,
105 const char* actualString);
106
73c04bcf
A
107/**
108 * Time bomb - allows temporary behavior that expires at a given
109 * release
110 *
111 */
112U_CFUNC UBool isICUVersionAtLeast(const UVersionInfo x);
113
b75a7d8f 114#endif