OLD | NEW |
---|---|
1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 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 "components/translate/core/browser/translate_prefs.h" | 5 #include "components/translate/core/browser/translate_prefs.h" |
6 | 6 |
7 #include <algorithm> | 7 #include <algorithm> |
8 #include <string> | 8 #include <string> |
9 #include <utility> | 9 #include <utility> |
10 #include <vector> | 10 #include <vector> |
11 | 11 |
12 #include "base/json/json_reader.h" | 12 #include "base/json/json_reader.h" |
13 #include "base/test/scoped_feature_list.h" | 13 #include "base/test/scoped_feature_list.h" |
14 #include "base/values.h" | 14 #include "base/values.h" |
15 #include "build/build_config.h" | 15 #include "build/build_config.h" |
16 #include "components/prefs/scoped_user_pref_update.h" | 16 #include "components/prefs/scoped_user_pref_update.h" |
17 #include "components/sync_preferences/testing_pref_service_syncable.h" | 17 #include "components/sync_preferences/testing_pref_service_syncable.h" |
18 #include "components/translate/core/browser/translate_download_manager.h" | 18 #include "components/translate/core/browser/translate_download_manager.h" |
19 #include "components/translate/core/browser/translate_prefs.h" | 19 #include "components/translate/core/browser/translate_prefs.h" |
20 #include "testing/gtest/include/gtest/gtest.h" | 20 #include "testing/gtest/include/gtest/gtest.h" |
21 | 21 |
22 namespace { | 22 namespace { |
23 | 23 |
24 const char kTestLanguage[] = "en"; | 24 const char kTestLanguage[] = "en"; |
25 | 25 |
26 #if defined(OS_CHROMEOS) | |
groby-ooo-7-16
2017/03/08 00:49:15
If you're refactoring this anyways - could you fac
Matt Giuca
2017/03/15 02:45:18
Hmm, I had a bit of a think about it but it's not
| |
27 const char kPreferredLanguagesPref[] = "settings.language.preferred_languages"; | |
28 #else | |
29 const char* kPreferredLanguagesPref = nullptr; | |
30 #endif | |
31 const char kAcceptLanguagesPref[] = "intl.accept_languages"; | |
32 | |
26 } // namespace | 33 } // namespace |
27 | 34 |
28 namespace translate { | 35 namespace translate { |
29 | 36 |
30 class TranslatePrefTest : public testing::Test { | 37 class TranslatePrefTest : public testing::Test { |
31 protected: | 38 protected: |
32 TranslatePrefTest() | 39 TranslatePrefTest() |
33 : prefs_(new sync_preferences::TestingPrefServiceSyncable()) { | 40 : prefs_(new sync_preferences::TestingPrefServiceSyncable()) { |
34 #if defined(OS_CHROMEOS) | |
35 const char* preferred_languages_prefs = | |
36 "settings.language.preferred_languages"; | |
37 #else | |
38 const char* preferred_languages_prefs = NULL; | |
39 #endif | |
40 translate_prefs_.reset(new translate::TranslatePrefs( | 41 translate_prefs_.reset(new translate::TranslatePrefs( |
41 prefs_.get(), "intl.accept_languages", preferred_languages_prefs)); | 42 prefs_.get(), kAcceptLanguagesPref, kPreferredLanguagesPref)); |
42 TranslatePrefs::RegisterProfilePrefs(prefs_->registry()); | 43 TranslatePrefs::RegisterProfilePrefs(prefs_->registry()); |
43 now_ = base::Time::Now(); | 44 now_ = base::Time::Now(); |
44 two_days_ago_ = now_ - base::TimeDelta::FromDays(2); | 45 two_days_ago_ = now_ - base::TimeDelta::FromDays(2); |
45 } | 46 } |
46 | 47 |
48 void SetUp() override { | |
49 prefs_->registry()->RegisterStringPref(kAcceptLanguagesPref, std::string()); | |
50 #if defined(OS_CHROMEOS) | |
51 prefs_->registry()->RegisterStringPref(kPreferredLanguagesPref, | |
groby-ooo-7-16
2017/03/08 00:49:15
I'd really like to break the defined(OS_CHROMEOS)
Matt Giuca
2017/03/15 02:45:18
Done.
Matt Giuca
2017/03/15 07:45:14
Undone... unfortunately I get this compile error o
| |
52 std::string()); | |
53 #endif | |
54 } | |
55 | |
47 void SetLastDeniedTime(const std::string& language, base::Time time) { | 56 void SetLastDeniedTime(const std::string& language, base::Time time) { |
48 DenialTimeUpdate update(prefs_.get(), language, 2); | 57 DenialTimeUpdate update(prefs_.get(), language, 2); |
49 update.AddDenialTime(time); | 58 update.AddDenialTime(time); |
50 } | 59 } |
51 | 60 |
52 base::Time GetLastDeniedTime(const std::string& language) { | 61 base::Time GetLastDeniedTime(const std::string& language) { |
53 DenialTimeUpdate update(prefs_.get(), language, 2); | 62 DenialTimeUpdate update(prefs_.get(), language, 2); |
54 return update.GetOldestDenialTime(); | 63 return update.GetOldestDenialTime(); |
55 } | 64 } |
56 | 65 |
(...skipping 148 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
205 | 214 |
206 update.AddDenialTime(now_); | 215 update.AddDenialTime(now_); |
207 EXPECT_EQ(update.GetOldestDenialTime(), | 216 EXPECT_EQ(update.GetOldestDenialTime(), |
208 now_ - base::TimeDelta::FromMinutes(3)); | 217 now_ - base::TimeDelta::FromMinutes(3)); |
209 | 218 |
210 update.AddDenialTime(now_); | 219 update.AddDenialTime(now_); |
211 EXPECT_EQ(update.GetOldestDenialTime(), | 220 EXPECT_EQ(update.GetOldestDenialTime(), |
212 now_ - base::TimeDelta::FromMinutes(2)); | 221 now_ - base::TimeDelta::FromMinutes(2)); |
213 } | 222 } |
214 | 223 |
224 TEST_F(TranslatePrefTest, UpdateLanguageList) { | |
225 // Test with basic set of languages (no country codes). | |
226 std::vector<std::string> languages{"en", "ja"}; | |
227 translate_prefs_->UpdateLanguageList(languages); | |
228 EXPECT_EQ("en,ja", prefs_->GetString(kAcceptLanguagesPref)); | |
229 | |
230 // Test with languages that have country codes. Expect accepted languages both | |
231 // with and without a country code. (See documentation for | |
232 // ExpandLanguageCodes.) | |
233 languages = {"en-US", "ja", "en-CA"}; | |
234 translate_prefs_->UpdateLanguageList(languages); | |
235 #if defined(OS_CHROMEOS) | |
236 EXPECT_EQ("en-US,ja,en-CA", prefs_->GetString(kPreferredLanguagesPref)); | |
237 #endif | |
238 EXPECT_EQ("en-US,en,ja,en-CA", prefs_->GetString(kAcceptLanguagesPref)); | |
239 } | |
240 | |
215 TEST_F(TranslatePrefTest, ULPPrefs) { | 241 TEST_F(TranslatePrefTest, ULPPrefs) { |
216 // Mock the pref. | 242 // Mock the pref. |
217 // Case 1: well formed ULP. | 243 // Case 1: well formed ULP. |
218 const char json1[] = | 244 const char json1[] = |
219 "{\n" | 245 "{\n" |
220 " \"reading\": {\n" | 246 " \"reading\": {\n" |
221 " \"confidence\": 0.8,\n" | 247 " \"confidence\": 0.8,\n" |
222 " \"preference\": [\n" | 248 " \"preference\": [\n" |
223 " {\n" | 249 " {\n" |
224 " \"language\": \"en-AU\",\n" | 250 " \"language\": \"en-AU\",\n" |
(...skipping 106 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
331 EXPECT_EQ(0.8, translate_prefs_->GetReadingFromUserLanguageProfile(&list)); | 357 EXPECT_EQ(0.8, translate_prefs_->GetReadingFromUserLanguageProfile(&list)); |
332 EXPECT_EQ(2UL, list.size()); | 358 EXPECT_EQ(2UL, list.size()); |
333 EXPECT_EQ("en", list[0].first); // en-US and en-GB will be normalize into en | 359 EXPECT_EQ("en", list[0].first); // en-US and en-GB will be normalize into en |
334 EXPECT_EQ(0.6, | 360 EXPECT_EQ(0.6, |
335 list[0].second); // and their probability will add to gether be 0.6 | 361 list[0].second); // and their probability will add to gether be 0.6 |
336 EXPECT_EQ("fr", list[1].first); // fr will move down to the 2nd one | 362 EXPECT_EQ("fr", list[1].first); // fr will move down to the 2nd one |
337 EXPECT_EQ(0.4, list[1].second); | 363 EXPECT_EQ(0.4, list[1].second); |
338 } | 364 } |
339 | 365 |
340 } // namespace translate | 366 } // namespace translate |
OLD | NEW |