]> git.saurik.com Git - apple/icu.git/blobdiff - icuSources/test/cintltst/uregiontest.c
ICU-57163.0.1.tar.gz
[apple/icu.git] / icuSources / test / cintltst / uregiontest.c
index c86355bf9b43e49800c12a95f73f8c9fa8da04f9..4f1f7020a329ef341d00ece71e4ba8652650e61b 100644 (file)
@@ -1,5 +1,5 @@
 /********************************************************************
- * Copyright (c) 2013, International Business Machines Corporation
+ * Copyright (c) 2014-2016, International Business Machines Corporation
  * and others. All Rights Reserved.
  ********************************************************************/
 /* C API TEST FOR UREGION */
 #include "unicode/uenum.h"
 #include "cintltst.h"
 #include "cmemory.h"
+#include "cstring.h"
 
 static void TestKnownRegions(void);
 static void TestGetContainedRegions(void);
 static void TestGetContainedRegionsWithType(void);
 static void TestGetContainingRegion(void);
 static void TestGetContainingRegionWithType(void);
+static void TestGetPreferredValues(void);
+static void TestContains(void);
 
 void addURegionTest(TestNode** root);
 
@@ -36,6 +39,8 @@ void addURegionTest(TestNode** root)
     TESTCASE(TestGetContainedRegionsWithType);
     TESTCASE(TestGetContainingRegion);
     TESTCASE(TestGetContainingRegionWithType);
+    TESTCASE(TestGetPreferredValues);
+    TESTCASE(TestContains);
 }
 
 typedef struct KnownRegion {
@@ -46,8 +51,6 @@ typedef struct KnownRegion {
   const char *containingContinent;
 } KnownRegion;
 
-#define LENGTHOF(array) (int32_t)(sizeof(array) / sizeof((array)[0]))
-
 static KnownRegion knownRegions[] = {
     // Code, Num, Parent, Type,             Containing Continent
     { "TP" , 626, "035", URGN_TERRITORY, "142" },
@@ -301,7 +304,7 @@ static KnownRegion knownRegions[] = {
     { "SN" , 686, "011", URGN_TERRITORY, "002" },
     { "SO" , 706, "014", URGN_TERRITORY, "002" },
     { "SR" , 740, "005", URGN_TERRITORY, "019" },
-    { "SS" , 728, "015", URGN_TERRITORY, "002" },
+    { "SS" , 728, "014", URGN_TERRITORY, "002" },
     { "ST" , 678, "017", URGN_TERRITORY, "002" },
     { "SU" , 810, NULL , URGN_DEPRECATED , NULL},
     { "SV" , 222, "013", URGN_TERRITORY, "019" },
@@ -392,7 +395,7 @@ static void TestGetContainedRegions() {
                 continue;
             }
             containedRegions = uregion_getContainedRegions(r, &status);
-            if (containedRegions) {
+            if (containedRegions != NULL) {
                 while ((crID = uenum_next(containedRegions, NULL, &status)) != NULL && U_SUCCESS(status) ) {
                     const URegion *cr = uregion_getRegionFromCode(crID, &status);
                     const URegion *containingRegion = (cr)? uregion_getContainingRegion(cr) : NULL;
@@ -421,7 +424,7 @@ static void TestGetContainedRegionsWithType() {
                 continue;
             }
             containedRegions = uregion_getContainedRegionsOfType(r, URGN_TERRITORY, &status);
-            if (containedRegions) {
+            if (containedRegions != NULL) {
                 while ((crID = uenum_next(containedRegions, NULL, &status)) != NULL && U_SUCCESS(status) ) {
                     const URegion *cr = uregion_getRegionFromCode(crID, &status);
                     const URegion *containingRegion = (cr)? uregion_getContainingRegionOfType(cr, URGN_CONTINENT) : NULL;
@@ -486,5 +489,76 @@ static void TestGetContainingRegionWithType() {
     }
 }
 
+static const char * expectPrefRegions0[] = { "AN","CW","SX","BQ",NULL };        /* Netherlands Antilles */
+static const char * expectPrefRegions1[] = { "CS","RS","ME",NULL };             /* Serbia & Montenegro */
+static const char * expectPrefRegions2[] = { "FQ","AQ","TF",NULL };             /* French Southern and Antarctic Territories */
+static const char * expectPrefRegions3[] = { "NT","IQ","SA",NULL };             /* Neutral Zone */
+static const char * expectPrefRegions4[] = { "PC","FM","MH","MP","PW",NULL };   /* Pacific Islands Trust Territory */
+static const char * expectPrefRegions5[] = { "SU","RU","AM","AZ","BY","EE","GE","KZ","KG","LV","LT","MD","TJ","TM","UA","UZ",NULL }; /* Soviet Union */
+static const char ** expectPrefRegionsTestData[] = {
+    expectPrefRegions0,
+    expectPrefRegions1,
+    expectPrefRegions2,
+    expectPrefRegions3,
+    expectPrefRegions4,
+    expectPrefRegions5,
+    NULL
+};
+
+static void TestGetPreferredValues() {
+    const char *** testDataPtr = expectPrefRegionsTestData;
+    const char ** regionListPtr;
+    while ( (regionListPtr = *testDataPtr++) != NULL ) {
+        UErrorCode status = U_ZERO_ERROR;
+        const char * deprecatedCode = *regionListPtr++;
+        const URegion *r = uregion_getRegionFromCode(deprecatedCode, &status);
+        if ( U_SUCCESS(status) ) {
+            UEnumeration *preferredRegions = uregion_getPreferredValues(r, &status);
+            if ( U_SUCCESS(status) ) {
+                if (preferredRegions != NULL) {
+                    const char * preferredCode;
+                    while ( (preferredCode = *regionListPtr++) != NULL ) {
+                        const char *check;
+                        UBool found = FALSE;
+                        uenum_reset(preferredRegions, &status);
+                        while ((check = uenum_next(preferredRegions, NULL, &status)) != NULL && U_SUCCESS(status) ) {
+                            if ( !uprv_strcmp(check,preferredCode) ) {
+                                found = TRUE;
+                                break;
+                            }
+                        }
+                        if ( !found ) {
+                            log_err("ERROR: uregion_getPreferredValues for region \"%s\" should have contained \"%s\" but it didn't.\n", uregion_getRegionCode(r), preferredCode);
+                        }
+                    }
+                    uenum_close(preferredRegions);
+                }
+            } else {
+                log_err("ERROR: uregion_getPreferredValues failed for region %s.\n", uregion_getRegionCode(r));
+            }
+        } else {
+            log_data_err("ERROR: Known region %s was not recognized.\n", deprecatedCode);
+        }
+    }
+}
+
+static void TestContains() {
+    const KnownRegion * rd;
+    for (rd = knownRegions; rd->code != NULL ; rd++ ) {
+        UErrorCode status = U_ZERO_ERROR;
+        const URegion *r = uregion_getRegionFromCode(rd->code, &status);
+        if ( U_SUCCESS(status) ) {
+            const URegion *c = uregion_getContainingRegion(r);
+            while (c != NULL) {
+                if ( !uregion_contains(c, r) ) {
+                    log_err("ERROR: Region \"%s\" should have contained \"%s\" but it didn't.\n", uregion_getRegionCode(c), uregion_getRegionCode(r) );
+                }
+                c = uregion_getContainingRegion(c);
+            }
+        } else {
+            log_data_err("ERROR: Known region %s was not recognized.\n", rd->code);
+        }
+    }
+}
 
 #endif /* #if !UCONFIG_NO_FORMATTING */