summaryrefslogtreecommitdiffstats
path: root/intl/icu/source/tools/ctestfw/unicode/tstdtmod.h
diff options
context:
space:
mode:
Diffstat (limited to 'intl/icu/source/tools/ctestfw/unicode/tstdtmod.h')
-rw-r--r--intl/icu/source/tools/ctestfw/unicode/tstdtmod.h117
1 files changed, 117 insertions, 0 deletions
diff --git a/intl/icu/source/tools/ctestfw/unicode/tstdtmod.h b/intl/icu/source/tools/ctestfw/unicode/tstdtmod.h
new file mode 100644
index 0000000000..fb2f19631d
--- /dev/null
+++ b/intl/icu/source/tools/ctestfw/unicode/tstdtmod.h
@@ -0,0 +1,117 @@
+// © 2016 and later: Unicode, Inc. and others.
+// License & terms of use: http://www.unicode.org/copyright.html
+/********************************************************************
+ * COPYRIGHT:
+ * Copyright (c) 2002-2005, International Business Machines Corporation and
+ * others. All Rights Reserved.
+ ********************************************************************/
+
+/* Created by weiv 05/09/2002 */
+
+/* Base class for data driven tests */
+
+#ifndef U_TESTFW_TESTMODULE
+#define U_TESTFW_TESTMODULE
+
+#include "unicode/unistr.h"
+#include "unicode/ures.h"
+#include "unicode/testtype.h"
+#include "unicode/testdata.h"
+#include "unicode/datamap.h"
+#include "unicode/testlog.h"
+
+
+/* This class abstracts the actual organization of the
+ * data for data driven tests
+ */
+
+
+class DataMap;
+class TestData;
+
+
+/** Main data driven test class. Corresponds to one named data
+ * unit (such as a resource bundle. It is instantiated using
+ * a factory method getTestDataModule
+ */
+class T_CTEST_EXPORT_API TestDataModule {
+ const char* testName;
+
+protected:
+ DataMap *fInfo;
+ TestLog& fLog;
+
+public:
+ /** Factory method.
+ * @param name name of the test module. Usually name of a resource bundle or a XML file
+ * @param log a logging class, used for internal error reporting.
+ * @param status if something goes wrong, status will be set
+ * @return a TestDataModule object. Use it to get test data from it
+ */
+ static TestDataModule *getTestDataModule(const char* name, TestLog& log, UErrorCode &status);
+ virtual ~TestDataModule();
+
+protected:
+ TestDataModule(const char* name, TestLog& log, UErrorCode& status);
+
+public:
+ /** Name of this TestData module.
+ * @return a name
+ */
+ const char * getName() const;
+
+ /** Get a pointer to an object owned DataMap that contains more information on this module
+ * Usual fields are "Description", "LongDescription", "Settings". Also, if containing a
+ * field "Headers" these will be used as the default headers, so that you don't have to
+ * to specify per test headers.
+ * @param info pass in a const DataMap pointer. If no info, it will be set to nullptr
+ */
+ virtual UBool getInfo(const DataMap *& info, UErrorCode &status) const = 0;
+
+ /** Create a test data object from an index. Helpful for integrating tests with current
+ * intltest framework which addresses the tests by index.
+ * @param index index of the test to be instantiated
+ * @return an instantiated TestData object, ready to provide settings and cases for
+ * the tests.
+ */
+ virtual TestData* createTestData(int32_t index, UErrorCode &status) const = 0;
+
+ /** Create a test data object from a name.
+ * @param name name of the test to be instantiated
+ * @return an instantiated TestData object, ready to provide settings and cases for
+ * the tests.
+ */
+ virtual TestData* createTestData(const char* name, UErrorCode &status) const = 0;
+};
+
+class T_CTEST_EXPORT_API RBTestDataModule : public TestDataModule {
+public:
+ virtual ~RBTestDataModule();
+
+public:
+ RBTestDataModule(const char* name, TestLog& log, UErrorCode& status);
+
+public:
+ virtual UBool getInfo(const DataMap *& info, UErrorCode &status) const override;
+
+ virtual TestData* createTestData(int32_t index, UErrorCode &status) const override;
+ virtual TestData* createTestData(const char* name, UErrorCode &status) const override;
+
+private:
+ UResourceBundle *getTestBundle(const char* bundleName, UErrorCode &status);
+
+private:
+ UResourceBundle *fModuleBundle;
+ UResourceBundle *fTestData;
+ UResourceBundle *fInfoRB;
+ UBool fDataTestValid;
+ char *tdpath;
+
+/* const char* fTestName;*/ /* See name */
+ int32_t fNumberOfTests;
+
+};
+
+
+#endif
+