|  | // Copyright 2014 The Chromium Authors. All rights reserved. | 
|  | // Use of this source code is governed by a BSD-style license that can be | 
|  | // found in the LICENSE file. | 
|  |  | 
|  | #include "components/language_usage_metrics/language_usage_metrics.h" | 
|  |  | 
|  | #include "testing/gtest/include/gtest/gtest.h" | 
|  |  | 
|  | namespace language_usage_metrics { | 
|  |  | 
|  | TEST(LanguageUsageMetricsTest, ParseAcceptLanguages) { | 
|  | std::set<int> language_set; | 
|  | std::set<int>::const_iterator it; | 
|  |  | 
|  | const int ENGLISH = 25966; | 
|  | const int SPANISH = 25971; | 
|  | const int JAPANESE = 27233; | 
|  |  | 
|  | // Basic single language case. | 
|  | LanguageUsageMetrics::ParseAcceptLanguages("ja", &language_set); | 
|  | EXPECT_EQ(1U, language_set.size()); | 
|  | EXPECT_EQ(JAPANESE, *language_set.begin()); | 
|  |  | 
|  | // Empty language. | 
|  | LanguageUsageMetrics::ParseAcceptLanguages(std::string(), &language_set); | 
|  | EXPECT_EQ(0U, language_set.size()); | 
|  |  | 
|  | // Country code is ignored. | 
|  | LanguageUsageMetrics::ParseAcceptLanguages("ja-JP", &language_set); | 
|  | EXPECT_EQ(1U, language_set.size()); | 
|  | EXPECT_EQ(JAPANESE, *language_set.begin()); | 
|  |  | 
|  | // Case is ignored. | 
|  | LanguageUsageMetrics::ParseAcceptLanguages("Ja-jP", &language_set); | 
|  | EXPECT_EQ(1U, language_set.size()); | 
|  | EXPECT_EQ(JAPANESE, *language_set.begin()); | 
|  |  | 
|  | // Underscore as the separator. | 
|  | LanguageUsageMetrics::ParseAcceptLanguages("ja_JP", &language_set); | 
|  | EXPECT_EQ(1U, language_set.size()); | 
|  | EXPECT_EQ(JAPANESE, *language_set.begin()); | 
|  |  | 
|  | // The result contains a same language code only once. | 
|  | LanguageUsageMetrics::ParseAcceptLanguages("ja-JP,ja", &language_set); | 
|  | EXPECT_EQ(1U, language_set.size()); | 
|  | EXPECT_EQ(JAPANESE, *language_set.begin()); | 
|  |  | 
|  | // Basic two languages case. | 
|  | LanguageUsageMetrics::ParseAcceptLanguages("en,ja", &language_set); | 
|  | EXPECT_EQ(2U, language_set.size()); | 
|  | it = language_set.begin(); | 
|  | EXPECT_EQ(ENGLISH, *it); | 
|  | EXPECT_EQ(JAPANESE, *++it); | 
|  |  | 
|  | // Multiple languages. | 
|  | LanguageUsageMetrics::ParseAcceptLanguages("ja-JP,en,es,ja,en-US", | 
|  | &language_set); | 
|  | EXPECT_EQ(3U, language_set.size()); | 
|  | it = language_set.begin(); | 
|  | EXPECT_EQ(ENGLISH, *it); | 
|  | EXPECT_EQ(SPANISH, *++it); | 
|  | EXPECT_EQ(JAPANESE, *++it); | 
|  |  | 
|  | // Two empty languages. | 
|  | LanguageUsageMetrics::ParseAcceptLanguages(",", &language_set); | 
|  | EXPECT_EQ(0U, language_set.size()); | 
|  |  | 
|  | // Trailing comma. | 
|  | LanguageUsageMetrics::ParseAcceptLanguages("ja,", &language_set); | 
|  | EXPECT_EQ(1U, language_set.size()); | 
|  | EXPECT_EQ(JAPANESE, *language_set.begin()); | 
|  |  | 
|  | // Leading comma. | 
|  | LanguageUsageMetrics::ParseAcceptLanguages(",es", &language_set); | 
|  | EXPECT_EQ(1U, language_set.size()); | 
|  | EXPECT_EQ(SPANISH, *language_set.begin()); | 
|  |  | 
|  | // Combination of invalid and valid. | 
|  | LanguageUsageMetrics::ParseAcceptLanguages("1234,en", &language_set); | 
|  | EXPECT_EQ(1U, language_set.size()); | 
|  | it = language_set.begin(); | 
|  | EXPECT_EQ(ENGLISH, *it); | 
|  | } | 
|  |  | 
|  | TEST(LanguageUsageMetricsTest, ToLanguageCode) { | 
|  | const int SPANISH = 25971; | 
|  | const int JAPANESE = 27233; | 
|  |  | 
|  | // Basic case. | 
|  | EXPECT_EQ(JAPANESE, LanguageUsageMetrics::ToLanguageCode("ja")); | 
|  |  | 
|  | // Case is ignored. | 
|  | EXPECT_EQ(SPANISH, LanguageUsageMetrics::ToLanguageCode("Es")); | 
|  |  | 
|  | // Coutry code is ignored. | 
|  | EXPECT_EQ(JAPANESE, LanguageUsageMetrics::ToLanguageCode("ja-JP")); | 
|  |  | 
|  | // Invalid locales are considered as unknown language. | 
|  | EXPECT_EQ(0, LanguageUsageMetrics::ToLanguageCode(std::string())); | 
|  | EXPECT_EQ(0, LanguageUsageMetrics::ToLanguageCode("1234")); | 
|  |  | 
|  | // "xx" is not acceptable because it doesn't exist in ISO 639-1 table. | 
|  | // However, LanguageUsageMetrics doesn't tell what code is valid. | 
|  | EXPECT_EQ(30840, LanguageUsageMetrics::ToLanguageCode("xx")); | 
|  | } | 
|  |  | 
|  | }  // namespace language_usage_metrics |