Index: chrome/browser/android/preferences/pref_service_bridge_unittest.cc |
diff --git a/chrome/browser/android/preferences/pref_service_bridge_unittest.cc b/chrome/browser/android/preferences/pref_service_bridge_unittest.cc |
new file mode 100644 |
index 0000000000000000000000000000000000000000..e73e7ee50a8440c9ff3de650fc41e3e2edb2433a |
--- /dev/null |
+++ b/chrome/browser/android/preferences/pref_service_bridge_unittest.cc |
@@ -0,0 +1,48 @@ |
+// 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 "chrome/browser/android/preferences/pref_service_bridge.h" |
+ |
+#include <string> |
+ |
+#include "testing/gtest/include/gtest/gtest.h" |
+ |
+ |
+// A test class for PrefServiceBridge class. |
+class PrefServiceBridgeTest : public testing::Test { |
+ public: |
+ std::string GetAcceptLanguages(std::string locale, |
+ std::string accept_languages) { |
+ PrependToAcceptLanguagesIfNecessary(locale, &accept_languages); |
+ return accept_languages; |
+ } |
+}; |
+ |
+TEST_F(PrefServiceBridgeTest, PrependToAcceptLanguagesAsNecessary) { |
Ted C
2014/10/21 16:57:21
ah ha...for testing. gotcha
Yaron
2014/10/21 17:40:14
Acknowledged.
|
+ EXPECT_EQ("ms-MY,ms,en-US,en", GetAcceptLanguages("ms_MY", "en-US,en")); |
+ |
+ EXPECT_EQ("de-CH,de-DE,de,en-US,en", |
+ GetAcceptLanguages("de_CH", "de-DE,de,en-US,en")); |
+ |
+ // Make sure we do not prepend language code even when a language code is at |
+ // the end. |
+ EXPECT_EQ("zh-TW,zh-CN,zh", GetAcceptLanguages("zh_TW", "zh-CN,zh")); |
+} |
+ |
+TEST_F(PrefServiceBridgeTest, |
+ ShouldNotPrependToAcceptLanguagesWhenNotNecessary) { |
+ // Java has some deprecated two letter language code. For instance, "iw" is |
+ // an old code that needs to be replaced by "he" which is the new code for |
+ // Hebrew. |
+ EXPECT_EQ("he-IL,he,en-US,en", |
+ GetAcceptLanguages("iw_IL", "he-IL,he,en-US,en")); |
+ |
+ // This logic should not affect cases where original accept language already |
+ // reflects the language code in the locale. |
+ EXPECT_EQ("en-US,en", GetAcceptLanguages("en_US", "en-US,en")); |
+ EXPECT_EQ("zh-CN,zh", GetAcceptLanguages("zh_CN", "zh-CN,zh")); |
+ |
+ // "ms" is not expected. No replacement takes place. |
+ EXPECT_EQ("en-US,en", GetAcceptLanguages("ms", "en-US,en")); |
+} |