2 **********************************************************************
3 * Copyright (c) 2002-2005, International Business Machines
4 * Corporation and others. All Rights Reserved.
5 **********************************************************************
6 **********************************************************************
11 #include "unicode/utypes.h"
12 #include "unicode/unistr.h"
13 #include "unicode/ustring.h"
15 #include "unicode/testtype.h"
16 #include "unicode/utimer.h"
19 #if !UCONFIG_NO_CONVERSION
22 // Use the TESTCASE macro in subclasses of IntlTest. Define the
23 // runIndexedTest method in this fashion:
25 //| void MyTest::runIndexedTest(int32_t index, UBool exec,
26 //| const char* &name, char* /*par*/) {
28 //| TESTCASE(0,TestSomething);
29 //| TESTCASE(1,TestSomethingElse);
30 //| TESTCASE(2,TestAnotherThing);
37 #define TESTCASE(id,test) \
41 fprintf(stdout,#test "---"); \
42 fprintf(stdout,"\n"); \
48 #define TESTCASE(id,test) \
57 * Subclasses of PerfTest will need to create subclasses of
58 * Function that define a call() method which contains the code to
59 * be timed. They then call setTestFunction() in their "Test..."
60 * method to establish this as the current test functor.
62 class T_CTEST_EXPORT_API UPerfFunction
{
65 * Subclasses must implement this method to do the action to be
68 virtual void call(UErrorCode
* status
)=0;
71 * Subclasses must implement this method to return positive
72 * integer indicating the number of operations in a single
73 * call to this object's call() method.
75 virtual long getOperationsPerIteration()=0;
77 * Subclasses should override this method to return either positive
78 * or negative integer indicating the number of events in a single
79 * call to this object's call() method, if applicable
80 * e.g: Number of breaks / iterations for break iterator
82 virtual long getEventsPerIteration(){
88 virtual ~UPerfFunction() {}
91 * Call call() n times in a tight loop and return the elapsed
92 * milliseconds. If n is small and call() is fast the return
93 * result may be zero. Small return values have limited
94 * meaningfulness, depending on the underlying CPU and OS.
96 virtual double time(int32_t n
, UErrorCode
* status
) {
98 utimer_getTime(&start
);
102 utimer_getTime(&stop
);
103 return utimer_getDeltaSeconds(&start
,&stop
); // ms
109 class T_CTEST_EXPORT_API UPerfTest
{
112 UBool
runTest( char* name
= NULL
, char* par
= NULL
); // not to be overidden
114 virtual void usage( void ) ;
116 virtual ~UPerfTest();
118 void setCaller( UPerfTest
* callingTest
); // for internal use only
120 void setPath( char* path
); // for internal use only
122 ULine
* getLines(UErrorCode
& status
);
124 const UChar
* getBuffer(int32_t& len
,UErrorCode
& status
);
127 UPerfTest(int32_t argc
, const char* argv
[], UErrorCode
& status
);
129 virtual UPerfFunction
* runIndexedTest( int32_t index
, UBool exec
, const char* &name
, char* par
= NULL
); // overide !
131 virtual UBool
runTestLoop( char* testname
, char* par
);
133 virtual UBool
callTest( UPerfTest
& testToBeCalled
, char* par
);
136 const char* sourceDir
;
137 const char* fileName
;
138 char* resolvedFileName
;
139 const char* encoding
;
146 int32_t _remainingArgc
;
157 char* path
; // specifies subtests
161 static UPerfTest
* gTest
;
162 static const char gUsageString
[];