[email protected] | d3b05ea | 2012-01-24 22:57:05 | [diff] [blame^] | 1 | // Copyright (c) 2012 The Chromium Authors. All rights reserved. |
license.bot | bf09a50 | 2008-08-24 00:55:55 | [diff] [blame] | 2 | // Use of this source code is governed by a BSD-style license that can be |
| 3 | // found in the LICENSE file. |
initial.commit | 09911bf | 2008-07-26 23:55:29 | [diff] [blame] | 4 | |
[email protected] | ecde274 | 2010-04-02 17:36:18 | [diff] [blame] | 5 | #include <string> |
| 6 | |
[email protected] | ce1850e9 | 2010-10-15 08:40:58 | [diff] [blame] | 7 | #include "base/command_line.h" |
[email protected] | 3b63f8f4 | 2011-03-28 01:54:15 | [diff] [blame] | 8 | #include "base/memory/scoped_ptr.h" |
[email protected] | 1bec237 | 2011-12-07 09:19:06 | [diff] [blame] | 9 | #include "base/utf_string_conversions.h" |
[email protected] | ecde274 | 2010-04-02 17:36:18 | [diff] [blame] | 10 | #include "base/values.h" |
[email protected] | ce1850e9 | 2010-10-15 08:40:58 | [diff] [blame] | 11 | #include "chrome/browser/policy/configuration_policy_pref_store.h" |
| 12 | #include "chrome/browser/policy/mock_configuration_policy_provider.h" |
| 13 | #include "chrome/browser/prefs/browser_prefs.h" |
| 14 | #include "chrome/browser/prefs/command_line_pref_store.h" |
[email protected] | 2fb7dc98 | 2010-09-29 12:24:28 | [diff] [blame] | 15 | #include "chrome/browser/prefs/pref_change_registrar.h" |
[email protected] | acd78969c | 2010-12-08 09:49:11 | [diff] [blame] | 16 | #include "chrome/browser/prefs/pref_observer_mock.h" |
[email protected] | f2d1f61 | 2010-12-09 15:10:17 | [diff] [blame] | 17 | #include "chrome/browser/prefs/pref_service_mock_builder.h" |
[email protected] | 37858e5 | 2010-08-26 00:22:02 | [diff] [blame] | 18 | #include "chrome/browser/prefs/pref_value_store.h" |
[email protected] | f2d1f61 | 2010-12-09 15:10:17 | [diff] [blame] | 19 | #include "chrome/browser/prefs/testing_pref_store.h" |
initial.commit | 09911bf | 2008-07-26 23:55:29 | [diff] [blame] | 20 | #include "chrome/common/chrome_paths.h" |
[email protected] | ce1850e9 | 2010-10-15 08:40:58 | [diff] [blame] | 21 | #include "chrome/common/chrome_switches.h" |
initial.commit | 09911bf | 2008-07-26 23:55:29 | [diff] [blame] | 22 | #include "chrome/common/pref_names.h" |
[email protected] | 1bec237 | 2011-12-07 09:19:06 | [diff] [blame] | 23 | #include "chrome/test/base/chrome_render_view_host_test_harness.h" |
[email protected] | 8ad3636e | 2011-08-01 22:31:40 | [diff] [blame] | 24 | #include "chrome/test/base/testing_pref_service.h" |
[email protected] | 1bec237 | 2011-12-07 09:19:06 | [diff] [blame] | 25 | #include "chrome/test/base/testing_profile.h" |
| 26 | #include "content/browser/tab_contents/test_tab_contents.h" |
| 27 | #include "content/test/test_browser_thread.h" |
[email protected] | ecde274 | 2010-04-02 17:36:18 | [diff] [blame] | 28 | #include "testing/gmock/include/gmock/gmock.h" |
initial.commit | 09911bf | 2008-07-26 23:55:29 | [diff] [blame] | 29 | #include "testing/gtest/include/gtest/gtest.h" |
[email protected] | 41110ca | 2011-06-27 16:45:49 | [diff] [blame] | 30 | #include "ui/base/test/data/resource.h" |
initial.commit | 09911bf | 2008-07-26 23:55:29 | [diff] [blame] | 31 | |
[email protected] | 1bec237 | 2011-12-07 09:19:06 | [diff] [blame] | 32 | using content::BrowserThread; |
[email protected] | ecde274 | 2010-04-02 17:36:18 | [diff] [blame] | 33 | using testing::_; |
| 34 | using testing::Mock; |
[email protected] | 12a3c02 | 2010-11-03 10:24:11 | [diff] [blame] | 35 | |
[email protected] | 277404c2 | 2010-04-22 13:09:45 | [diff] [blame] | 36 | TEST(PrefServiceTest, NoObserverFire) { |
[email protected] | 74379bc5 | 2010-07-21 13:54:08 | [diff] [blame] | 37 | TestingPrefService prefs; |
[email protected] | 7aa0a96 | 2010-04-21 17:24:42 | [diff] [blame] | 38 | |
[email protected] | 57ecc4b | 2010-08-11 03:02:51 | [diff] [blame] | 39 | const char pref_name[] = "homepage"; |
[email protected] | 12a3c02 | 2010-11-03 10:24:11 | [diff] [blame] | 40 | prefs.RegisterStringPref(pref_name, std::string()); |
[email protected] | 7aa0a96 | 2010-04-21 17:24:42 | [diff] [blame] | 41 | |
[email protected] | acd78969c | 2010-12-08 09:49:11 | [diff] [blame] | 42 | const char new_pref_value[] = "http://www.google.com/"; |
| 43 | PrefObserverMock obs; |
[email protected] | 2fb7dc98 | 2010-09-29 12:24:28 | [diff] [blame] | 44 | PrefChangeRegistrar registrar; |
| 45 | registrar.Init(&prefs); |
| 46 | registrar.Add(pref_name, &obs); |
[email protected] | 7aa0a96 | 2010-04-21 17:24:42 | [diff] [blame] | 47 | |
[email protected] | acd78969c | 2010-12-08 09:49:11 | [diff] [blame] | 48 | // This should fire the checks in PrefObserverMock::Observe. |
| 49 | const StringValue expected_value(new_pref_value); |
| 50 | obs.Expect(&prefs, pref_name, &expected_value); |
| 51 | prefs.SetString(pref_name, new_pref_value); |
| 52 | Mock::VerifyAndClearExpectations(&obs); |
[email protected] | 7aa0a96 | 2010-04-21 17:24:42 | [diff] [blame] | 53 | |
| 54 | // Setting the pref to the same value should not set the pref value a second |
| 55 | // time. |
[email protected] | acd78969c | 2010-12-08 09:49:11 | [diff] [blame] | 56 | EXPECT_CALL(obs, Observe(_, _, _)).Times(0); |
[email protected] | 7aa0a96 | 2010-04-21 17:24:42 | [diff] [blame] | 57 | prefs.SetString(pref_name, new_pref_value); |
[email protected] | acd78969c | 2010-12-08 09:49:11 | [diff] [blame] | 58 | Mock::VerifyAndClearExpectations(&obs); |
[email protected] | 7aa0a96 | 2010-04-21 17:24:42 | [diff] [blame] | 59 | |
| 60 | // Clearing the pref should cause the pref to fire. |
[email protected] | acd78969c | 2010-12-08 09:49:11 | [diff] [blame] | 61 | const StringValue expected_default_value(""); |
| 62 | obs.Expect(&prefs, pref_name, &expected_default_value); |
[email protected] | 7aa0a96 | 2010-04-21 17:24:42 | [diff] [blame] | 63 | prefs.ClearPref(pref_name); |
[email protected] | acd78969c | 2010-12-08 09:49:11 | [diff] [blame] | 64 | Mock::VerifyAndClearExpectations(&obs); |
[email protected] | 7aa0a96 | 2010-04-21 17:24:42 | [diff] [blame] | 65 | |
| 66 | // Clearing the pref again should not cause the pref to fire. |
[email protected] | acd78969c | 2010-12-08 09:49:11 | [diff] [blame] | 67 | EXPECT_CALL(obs, Observe(_, _, _)).Times(0); |
[email protected] | 7aa0a96 | 2010-04-21 17:24:42 | [diff] [blame] | 68 | prefs.ClearPref(pref_name); |
[email protected] | acd78969c | 2010-12-08 09:49:11 | [diff] [blame] | 69 | Mock::VerifyAndClearExpectations(&obs); |
[email protected] | 7aa0a96 | 2010-04-21 17:24:42 | [diff] [blame] | 70 | } |
| 71 | |
[email protected] | 277404c2 | 2010-04-22 13:09:45 | [diff] [blame] | 72 | TEST(PrefServiceTest, HasPrefPath) { |
[email protected] | 74379bc5 | 2010-07-21 13:54:08 | [diff] [blame] | 73 | TestingPrefService prefs; |
[email protected] | 7aa0a96 | 2010-04-21 17:24:42 | [diff] [blame] | 74 | |
[email protected] | 57ecc4b | 2010-08-11 03:02:51 | [diff] [blame] | 75 | const char path[] = "fake.path"; |
[email protected] | 7aa0a96 | 2010-04-21 17:24:42 | [diff] [blame] | 76 | |
| 77 | // Shouldn't initially have a path. |
| 78 | EXPECT_FALSE(prefs.HasPrefPath(path)); |
| 79 | |
| 80 | // Register the path. This doesn't set a value, so the path still shouldn't |
| 81 | // exist. |
[email protected] | 20ce516d | 2010-06-18 02:20:04 | [diff] [blame] | 82 | prefs.RegisterStringPref(path, std::string()); |
[email protected] | 7aa0a96 | 2010-04-21 17:24:42 | [diff] [blame] | 83 | EXPECT_FALSE(prefs.HasPrefPath(path)); |
| 84 | |
| 85 | // Set a value and make sure we have a path. |
[email protected] | ddd231e | 2010-06-29 20:35:19 | [diff] [blame] | 86 | prefs.SetString(path, "blah"); |
[email protected] | 7aa0a96 | 2010-04-21 17:24:42 | [diff] [blame] | 87 | EXPECT_TRUE(prefs.HasPrefPath(path)); |
| 88 | } |
| 89 | |
[email protected] | 277404c2 | 2010-04-22 13:09:45 | [diff] [blame] | 90 | TEST(PrefServiceTest, Observers) { |
[email protected] | 57ecc4b | 2010-08-11 03:02:51 | [diff] [blame] | 91 | const char pref_name[] = "homepage"; |
[email protected] | 277404c2 | 2010-04-22 13:09:45 | [diff] [blame] | 92 | |
[email protected] | 74379bc5 | 2010-07-21 13:54:08 | [diff] [blame] | 93 | TestingPrefService prefs; |
[email protected] | 57ecc4b | 2010-08-11 03:02:51 | [diff] [blame] | 94 | prefs.SetUserPref(pref_name, Value::CreateStringValue("http://www.cnn.com")); |
[email protected] | 12a3c02 | 2010-11-03 10:24:11 | [diff] [blame] | 95 | prefs.RegisterStringPref(pref_name, std::string()); |
[email protected] | 277404c2 | 2010-04-22 13:09:45 | [diff] [blame] | 96 | |
[email protected] | acd78969c | 2010-12-08 09:49:11 | [diff] [blame] | 97 | const char new_pref_value[] = "http://www.google.com/"; |
| 98 | const StringValue expected_new_pref_value(new_pref_value); |
| 99 | PrefObserverMock obs; |
[email protected] | 2fb7dc98 | 2010-09-29 12:24:28 | [diff] [blame] | 100 | PrefChangeRegistrar registrar; |
| 101 | registrar.Init(&prefs); |
| 102 | registrar.Add(pref_name, &obs); |
[email protected] | 277404c2 | 2010-04-22 13:09:45 | [diff] [blame] | 103 | |
[email protected] | acd78969c | 2010-12-08 09:49:11 | [diff] [blame] | 104 | // This should fire the checks in PrefObserverMock::Observe. |
| 105 | obs.Expect(&prefs, pref_name, &expected_new_pref_value); |
| 106 | prefs.SetString(pref_name, new_pref_value); |
| 107 | Mock::VerifyAndClearExpectations(&obs); |
[email protected] | 277404c2 | 2010-04-22 13:09:45 | [diff] [blame] | 108 | |
| 109 | // Now try adding a second pref observer. |
[email protected] | acd78969c | 2010-12-08 09:49:11 | [diff] [blame] | 110 | const char new_pref_value2[] = "http://www.youtube.com/"; |
| 111 | const StringValue expected_new_pref_value2(new_pref_value2); |
| 112 | PrefObserverMock obs2; |
| 113 | obs.Expect(&prefs, pref_name, &expected_new_pref_value2); |
| 114 | obs2.Expect(&prefs, pref_name, &expected_new_pref_value2); |
[email protected] | 2fb7dc98 | 2010-09-29 12:24:28 | [diff] [blame] | 115 | registrar.Add(pref_name, &obs2); |
[email protected] | 277404c2 | 2010-04-22 13:09:45 | [diff] [blame] | 116 | // This should fire the checks in obs and obs2. |
| 117 | prefs.SetString(pref_name, new_pref_value2); |
[email protected] | acd78969c | 2010-12-08 09:49:11 | [diff] [blame] | 118 | Mock::VerifyAndClearExpectations(&obs); |
| 119 | Mock::VerifyAndClearExpectations(&obs2); |
[email protected] | 277404c2 | 2010-04-22 13:09:45 | [diff] [blame] | 120 | |
| 121 | // Make sure obs2 still works after removing obs. |
[email protected] | 2fb7dc98 | 2010-09-29 12:24:28 | [diff] [blame] | 122 | registrar.Remove(pref_name, &obs); |
[email protected] | acd78969c | 2010-12-08 09:49:11 | [diff] [blame] | 123 | EXPECT_CALL(obs, Observe(_, _, _)).Times(0); |
| 124 | obs2.Expect(&prefs, pref_name, &expected_new_pref_value); |
[email protected] | 277404c2 | 2010-04-22 13:09:45 | [diff] [blame] | 125 | // This should only fire the observer in obs2. |
| 126 | prefs.SetString(pref_name, new_pref_value); |
[email protected] | acd78969c | 2010-12-08 09:49:11 | [diff] [blame] | 127 | Mock::VerifyAndClearExpectations(&obs); |
| 128 | Mock::VerifyAndClearExpectations(&obs2); |
[email protected] | 277404c2 | 2010-04-22 13:09:45 | [diff] [blame] | 129 | } |
| 130 | |
[email protected] | 9a8c402 | 2011-01-25 14:25:33 | [diff] [blame] | 131 | // Make sure that if a preference changes type, so the wrong type is stored in |
| 132 | // the user pref file, it uses the correct fallback value instead. |
| 133 | TEST(PrefServiceTest, GetValueChangedType) { |
| 134 | const int kTestValue = 10; |
| 135 | TestingPrefService prefs; |
| 136 | prefs.RegisterIntegerPref(prefs::kStabilityLaunchCount, kTestValue); |
| 137 | |
| 138 | // Check falling back to a recommended value. |
| 139 | prefs.SetUserPref(prefs::kStabilityLaunchCount, |
| 140 | Value::CreateStringValue("not an integer")); |
| 141 | const PrefService::Preference* pref = |
| 142 | prefs.FindPreference(prefs::kStabilityLaunchCount); |
| 143 | ASSERT_TRUE(pref); |
| 144 | const Value* value = pref->GetValue(); |
| 145 | ASSERT_TRUE(value); |
| 146 | EXPECT_EQ(Value::TYPE_INTEGER, value->GetType()); |
| 147 | int actual_int_value = -1; |
| 148 | EXPECT_TRUE(value->GetAsInteger(&actual_int_value)); |
| 149 | EXPECT_EQ(kTestValue, actual_int_value); |
| 150 | } |
| 151 | |
[email protected] | d3b05ea | 2012-01-24 22:57:05 | [diff] [blame^] | 152 | TEST(PrefServiceTest, UpdateCommandLinePrefStore) { |
| 153 | TestingPrefService prefs; |
| 154 | prefs.RegisterBooleanPref(prefs::kCloudPrintProxyEnabled, false); |
| 155 | |
| 156 | // Check to make sure the value is as expected. |
| 157 | const PrefService::Preference* pref = |
| 158 | prefs.FindPreference(prefs::kCloudPrintProxyEnabled); |
| 159 | ASSERT_TRUE(pref); |
| 160 | const Value* value = pref->GetValue(); |
| 161 | ASSERT_TRUE(value); |
| 162 | EXPECT_EQ(Value::TYPE_BOOLEAN, value->GetType()); |
| 163 | bool actual_bool_value = true; |
| 164 | EXPECT_TRUE(value->GetAsBoolean(&actual_bool_value)); |
| 165 | EXPECT_EQ(false, actual_bool_value); |
| 166 | |
| 167 | // Change the command line. |
| 168 | CommandLine cmd_line(CommandLine::NO_PROGRAM); |
| 169 | cmd_line.AppendSwitch(switches::kEnableCloudPrintProxy); |
| 170 | |
| 171 | // Call UpdateCommandLinePrefStore and check to see if the value has changed. |
| 172 | prefs.UpdateCommandLinePrefStore(&cmd_line); |
| 173 | pref = prefs.FindPreference(prefs::kCloudPrintProxyEnabled); |
| 174 | ASSERT_TRUE(pref); |
| 175 | value = pref->GetValue(); |
| 176 | ASSERT_TRUE(value); |
| 177 | EXPECT_EQ(Value::TYPE_BOOLEAN, value->GetType()); |
| 178 | actual_bool_value = false; |
| 179 | EXPECT_TRUE(value->GetAsBoolean(&actual_bool_value)); |
| 180 | EXPECT_EQ(true, actual_bool_value); |
| 181 | } |
| 182 | |
[email protected] | ecde274 | 2010-04-02 17:36:18 | [diff] [blame] | 183 | class PrefServiceSetValueTest : public testing::Test { |
| 184 | protected: |
[email protected] | 12a3c02 | 2010-11-03 10:24:11 | [diff] [blame] | 185 | static const char kName[]; |
| 186 | static const char kValue[]; |
[email protected] | ecde274 | 2010-04-02 17:36:18 | [diff] [blame] | 187 | |
[email protected] | 74379bc5 | 2010-07-21 13:54:08 | [diff] [blame] | 188 | TestingPrefService prefs_; |
[email protected] | acd78969c | 2010-12-08 09:49:11 | [diff] [blame] | 189 | PrefObserverMock observer_; |
[email protected] | ecde274 | 2010-04-02 17:36:18 | [diff] [blame] | 190 | }; |
[email protected] | ddd231e | 2010-06-29 20:35:19 | [diff] [blame] | 191 | |
[email protected] | 12a3c02 | 2010-11-03 10:24:11 | [diff] [blame] | 192 | const char PrefServiceSetValueTest::kName[] = "name"; |
| 193 | const char PrefServiceSetValueTest::kValue[] = "value"; |
[email protected] | ecde274 | 2010-04-02 17:36:18 | [diff] [blame] | 194 | |
| 195 | TEST_F(PrefServiceSetValueTest, SetStringValue) { |
[email protected] | 20ce516d | 2010-06-18 02:20:04 | [diff] [blame] | 196 | const char default_string[] = "default"; |
[email protected] | acd78969c | 2010-12-08 09:49:11 | [diff] [blame] | 197 | const StringValue default_value(default_string); |
[email protected] | 12a3c02 | 2010-11-03 10:24:11 | [diff] [blame] | 198 | prefs_.RegisterStringPref(kName, default_string); |
[email protected] | 2fb7dc98 | 2010-09-29 12:24:28 | [diff] [blame] | 199 | |
| 200 | PrefChangeRegistrar registrar; |
| 201 | registrar.Init(&prefs_); |
[email protected] | 12a3c02 | 2010-11-03 10:24:11 | [diff] [blame] | 202 | registrar.Add(kName, &observer_); |
[email protected] | 2fb7dc98 | 2010-09-29 12:24:28 | [diff] [blame] | 203 | |
[email protected] | c3b54f37 | 2010-09-14 08:25:07 | [diff] [blame] | 204 | // Changing the controlling store from default to user triggers notification. |
[email protected] | acd78969c | 2010-12-08 09:49:11 | [diff] [blame] | 205 | observer_.Expect(&prefs_, kName, &default_value); |
| 206 | prefs_.Set(kName, default_value); |
[email protected] | c3b54f37 | 2010-09-14 08:25:07 | [diff] [blame] | 207 | Mock::VerifyAndClearExpectations(&observer_); |
| 208 | |
[email protected] | acd78969c | 2010-12-08 09:49:11 | [diff] [blame] | 209 | EXPECT_CALL(observer_, Observe(_, _, _)).Times(0); |
| 210 | prefs_.Set(kName, default_value); |
[email protected] | ecde274 | 2010-04-02 17:36:18 | [diff] [blame] | 211 | Mock::VerifyAndClearExpectations(&observer_); |
| 212 | |
[email protected] | acd78969c | 2010-12-08 09:49:11 | [diff] [blame] | 213 | StringValue new_value(kValue); |
| 214 | observer_.Expect(&prefs_, kName, &new_value); |
| 215 | prefs_.Set(kName, new_value); |
| 216 | Mock::VerifyAndClearExpectations(&observer_); |
[email protected] | ecde274 | 2010-04-02 17:36:18 | [diff] [blame] | 217 | } |
| 218 | |
| 219 | TEST_F(PrefServiceSetValueTest, SetDictionaryValue) { |
[email protected] | 12a3c02 | 2010-11-03 10:24:11 | [diff] [blame] | 220 | prefs_.RegisterDictionaryPref(kName); |
[email protected] | 2fb7dc98 | 2010-09-29 12:24:28 | [diff] [blame] | 221 | PrefChangeRegistrar registrar; |
| 222 | registrar.Init(&prefs_); |
[email protected] | 12a3c02 | 2010-11-03 10:24:11 | [diff] [blame] | 223 | registrar.Add(kName, &observer_); |
[email protected] | ecde274 | 2010-04-02 17:36:18 | [diff] [blame] | 224 | |
[email protected] | acd78969c | 2010-12-08 09:49:11 | [diff] [blame] | 225 | EXPECT_CALL(observer_, Observe(_, _, _)).Times(0); |
[email protected] | 9a8c402 | 2011-01-25 14:25:33 | [diff] [blame] | 226 | prefs_.RemoveUserPref(kName); |
[email protected] | ecde274 | 2010-04-02 17:36:18 | [diff] [blame] | 227 | Mock::VerifyAndClearExpectations(&observer_); |
| 228 | |
| 229 | DictionaryValue new_value; |
[email protected] | 12a3c02 | 2010-11-03 10:24:11 | [diff] [blame] | 230 | new_value.SetString(kName, kValue); |
[email protected] | acd78969c | 2010-12-08 09:49:11 | [diff] [blame] | 231 | observer_.Expect(&prefs_, kName, &new_value); |
[email protected] | 12a3c02 | 2010-11-03 10:24:11 | [diff] [blame] | 232 | prefs_.Set(kName, new_value); |
[email protected] | ecde274 | 2010-04-02 17:36:18 | [diff] [blame] | 233 | Mock::VerifyAndClearExpectations(&observer_); |
| 234 | |
[email protected] | acd78969c | 2010-12-08 09:49:11 | [diff] [blame] | 235 | EXPECT_CALL(observer_, Observe(_, _, _)).Times(0); |
| 236 | prefs_.Set(kName, new_value); |
| 237 | Mock::VerifyAndClearExpectations(&observer_); |
| 238 | |
[email protected] | 9a8c402 | 2011-01-25 14:25:33 | [diff] [blame] | 239 | DictionaryValue empty; |
| 240 | observer_.Expect(&prefs_, kName, &empty); |
| 241 | prefs_.Set(kName, empty); |
[email protected] | ecde274 | 2010-04-02 17:36:18 | [diff] [blame] | 242 | Mock::VerifyAndClearExpectations(&observer_); |
[email protected] | ecde274 | 2010-04-02 17:36:18 | [diff] [blame] | 243 | } |
| 244 | |
| 245 | TEST_F(PrefServiceSetValueTest, SetListValue) { |
[email protected] | 12a3c02 | 2010-11-03 10:24:11 | [diff] [blame] | 246 | prefs_.RegisterListPref(kName); |
[email protected] | 2fb7dc98 | 2010-09-29 12:24:28 | [diff] [blame] | 247 | PrefChangeRegistrar registrar; |
| 248 | registrar.Init(&prefs_); |
[email protected] | 12a3c02 | 2010-11-03 10:24:11 | [diff] [blame] | 249 | registrar.Add(kName, &observer_); |
[email protected] | ecde274 | 2010-04-02 17:36:18 | [diff] [blame] | 250 | |
[email protected] | acd78969c | 2010-12-08 09:49:11 | [diff] [blame] | 251 | EXPECT_CALL(observer_, Observe(_, _, _)).Times(0); |
[email protected] | 9a8c402 | 2011-01-25 14:25:33 | [diff] [blame] | 252 | prefs_.RemoveUserPref(kName); |
[email protected] | ecde274 | 2010-04-02 17:36:18 | [diff] [blame] | 253 | Mock::VerifyAndClearExpectations(&observer_); |
| 254 | |
| 255 | ListValue new_value; |
[email protected] | 12a3c02 | 2010-11-03 10:24:11 | [diff] [blame] | 256 | new_value.Append(Value::CreateStringValue(kValue)); |
[email protected] | acd78969c | 2010-12-08 09:49:11 | [diff] [blame] | 257 | observer_.Expect(&prefs_, kName, &new_value); |
[email protected] | 12a3c02 | 2010-11-03 10:24:11 | [diff] [blame] | 258 | prefs_.Set(kName, new_value); |
[email protected] | ecde274 | 2010-04-02 17:36:18 | [diff] [blame] | 259 | Mock::VerifyAndClearExpectations(&observer_); |
| 260 | |
[email protected] | acd78969c | 2010-12-08 09:49:11 | [diff] [blame] | 261 | EXPECT_CALL(observer_, Observe(_, _, _)).Times(0); |
| 262 | prefs_.Set(kName, new_value); |
| 263 | Mock::VerifyAndClearExpectations(&observer_); |
| 264 | |
[email protected] | 9a8c402 | 2011-01-25 14:25:33 | [diff] [blame] | 265 | ListValue empty; |
| 266 | observer_.Expect(&prefs_, kName, &empty); |
| 267 | prefs_.Set(kName, empty); |
[email protected] | ecde274 | 2010-04-02 17:36:18 | [diff] [blame] | 268 | Mock::VerifyAndClearExpectations(&observer_); |
[email protected] | ecde274 | 2010-04-02 17:36:18 | [diff] [blame] | 269 | } |
[email protected] | 1bec237 | 2011-12-07 09:19:06 | [diff] [blame] | 270 | |
| 271 | class PrefServiceWebKitPrefs : public ChromeRenderViewHostTestHarness { |
| 272 | protected: |
| 273 | PrefServiceWebKitPrefs() : ui_thread_(BrowserThread::UI, &message_loop_) { |
| 274 | } |
| 275 | |
| 276 | virtual void SetUp() { |
| 277 | ChromeRenderViewHostTestHarness::SetUp(); |
| 278 | |
| 279 | // Supply our own profile so we use the correct profile data. The test |
| 280 | // harness is not supposed to overwrite a profile if it's already created. |
| 281 | |
| 282 | // Set some (WebKit) user preferences. |
| 283 | TestingPrefService* pref_services = profile()->GetTestingPrefService(); |
| 284 | #if defined(TOOLKIT_USES_GTK) |
| 285 | pref_services->SetUserPref(prefs::kUsesSystemTheme, |
| 286 | Value::CreateBooleanValue(false)); |
| 287 | #endif |
[email protected] | 7a5f593 | 2011-12-29 10:35:49 | [diff] [blame] | 288 | pref_services->SetUserPref(prefs::kGlobalDefaultCharset, |
[email protected] | 1bec237 | 2011-12-07 09:19:06 | [diff] [blame] | 289 | Value::CreateStringValue("utf8")); |
[email protected] | 7a5f593 | 2011-12-29 10:35:49 | [diff] [blame] | 290 | pref_services->SetUserPref(prefs::kWebKitGlobalDefaultFontSize, |
[email protected] | 1bec237 | 2011-12-07 09:19:06 | [diff] [blame] | 291 | Value::CreateIntegerValue(20)); |
| 292 | pref_services->SetUserPref(prefs::kWebKitTextAreasAreResizable, |
| 293 | Value::CreateBooleanValue(false)); |
| 294 | pref_services->SetUserPref(prefs::kWebKitUsesUniversalDetector, |
| 295 | Value::CreateBooleanValue(true)); |
| 296 | pref_services->SetUserPref("webkit.webprefs.foo", |
| 297 | Value::CreateStringValue("bar")); |
| 298 | } |
| 299 | |
| 300 | private: |
| 301 | content::TestBrowserThread ui_thread_; |
| 302 | }; |
| 303 | |
| 304 | // Tests to see that webkit preferences are properly loaded and copied over |
| 305 | // to a WebPreferences object. |
| 306 | TEST_F(PrefServiceWebKitPrefs, PrefsCopied) { |
| 307 | WebPreferences webkit_prefs = contents()->TestGetWebkitPrefs(); |
| 308 | |
| 309 | // These values have been overridden by the profile preferences. |
| 310 | EXPECT_EQ("UTF-8", webkit_prefs.default_encoding); |
| 311 | EXPECT_EQ(20, webkit_prefs.default_font_size); |
| 312 | EXPECT_FALSE(webkit_prefs.text_areas_are_resizable); |
| 313 | EXPECT_TRUE(webkit_prefs.uses_universal_detector); |
| 314 | |
| 315 | // These should still be the default values. |
| 316 | #if defined(OS_MACOSX) |
| 317 | const char kDefaultFont[] = "Times"; |
| 318 | #elif defined(OS_CHROMEOS) |
| 319 | const char kDefaultFont[] = "Tinos"; |
| 320 | #else |
| 321 | const char kDefaultFont[] = "Times New Roman"; |
| 322 | #endif |
| 323 | EXPECT_EQ(ASCIIToUTF16(kDefaultFont), webkit_prefs.standard_font_family); |
| 324 | EXPECT_TRUE(webkit_prefs.javascript_enabled); |
| 325 | } |