Home | History | Annotate | Download | only in cintltst
      1 /********************************************************************
      2  * COPYRIGHT:
      3  * Copyright (c) 1997-2012, International Business Machines Corporation and
      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 
     16 The main root for C API tests
     17 */
     18 
     19 #ifndef _CINTLTST
     20 #define _CINTLTST
     21 
     22 #include "unicode/utypes.h"
     23 #include "unicode/putil.h"
     24 #include "unicode/ctest.h"
     25 
     26 #if U_NO_DEFAULT_INCLUDE_UTF_HEADERS
     27 /* deprecated  - make tests pass with U_NO_DEFAULT_INCLUDE_UTF_HEADERS */
     28 #include "unicode/utf_old.h"
     29 #endif
     30 
     31 #include <stdlib.h>
     32 
     33 #ifndef U_USE_DEPRECATED_API
     34 #define U_USE_DEPRECATED_API 1
     35 #endif
     36 
     37 U_CFUNC void addAllTests(TestNode** root);
     38 
     39 /**
     40  * Return the path to the icu/source/data/out  directory
     41  */
     42 U_CFUNC const char* ctest_dataOutDir(void);
     43 
     44 /**
     45  * Return the path to the icu/source/data/  directory
     46  * for out of source builds too returns the source directory
     47  */
     48 U_CFUNC const char* ctest_dataSrcDir(void);
     49 
     50 /**
     51  * Convert a char string into a UChar string, with unescaping
     52  * The result buffer has been malloc()'ed (not ctst_malloc) and needs to be free()'ed by the caller.
     53  */
     54 U_CFUNC UChar* CharsToUChars(const char* chars);
     55 
     56 /**
     57  * Convert a const UChar* into a char*
     58  * Result is allocated with ctst_malloc and will be freed at the end of the test.
     59  * @param unichars UChars (null terminated) to be converted
     60  * @return new char* to the unichars in host format
     61  */
     62 
     63 U_CFUNC char *austrdup(const UChar* unichars);
     64 
     65 /**
     66  * Convert a const UChar* into an escaped char*
     67  * Result is allocated with ctst_malloc and will be freed at the end of the test.
     68  * @param unichars UChars to be converted
     69  * @param length length of chars
     70  * @return new char* to the unichars in host format
     71  */
     72 U_CFUNC char *aescstrdup(const UChar* unichars, int32_t length);
     73 
     74 /**
     75  * Special memory allocation function for test use. At the end of cintltst,
     76  * or every few thousand allocations, memory allocated by this function will be freed.
     77  * Do not manually free memory returned by this function, and do not retain a pointer
     78  * outside of a single instruction scope (i.e. long enough to display the value).
     79  * @see #ctst_freeAll
     80  */
     81 U_CFUNC void *ctst_malloc(size_t size);
     82 
     83 /**
     84  * Return the path to cintltst's data ( icu/source/data/testdata ) directory.
     85  * Return value is allocated by ctst_malloc and should not be deleted.
     86  */
     87 U_CFUNC const char* loadTestData(UErrorCode* err);
     88 
     89 /**
     90  * function used to specify the error
     91  * converts the errorcode to an error descriptive string(const char*)
     92  * @param status the error code
     93  */
     94 #define myErrorName(errorCode) u_errorName(errorCode)
     95 
     96 
     97 /**
     98  * Call this once to get a consistent timezone. Use ctest_resetTimeZone to set it back to the original value.
     99  * @param optionalTimeZone Set this to a requested timezone.
    100  *      Set to NULL to use the standard test timezone (Pacific Time)
    101  */
    102 U_CFUNC void ctest_setTimeZone(const char *optionalTimeZone, UErrorCode *status);
    103 /**
    104  * Call this once get back the original timezone
    105  */
    106 U_CFUNC void ctest_resetTimeZone(void);
    107 
    108 /**
    109  * Call this once get ICU back to its original state with test arguments.
    110  * This function calls u_cleanup.
    111  */
    112 U_CFUNC UBool ctest_resetICU(void);
    113 
    114 /**
    115  * Assert that the given UErrorCode succeeds, and return TRUE if it does.
    116  */
    117 U_CFUNC UBool assertSuccess(const char* msg, UErrorCode* ec);
    118 
    119 /**
    120  * Assert that the UBool is TRUE, and return TRUE if it does.
    121  *
    122  * NOTE: Use 'int condition' rather than 'UBool condition' so the
    123  * compiler doesn't complain about integral conversion of expressions
    124  * like 'p != 0'.
    125  */
    126 U_CFUNC UBool assertTrue(const char* msg, int condition);
    127 
    128 /**
    129  * Assert that the actualString equals the expectedString, and return
    130  * TRUE if it does.
    131  */
    132 U_CFUNC UBool assertEquals(const char* msg, const char* expectedString,
    133                            const char* actualString);
    134 
    135 /**
    136  * Returns true if u_getVersion() < major.minor.milli.
    137  */
    138 U_CFUNC UBool isICUVersionBefore(int major, int minor, int milli);
    139 
    140 /**
    141  * Returns true if u_getVersion() >= major.minor.milli.
    142  */
    143 U_CFUNC UBool isICUVersionAtLeast(int major, int minor, int milli);
    144 
    145 #endif
    146