1 // © 2016 and later: Unicode, Inc. and others. 2 // License & terms of use: http://www.unicode.org/copyright.html 3 /******************************************************************** 4 * COPYRIGHT: 5 * Copyright (c) 2002-2005, International Business Machines Corporation and 6 * others. All Rights Reserved. 7 ********************************************************************/ 8 9 /* Created by weiv 05/09/2002 */ 10 11 /* Base class for data driven tests */ 12 13 #ifndef U_TESTFW_TESTMODULE 14 #define U_TESTFW_TESTMODULE 15 16 #include "unicode/unistr.h" 17 #include "unicode/ures.h" 18 #include "unicode/testtype.h" 19 #include "unicode/testdata.h" 20 #include "unicode/datamap.h" 21 #include "unicode/testlog.h" 22 23 24 /* This class abstracts the actual organization of the 25 * data for data driven tests 26 */ 27 28 29 class DataMap; 30 class TestData; 31 32 33 /** Main data driven test class. Corresponds to one named data 34 * unit (such as a resource bundle. It is instantiated using 35 * a factory method getTestDataModule 36 */ 37 class T_CTEST_EXPORT_API TestDataModule { 38 const char* testName; 39 40 protected: 41 DataMap *fInfo; 42 TestLog& fLog; 43 44 public: 45 /** Factory method. 46 * @param name name of the test module. Usually name of a resource bundle or a XML file 47 * @param log a logging class, used for internal error reporting. 48 * @param status if something goes wrong, status will be set 49 * @return a TestDataModule object. Use it to get test data from it 50 */ 51 static TestDataModule *getTestDataModule(const char* name, TestLog& log, UErrorCode &status); 52 virtual ~TestDataModule(); 53 54 protected: 55 TestDataModule(const char* name, TestLog& log, UErrorCode& status); 56 57 public: 58 /** Name of this TestData module. 59 * @return a name 60 */ 61 const char * getName() const; 62 63 /** Get a pointer to an object owned DataMap that contains more information on this module 64 * Usual fields are "Description", "LongDescription", "Settings". Also, if containing a 65 * field "Headers" these will be used as the default headers, so that you don't have to 66 * to specify per test headers. 67 * @param info pass in a const DataMap pointer. If no info, it will be set to NULL 68 */ 69 virtual UBool getInfo(const DataMap *& info, UErrorCode &status) const = 0; 70 71 /** Create a test data object from an index. Helpful for integrating tests with current 72 * intltest framework which addresses the tests by index. 73 * @param index index of the test to be instantiated 74 * @return an instantiated TestData object, ready to provide settings and cases for 75 * the tests. 76 */ 77 virtual TestData* createTestData(int32_t index, UErrorCode &status) const = 0; 78 79 /** Create a test data object from a name. 80 * @param name name of the test to be instantiated 81 * @return an instantiated TestData object, ready to provide settings and cases for 82 * the tests. 83 */ 84 virtual TestData* createTestData(const char* name, UErrorCode &status) const = 0; 85 }; 86 87 class T_CTEST_EXPORT_API RBTestDataModule : public TestDataModule { 88 public: 89 virtual ~RBTestDataModule(); 90 91 public: 92 RBTestDataModule(const char* name, TestLog& log, UErrorCode& status); 93 94 public: 95 virtual UBool getInfo(const DataMap *& info, UErrorCode &status) const override; 96 97 virtual TestData* createTestData(int32_t index, UErrorCode &status) const override; 98 virtual TestData* createTestData(const char* name, UErrorCode &status) const override; 99 100 private: 101 UResourceBundle *getTestBundle(const char* bundleName, UErrorCode &status); 102 103 private: 104 UResourceBundle *fModuleBundle; 105 UResourceBundle *fTestData; 106 UResourceBundle *fInfoRB; 107 UBool fDataTestValid; 108 char *tdpath; 109 110 /* const char* fTestName;*/ /* See name */ 111 int32_t fNumberOfTests; 112 113 }; 114 115 116 #endif 117 118