OLD | NEW |
---|---|
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #include "build/build_config.h" | 5 #include "build/build_config.h" |
6 | 6 |
7 #if defined(OS_POSIX) && !defined(OS_MACOSX) | 7 #if defined(OS_POSIX) && !defined(OS_MACOSX) |
8 #include <cstdlib> | 8 #include <cstdlib> |
9 #endif | 9 #endif |
10 | 10 |
(...skipping 56 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
67 #endif // defined(OS_WIN) | 67 #endif // defined(OS_WIN) |
68 | 68 |
69 #if !defined(OS_MACOSX) | 69 #if !defined(OS_MACOSX) |
70 // We are disabling this test on MacOS because GetApplicationLocale() as an | 70 // We are disabling this test on MacOS because GetApplicationLocale() as an |
71 // API isn't something that we'll easily be able to unit test in this manner. | 71 // API isn't something that we'll easily be able to unit test in this manner. |
72 // The meaning of that API, on the Mac, is "the locale used by Cocoa's main | 72 // The meaning of that API, on the Mac, is "the locale used by Cocoa's main |
73 // nib file", which clearly can't be stubbed by a test app that doesn't use | 73 // nib file", which clearly can't be stubbed by a test app that doesn't use |
74 // Cocoa. | 74 // Cocoa. |
75 | 75 |
76 void SetDefaultLocaleForTest(const std::string& tag, base::Environment* env) { | 76 void SetDefaultLocaleForTest(const std::string& tag, base::Environment* env) { |
77 #if defined(OS_POSIX) && !defined(OS_CHROMEOS) | 77 #if defined(OS_POSIX) && !defined(OS_CHROMEOS) && !defined(OS_ANDROID) |
78 env->SetVar("LANGUAGE", tag); | 78 env->SetVar("LANGUAGE", tag); |
79 #else | 79 #else |
80 base::i18n::SetICUDefaultLocale(tag); | 80 base::i18n::SetICUDefaultLocale(tag); |
81 #endif | 81 #endif |
82 } | 82 } |
83 | 83 |
84 TEST_F(L10nUtilTest, GetAppLocale) { | 84 TEST_F(L10nUtilTest, GetAppLocale) { |
85 scoped_ptr<base::Environment> env; | 85 scoped_ptr<base::Environment> env; |
86 // Use a temporary locale dir so we don't have to actually build the locale | 86 // Use a temporary locale dir so we don't have to actually build the locale |
87 // pak files for this test. | 87 // pak files for this test. |
88 FilePath orig_locale_dir; | 88 FilePath orig_locale_dir; |
89 #if defined(OS_ANDROID) | |
90 // For Android, locale file path uses the directory 'paks' under | |
91 // base::DIR_ANDROID_APP_DATA. See ResourceBundle::GetLocaleFilePath. | |
nilesh
2012/07/25 17:41:50
I think we should modify ui/base/ui_base_paths.cc
| |
92 PathService::Get(base::DIR_ANDROID_APP_DATA, &orig_locale_dir); | |
93 #else | |
89 PathService::Get(ui::DIR_LOCALES, &orig_locale_dir); | 94 PathService::Get(ui::DIR_LOCALES, &orig_locale_dir); |
95 #endif | |
90 FilePath new_locale_dir; | 96 FilePath new_locale_dir; |
91 EXPECT_TRUE(file_util::CreateNewTempDirectory( | 97 EXPECT_TRUE(file_util::CreateNewTempDirectory( |
92 FILE_PATH_LITERAL("l10n_util_test"), | 98 FILE_PATH_LITERAL("l10n_util_test"), |
93 &new_locale_dir)); | 99 &new_locale_dir)); |
100 #if defined(OS_ANDROID) | |
101 PathService::Override(base::DIR_ANDROID_APP_DATA, new_locale_dir); | |
102 // A variable to hold the real directory for locale files | |
103 FilePath locale_paks_dir = new_locale_dir.Append(FILE_PATH_LITERAL("paks")); | |
104 file_util::CreateDirectory(locale_paks_dir); | |
105 #else | |
94 PathService::Override(ui::DIR_LOCALES, new_locale_dir); | 106 PathService::Override(ui::DIR_LOCALES, new_locale_dir); |
107 #endif | |
95 // Make fake locale files. | 108 // Make fake locale files. |
96 std::string filenames[] = { | 109 std::string filenames[] = { |
97 "en-US", | 110 "en-US", |
98 "en-GB", | 111 "en-GB", |
99 "fr", | 112 "fr", |
100 "es-419", | 113 "es-419", |
101 "es", | 114 "es", |
102 "zh-TW", | 115 "zh-TW", |
103 "zh-CN", | 116 "zh-CN", |
104 "he", | 117 "he", |
105 "fil", | 118 "fil", |
106 "nb", | 119 "nb", |
107 "am", | 120 "am", |
108 "ca", | 121 "ca", |
109 "ca@valencia", | 122 "ca@valencia", |
110 }; | 123 }; |
111 | 124 |
112 for (size_t i = 0; i < arraysize(filenames); ++i) { | 125 for (size_t i = 0; i < arraysize(filenames); ++i) { |
126 #if defined(OS_ANDROID) | |
127 FilePath filename = locale_paks_dir.AppendASCII( | |
128 filenames[i] + ".pak"); | |
129 #else | |
113 FilePath filename = new_locale_dir.AppendASCII( | 130 FilePath filename = new_locale_dir.AppendASCII( |
114 filenames[i] + ".pak"); | 131 filenames[i] + ".pak"); |
132 #endif | |
115 file_util::WriteFile(filename, "", 0); | 133 file_util::WriteFile(filename, "", 0); |
116 } | 134 } |
117 | 135 |
118 // Keep a copy of ICU's default locale before we overwrite it. | 136 // Keep a copy of ICU's default locale before we overwrite it. |
119 icu::Locale locale = icu::Locale::getDefault(); | 137 icu::Locale locale = icu::Locale::getDefault(); |
120 | 138 |
121 #if defined(OS_POSIX) && !defined(OS_CHROMEOS) | 139 #if defined(OS_POSIX) && !defined(OS_CHROMEOS) && !defined(OS_ANDROID) |
122 env.reset(base::Environment::Create()); | 140 env.reset(base::Environment::Create()); |
123 | 141 |
124 // Test the support of LANGUAGE environment variable. | 142 // Test the support of LANGUAGE environment variable. |
125 base::i18n::SetICUDefaultLocale("en-US"); | 143 base::i18n::SetICUDefaultLocale("en-US"); |
126 env->SetVar("LANGUAGE", "xx:fr_CA"); | 144 env->SetVar("LANGUAGE", "xx:fr_CA"); |
127 EXPECT_EQ("fr", l10n_util::GetApplicationLocale("")); | 145 EXPECT_EQ("fr", l10n_util::GetApplicationLocale("")); |
128 | 146 |
129 env->SetVar("LANGUAGE", "xx:yy:en_gb.utf-8@quot"); | 147 env->SetVar("LANGUAGE", "xx:yy:en_gb.utf-8@quot"); |
130 EXPECT_EQ("en-GB", l10n_util::GetApplicationLocale("")); | 148 EXPECT_EQ("en-GB", l10n_util::GetApplicationLocale("")); |
131 | 149 |
(...skipping 31 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
163 EXPECT_EQ("ca", l10n_util::GetApplicationLocale("")); | 181 EXPECT_EQ("ca", l10n_util::GetApplicationLocale("")); |
164 | 182 |
165 SetDefaultLocaleForTest("ca@valencia", env.get()); | 183 SetDefaultLocaleForTest("ca@valencia", env.get()); |
166 EXPECT_EQ("ca@valencia", l10n_util::GetApplicationLocale("")); | 184 EXPECT_EQ("ca@valencia", l10n_util::GetApplicationLocale("")); |
167 | 185 |
168 SetDefaultLocaleForTest("ca_ES@valencia", env.get()); | 186 SetDefaultLocaleForTest("ca_ES@valencia", env.get()); |
169 EXPECT_EQ("ca@valencia", l10n_util::GetApplicationLocale("")); | 187 EXPECT_EQ("ca@valencia", l10n_util::GetApplicationLocale("")); |
170 | 188 |
171 SetDefaultLocaleForTest("ca_ES.UTF8@valencia", env.get()); | 189 SetDefaultLocaleForTest("ca_ES.UTF8@valencia", env.get()); |
172 EXPECT_EQ("ca@valencia", l10n_util::GetApplicationLocale("")); | 190 EXPECT_EQ("ca@valencia", l10n_util::GetApplicationLocale("")); |
173 #endif // defined(OS_POSIX) && !defined(OS_CHROMEOS) | 191 #endif // defined(OS_POSIX) && !defined(OS_CHROMEOS) && !defined(OS_ANDROID) |
174 | 192 |
175 SetDefaultLocaleForTest("en-US", env.get()); | 193 SetDefaultLocaleForTest("en-US", env.get()); |
176 EXPECT_EQ("en-US", l10n_util::GetApplicationLocale("")); | 194 EXPECT_EQ("en-US", l10n_util::GetApplicationLocale("")); |
177 | 195 |
178 SetDefaultLocaleForTest("xx", env.get()); | 196 SetDefaultLocaleForTest("xx", env.get()); |
179 EXPECT_EQ("en-US", l10n_util::GetApplicationLocale("")); | 197 EXPECT_EQ("en-US", l10n_util::GetApplicationLocale("")); |
180 | 198 |
181 #if defined(OS_CHROMEOS) | 199 #if defined(OS_CHROMEOS) || defined(OS_ANDROID) |
182 // ChromeOS honors preferred locale first in GetApplicationLocale(), | 200 // ChromeOS and Android honor preferred locale first in |
183 // defaulting to en-US, while other targets first honor other signals. | 201 // GetApplicationLocale(), defaulting to en-US, while other |
202 // targets first honor other signals. | |
184 base::i18n::SetICUDefaultLocale("en-GB"); | 203 base::i18n::SetICUDefaultLocale("en-GB"); |
185 EXPECT_EQ("en-US", l10n_util::GetApplicationLocale("")); | 204 EXPECT_EQ("en-US", l10n_util::GetApplicationLocale("")); |
186 | 205 |
187 base::i18n::SetICUDefaultLocale("en-US"); | 206 base::i18n::SetICUDefaultLocale("en-US"); |
188 EXPECT_EQ("en-GB", l10n_util::GetApplicationLocale("en-GB")); | 207 EXPECT_EQ("en-GB", l10n_util::GetApplicationLocale("en-GB")); |
189 | 208 |
190 base::i18n::SetICUDefaultLocale("en-US"); | 209 base::i18n::SetICUDefaultLocale("en-US"); |
191 EXPECT_EQ("en-GB", l10n_util::GetApplicationLocale("en-AU")); | 210 EXPECT_EQ("en-GB", l10n_util::GetApplicationLocale("en-AU")); |
192 | 211 |
193 base::i18n::SetICUDefaultLocale("en-US"); | 212 base::i18n::SetICUDefaultLocale("en-US"); |
194 EXPECT_EQ("en-GB", l10n_util::GetApplicationLocale("en-NZ")); | 213 EXPECT_EQ("en-GB", l10n_util::GetApplicationLocale("en-NZ")); |
195 | 214 |
196 base::i18n::SetICUDefaultLocale("en-US"); | 215 base::i18n::SetICUDefaultLocale("en-US"); |
197 EXPECT_EQ("en-GB", l10n_util::GetApplicationLocale("en-CA")); | 216 EXPECT_EQ("en-GB", l10n_util::GetApplicationLocale("en-CA")); |
198 | 217 |
199 base::i18n::SetICUDefaultLocale("en-US"); | 218 base::i18n::SetICUDefaultLocale("en-US"); |
200 EXPECT_EQ("en-GB", l10n_util::GetApplicationLocale("en-ZA")); | 219 EXPECT_EQ("en-GB", l10n_util::GetApplicationLocale("en-ZA")); |
201 #else // defined(OS_CHROMEOS) | 220 #else // !defined(OS_CHROMEOS) && !defined(OS_ANDROID) |
202 SetDefaultLocaleForTest("en-GB", env.get()); | 221 SetDefaultLocaleForTest("en-GB", env.get()); |
203 EXPECT_EQ("en-GB", l10n_util::GetApplicationLocale("")); | 222 EXPECT_EQ("en-GB", l10n_util::GetApplicationLocale("")); |
204 | 223 |
205 SetDefaultLocaleForTest("fr-CA", env.get()); | 224 SetDefaultLocaleForTest("fr-CA", env.get()); |
206 EXPECT_EQ("fr", l10n_util::GetApplicationLocale("")); | 225 EXPECT_EQ("fr", l10n_util::GetApplicationLocale("")); |
207 | 226 |
208 SetDefaultLocaleForTest("es-MX", env.get()); | 227 SetDefaultLocaleForTest("es-MX", env.get()); |
209 EXPECT_EQ("es-419", l10n_util::GetApplicationLocale("")); | 228 EXPECT_EQ("es-419", l10n_util::GetApplicationLocale("")); |
210 | 229 |
211 SetDefaultLocaleForTest("es-AR", env.get()); | 230 SetDefaultLocaleForTest("es-AR", env.get()); |
(...skipping 18 matching lines...) Expand all Loading... | |
230 EXPECT_EQ("en-GB", l10n_util::GetApplicationLocale("")); | 249 EXPECT_EQ("en-GB", l10n_util::GetApplicationLocale("")); |
231 | 250 |
232 SetDefaultLocaleForTest("en-AU", env.get()); | 251 SetDefaultLocaleForTest("en-AU", env.get()); |
233 EXPECT_EQ("en-GB", l10n_util::GetApplicationLocale("")); | 252 EXPECT_EQ("en-GB", l10n_util::GetApplicationLocale("")); |
234 | 253 |
235 SetDefaultLocaleForTest("en-NZ", env.get()); | 254 SetDefaultLocaleForTest("en-NZ", env.get()); |
236 EXPECT_EQ("en-GB", l10n_util::GetApplicationLocale("")); | 255 EXPECT_EQ("en-GB", l10n_util::GetApplicationLocale("")); |
237 | 256 |
238 SetDefaultLocaleForTest("en-ZA", env.get()); | 257 SetDefaultLocaleForTest("en-ZA", env.get()); |
239 EXPECT_EQ("en-GB", l10n_util::GetApplicationLocale("")); | 258 EXPECT_EQ("en-GB", l10n_util::GetApplicationLocale("")); |
240 #endif // defined (OS_CHROMEOS) | 259 #endif // defined (OS_CHROMEOS) || defined(OS_ANDROID) |
241 | 260 |
242 #if defined(OS_WIN) | 261 #if defined(OS_WIN) |
243 // We don't allow user prefs for locale on linux/mac. | 262 // We don't allow user prefs for locale on linux/mac. |
244 base::i18n::SetICUDefaultLocale("en-US"); | 263 base::i18n::SetICUDefaultLocale("en-US"); |
245 EXPECT_EQ("fr", l10n_util::GetApplicationLocale("fr")); | 264 EXPECT_EQ("fr", l10n_util::GetApplicationLocale("fr")); |
246 EXPECT_EQ("fr", l10n_util::GetApplicationLocale("fr-CA")); | 265 EXPECT_EQ("fr", l10n_util::GetApplicationLocale("fr-CA")); |
247 | 266 |
248 base::i18n::SetICUDefaultLocale("en-US"); | 267 base::i18n::SetICUDefaultLocale("en-US"); |
249 // Aliases iw, no, tl to he, nb, fil. | 268 // Aliases iw, no, tl to he, nb, fil. |
250 EXPECT_EQ("he", l10n_util::GetApplicationLocale("iw")); | 269 EXPECT_EQ("he", l10n_util::GetApplicationLocale("iw")); |
(...skipping 22 matching lines...) Expand all Loading... | |
273 EXPECT_EQ("en-GB", l10n_util::GetApplicationLocale("am")); | 292 EXPECT_EQ("en-GB", l10n_util::GetApplicationLocale("am")); |
274 } else { | 293 } else { |
275 base::i18n::SetICUDefaultLocale("am"); | 294 base::i18n::SetICUDefaultLocale("am"); |
276 EXPECT_EQ("am", l10n_util::GetApplicationLocale("")); | 295 EXPECT_EQ("am", l10n_util::GetApplicationLocale("")); |
277 base::i18n::SetICUDefaultLocale("en-GB"); | 296 base::i18n::SetICUDefaultLocale("en-GB"); |
278 EXPECT_EQ("am", l10n_util::GetApplicationLocale("am")); | 297 EXPECT_EQ("am", l10n_util::GetApplicationLocale("am")); |
279 } | 298 } |
280 #endif // defined(OS_WIN) | 299 #endif // defined(OS_WIN) |
281 | 300 |
282 // Clean up. | 301 // Clean up. |
302 #if defined(OS_ANDROID) | |
303 PathService::Override(base::DIR_ANDROID_APP_DATA, orig_locale_dir); | |
304 #else | |
283 PathService::Override(ui::DIR_LOCALES, orig_locale_dir); | 305 PathService::Override(ui::DIR_LOCALES, orig_locale_dir); |
306 #endif | |
284 file_util::Delete(new_locale_dir, true); | 307 file_util::Delete(new_locale_dir, true); |
285 UErrorCode error_code = U_ZERO_ERROR; | 308 UErrorCode error_code = U_ZERO_ERROR; |
286 icu::Locale::setDefault(locale, error_code); | 309 icu::Locale::setDefault(locale, error_code); |
287 } | 310 } |
288 #endif // !defined(OS_MACOSX) | 311 #endif // !defined(OS_MACOSX) |
289 | 312 |
290 TEST_F(L10nUtilTest, SortStringsUsingFunction) { | 313 TEST_F(L10nUtilTest, SortStringsUsingFunction) { |
291 std::vector<StringWrapper*> strings; | 314 std::vector<StringWrapper*> strings; |
292 strings.push_back(new StringWrapper(UTF8ToUTF16("C"))); | 315 strings.push_back(new StringWrapper(UTF8ToUTF16("C"))); |
293 strings.push_back(new StringWrapper(UTF8ToUTF16("d"))); | 316 strings.push_back(new StringWrapper(UTF8ToUTF16("d"))); |
(...skipping 115 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
409 EXPECT_FALSE(l10n_util::IsValidLocaleSyntax("Latin")); | 432 EXPECT_FALSE(l10n_util::IsValidLocaleSyntax("Latin")); |
410 EXPECT_FALSE(l10n_util::IsValidLocaleSyntax("German")); | 433 EXPECT_FALSE(l10n_util::IsValidLocaleSyntax("German")); |
411 EXPECT_FALSE(l10n_util::IsValidLocaleSyntax("pt--BR")); | 434 EXPECT_FALSE(l10n_util::IsValidLocaleSyntax("pt--BR")); |
412 EXPECT_FALSE(l10n_util::IsValidLocaleSyntax("sl-macedonia")); | 435 EXPECT_FALSE(l10n_util::IsValidLocaleSyntax("sl-macedonia")); |
413 EXPECT_FALSE(l10n_util::IsValidLocaleSyntax("@")); | 436 EXPECT_FALSE(l10n_util::IsValidLocaleSyntax("@")); |
414 EXPECT_FALSE(l10n_util::IsValidLocaleSyntax("en-US@")); | 437 EXPECT_FALSE(l10n_util::IsValidLocaleSyntax("en-US@")); |
415 EXPECT_FALSE(l10n_util::IsValidLocaleSyntax("en-US@x")); | 438 EXPECT_FALSE(l10n_util::IsValidLocaleSyntax("en-US@x")); |
416 EXPECT_FALSE(l10n_util::IsValidLocaleSyntax("en-US@x=")); | 439 EXPECT_FALSE(l10n_util::IsValidLocaleSyntax("en-US@x=")); |
417 EXPECT_FALSE(l10n_util::IsValidLocaleSyntax("en-US@=y")); | 440 EXPECT_FALSE(l10n_util::IsValidLocaleSyntax("en-US@=y")); |
418 } | 441 } |
OLD | NEW |