Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(78)

Unified Diff: components/autofill/core/browser/country_names_unittest.cc

Issue 1582353006: CountryNames: Separate data creation from usage (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@571610_exposeCountryNamesToTesting
Patch Set: Set CountryNames locale also from PersonalDataManager Created 4 years, 11 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: components/autofill/core/browser/country_names_unittest.cc
diff --git a/components/autofill/core/browser/country_names_unittest.cc b/components/autofill/core/browser/country_names_unittest.cc
index 65e0bfd1fb1d5bc97cd46990805b2f9bf3a780bf..93c25bc10ed90c79047965e2ea901d0abf50abf4 100644
--- a/components/autofill/core/browser/country_names_unittest.cc
+++ b/components/autofill/core/browser/country_names_unittest.cc
@@ -12,56 +12,66 @@
using base::ASCIIToUTF16;
namespace autofill {
+namespace {
+
+class TestCountryNames : public CountryNames {
+ public:
+ explicit TestCountryNames(const std::string& locale_name)
+ : CountryNames(locale_name) {}
+
+ ~TestCountryNames() = default;
+};
+
+} // namespace
// Test mapping of localized country names to country codes.
-TEST(CountryNamesTest, GetCountryCode) {
- // Basic mapping
- EXPECT_EQ("US", CountryNames::GetInstance()->GetCountryCode(
- ASCIIToUTF16("United States"), "en_US"));
- EXPECT_EQ("CA", CountryNames::GetInstance()->GetCountryCode(
- ASCIIToUTF16("Canada"), "en_US"));
+TEST(CountryNamesTest, GetCountryCode_BasicMapping) {
+ TestCountryNames en_us_names("en_US");
+ EXPECT_EQ("US", en_us_names.GetCountryCode(ASCIIToUTF16("United States")));
+ EXPECT_EQ("CA", en_us_names.GetCountryCode(ASCIIToUTF16("Canada")));
+}
- // Case-insensitive mapping
- EXPECT_EQ("US", CountryNames::GetInstance()->GetCountryCode(
- ASCIIToUTF16("united states"), "en_US"));
+TEST(CountryNamesTest, GetCountryCode_CaseInsensitiveMapping) {
+ EXPECT_EQ("US", TestCountryNames("en_US")
+ .GetCountryCode(ASCIIToUTF16("united states")));
+}
- // Country codes should map to themselves, independent of locale.
- EXPECT_EQ("US", CountryNames::GetInstance()->GetCountryCode(
- ASCIIToUTF16("US"), "en_US"));
- EXPECT_EQ("HU", CountryNames::GetInstance()->GetCountryCode(
- ASCIIToUTF16("hu"), "en_US"));
- EXPECT_EQ("CA", CountryNames::GetInstance()->GetCountryCode(
- ASCIIToUTF16("CA"), "fr_CA"));
- EXPECT_EQ("MX", CountryNames::GetInstance()->GetCountryCode(
- ASCIIToUTF16("mx"), "fr_CA"));
+TEST(CountryNamesTest, GetCountryCode_CodesMapToThemselves) {
+ TestCountryNames en_us_names("en_US");
+ TestCountryNames fr_ca_names("fr_CA");
+ EXPECT_EQ("US", en_us_names.GetCountryCode(ASCIIToUTF16("US")));
+ EXPECT_EQ("HU", en_us_names.GetCountryCode(ASCIIToUTF16("hu")));
+ EXPECT_EQ("CA", fr_ca_names.GetCountryCode(ASCIIToUTF16("CA")));
+ EXPECT_EQ("MX", fr_ca_names.GetCountryCode(ASCIIToUTF16("mx")));
+}
- // Basic synonyms
- EXPECT_EQ("US", CountryNames::GetInstance()->GetCountryCode(
- ASCIIToUTF16("United States of America"), "en_US"));
- EXPECT_EQ("US", CountryNames::GetInstance()->GetCountryCode(
- ASCIIToUTF16("USA"), "en_US"));
+TEST(CountryNamesTest, GetCountryCode_BasicSynonyms) {
+ TestCountryNames en_us_names("en_US");
+ EXPECT_EQ("US", en_us_names.GetCountryCode(
+ ASCIIToUTF16("United States of America")));
+ EXPECT_EQ("US", en_us_names.GetCountryCode(ASCIIToUTF16("USA")));
+}
- // Other locales
- EXPECT_EQ("US", CountryNames::GetInstance()->GetCountryCode(
- ASCIIToUTF16("Estados Unidos"), "es"));
- EXPECT_EQ("IT", CountryNames::GetInstance()->GetCountryCode(
- ASCIIToUTF16("Italia"), "it"));
- EXPECT_EQ("DE", CountryNames::GetInstance()->GetCountryCode(
- ASCIIToUTF16("duitsland"), "nl"));
+TEST(CountryNamesTest, GetCountryCode_OtherLocales) {
+ EXPECT_EQ("US", TestCountryNames("es")
+ .GetCountryCode(ASCIIToUTF16("Estados Unidos")));
+ EXPECT_EQ("IT",
+ TestCountryNames("it").GetCountryCode(ASCIIToUTF16("Italia")));
+ EXPECT_EQ("DE",
+ TestCountryNames("nl").GetCountryCode(ASCIIToUTF16("duitsland")));
+}
- // Should fall back to "en_US" locale if all else fails.
- EXPECT_EQ("US", CountryNames::GetInstance()->GetCountryCode(
- ASCIIToUTF16("United States"), "es"));
- EXPECT_EQ("US", CountryNames::GetInstance()->GetCountryCode(
- ASCIIToUTF16("united states"), "es"));
- EXPECT_EQ("US", CountryNames::GetInstance()->GetCountryCode(
- ASCIIToUTF16("USA"), "es"));
+TEST(CountryNamesTest, GetCountryCode_EnUsFallback) {
+ TestCountryNames es_names("es");
+ EXPECT_EQ("US", es_names.GetCountryCode(ASCIIToUTF16("United States")));
+ EXPECT_EQ("US", es_names.GetCountryCode(ASCIIToUTF16("united states")));
+ EXPECT_EQ("US", es_names.GetCountryCode(ASCIIToUTF16("USA")));
}
// Test mapping of empty country name to country code.
TEST(CountryNamesTest, EmptyCountryNameHasEmptyCountryCode) {
std::string country_code =
- CountryNames::GetInstance()->GetCountryCode(base::string16(), "en");
+ TestCountryNames("en").GetCountryCode(base::string16());
EXPECT_TRUE(country_code.empty()) << country_code;
}

Powered by Google App Engine
This is Rietveld 408576698