Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(121)

Unified Diff: chrome/browser/prefs/pref_service_unittest.cc

Issue 5915004: Introduce incognito preference settings. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Whitespaces + fixes for trybot Created 10 years ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: chrome/browser/prefs/pref_service_unittest.cc
diff --git a/chrome/browser/prefs/pref_service_unittest.cc b/chrome/browser/prefs/pref_service_unittest.cc
index 8ada07a47ffb62d04698ed9364c139382248aff0..885e1b94ef33c25fef12b4dabf2e5ac5e6fcba99 100644
--- a/chrome/browser/prefs/pref_service_unittest.cc
+++ b/chrome/browser/prefs/pref_service_unittest.cc
@@ -30,123 +30,149 @@ using testing::Mock;
// TODO(port): port this test to POSIX.
#if defined(OS_WIN)
TEST(PrefServiceTest, LocalizedPrefs) {
- TestingPrefService prefs;
+ scoped_ptr<TestingPrefService> prefs(
+ TestingPrefService::CreateTestingPrefService());
const char kBoolean[] = "boolean";
const char kInteger[] = "integer";
const char kString[] = "string";
- prefs.RegisterLocalizedBooleanPref(kBoolean, IDS_LOCALE_BOOL);
- prefs.RegisterLocalizedIntegerPref(kInteger, IDS_LOCALE_INT);
- prefs.RegisterLocalizedStringPref(kString, IDS_LOCALE_STRING);
+ prefs->RegisterLocalizedBooleanPref(kBoolean, IDS_LOCALE_BOOL);
+ prefs->RegisterLocalizedIntegerPref(kInteger, IDS_LOCALE_INT);
+ prefs->RegisterLocalizedStringPref(kString, IDS_LOCALE_STRING);
// The locale default should take preference over the user default.
- EXPECT_FALSE(prefs.GetBoolean(kBoolean));
- EXPECT_EQ(1, prefs.GetInteger(kInteger));
- EXPECT_EQ("hello", prefs.GetString(kString));
-
- prefs.SetBoolean(kBoolean, true);
- EXPECT_TRUE(prefs.GetBoolean(kBoolean));
- prefs.SetInteger(kInteger, 5);
- EXPECT_EQ(5, prefs.GetInteger(kInteger));
- prefs.SetString(kString, "foo");
- EXPECT_EQ("foo", prefs.GetString(kString));
+ EXPECT_FALSE(prefs->GetBoolean(kBoolean));
+ EXPECT_EQ(1, prefs->GetInteger(kInteger));
+ EXPECT_EQ("hello", prefs->GetString(kString));
+
+ prefs->SetBoolean(kBoolean, true);
+ EXPECT_TRUE(prefs->GetBoolean(kBoolean));
+ prefs->SetInteger(kInteger, 5);
+ EXPECT_EQ(5, prefs->GetInteger(kInteger));
+ prefs->SetString(kString, "foo");
+ EXPECT_EQ("foo", prefs->GetString(kString));
}
#endif
TEST(PrefServiceTest, NoObserverFire) {
- TestingPrefService prefs;
+ scoped_ptr<TestingPrefService> prefs(
+ TestingPrefService::CreateTestingPrefService());
const char pref_name[] = "homepage";
- prefs.RegisterStringPref(pref_name, std::string());
+ prefs->RegisterStringPref(pref_name, std::string());
const char new_pref_value[] = "http://www.google.com/";
PrefObserverMock obs;
PrefChangeRegistrar registrar;
- registrar.Init(&prefs);
+ registrar.Init(prefs.get());
registrar.Add(pref_name, &obs);
// This should fire the checks in PrefObserverMock::Observe.
const StringValue expected_value(new_pref_value);
- obs.Expect(&prefs, pref_name, &expected_value);
- prefs.SetString(pref_name, new_pref_value);
+ obs.Expect(prefs.get(), pref_name, &expected_value);
+ prefs->SetString(pref_name, new_pref_value);
Mock::VerifyAndClearExpectations(&obs);
// Setting the pref to the same value should not set the pref value a second
// time.
EXPECT_CALL(obs, Observe(_, _, _)).Times(0);
- prefs.SetString(pref_name, new_pref_value);
+ prefs->SetString(pref_name, new_pref_value);
Mock::VerifyAndClearExpectations(&obs);
// Clearing the pref should cause the pref to fire.
const StringValue expected_default_value("");
- obs.Expect(&prefs, pref_name, &expected_default_value);
- prefs.ClearPref(pref_name);
+ obs.Expect(prefs.get(), pref_name, &expected_default_value);
+ prefs->ClearPref(pref_name);
Mock::VerifyAndClearExpectations(&obs);
// Clearing the pref again should not cause the pref to fire.
EXPECT_CALL(obs, Observe(_, _, _)).Times(0);
- prefs.ClearPref(pref_name);
+ prefs->ClearPref(pref_name);
Mock::VerifyAndClearExpectations(&obs);
}
TEST(PrefServiceTest, HasPrefPath) {
- TestingPrefService prefs;
+ scoped_ptr<TestingPrefService> prefs(
+ TestingPrefService::CreateTestingPrefService());
const char path[] = "fake.path";
// Shouldn't initially have a path.
- EXPECT_FALSE(prefs.HasPrefPath(path));
+ EXPECT_FALSE(prefs->HasPrefPath(path));
// Register the path. This doesn't set a value, so the path still shouldn't
// exist.
- prefs.RegisterStringPref(path, std::string());
- EXPECT_FALSE(prefs.HasPrefPath(path));
+ prefs->RegisterStringPref(path, std::string());
+ EXPECT_FALSE(prefs->HasPrefPath(path));
// Set a value and make sure we have a path.
- prefs.SetString(path, "blah");
- EXPECT_TRUE(prefs.HasPrefPath(path));
+ prefs->SetString(path, "blah");
+ EXPECT_TRUE(prefs->HasPrefPath(path));
}
TEST(PrefServiceTest, Observers) {
const char pref_name[] = "homepage";
- TestingPrefService prefs;
- prefs.SetUserPref(pref_name, Value::CreateStringValue("http://www.cnn.com"));
- prefs.RegisterStringPref(pref_name, std::string());
+ scoped_ptr<TestingPrefService> prefs(
+ TestingPrefService::CreateTestingPrefService());
+ prefs->SetUserPref(pref_name, Value::CreateStringValue("http://www.cnn.com"));
+ prefs->RegisterStringPref(pref_name, std::string());
const char new_pref_value[] = "http://www.google.com/";
const StringValue expected_new_pref_value(new_pref_value);
PrefObserverMock obs;
PrefChangeRegistrar registrar;
- registrar.Init(&prefs);
+ registrar.Init(prefs.get());
registrar.Add(pref_name, &obs);
// This should fire the checks in PrefObserverMock::Observe.
- obs.Expect(&prefs, pref_name, &expected_new_pref_value);
- prefs.SetString(pref_name, new_pref_value);
+ obs.Expect(prefs.get(), pref_name, &expected_new_pref_value);
+ prefs->SetString(pref_name, new_pref_value);
Mock::VerifyAndClearExpectations(&obs);
// Now try adding a second pref observer.
const char new_pref_value2[] = "http://www.youtube.com/";
const StringValue expected_new_pref_value2(new_pref_value2);
PrefObserverMock obs2;
- obs.Expect(&prefs, pref_name, &expected_new_pref_value2);
- obs2.Expect(&prefs, pref_name, &expected_new_pref_value2);
+ obs.Expect(prefs.get(), pref_name, &expected_new_pref_value2);
+ obs2.Expect(prefs.get(), pref_name, &expected_new_pref_value2);
registrar.Add(pref_name, &obs2);
// This should fire the checks in obs and obs2.
- prefs.SetString(pref_name, new_pref_value2);
+ prefs->SetString(pref_name, new_pref_value2);
Mock::VerifyAndClearExpectations(&obs);
Mock::VerifyAndClearExpectations(&obs2);
// Make sure obs2 still works after removing obs.
registrar.Remove(pref_name, &obs);
EXPECT_CALL(obs, Observe(_, _, _)).Times(0);
- obs2.Expect(&prefs, pref_name, &expected_new_pref_value);
+ obs2.Expect(prefs.get(), pref_name, &expected_new_pref_value);
// This should only fire the observer in obs2.
- prefs.SetString(pref_name, new_pref_value);
+ prefs->SetString(pref_name, new_pref_value);
Mock::VerifyAndClearExpectations(&obs);
Mock::VerifyAndClearExpectations(&obs2);
}
+// Make sure that if a preference changes type, so the wrong type is stored in
+// the user pref file, it uses the correct fallback value instead.
+TEST(PrefServiceTest, GetValueChangedType) {
+ const int kTestValue = 10;
+ scoped_ptr<TestingPrefService> prefs(
+ TestingPrefService::CreateTestingPrefService());
+ prefs->RegisterIntegerPref(prefs::kStabilityLaunchCount, kTestValue);
+
+ // Check falling back to a recommended value.
+ prefs->SetUserPref(prefs::kStabilityLaunchCount,
+ Value::CreateStringValue("not an integer"));
+ const PrefService::Preference* pref =
+ prefs->FindPreference(prefs::kStabilityLaunchCount);
+ ASSERT_TRUE(pref);
+ const Value* value = pref->GetValue();
+ ASSERT_TRUE(value);
+ EXPECT_EQ(Value::TYPE_INTEGER, value->GetType());
+ int actual_int_value = -1;
+ EXPECT_TRUE(value->GetAsInteger(&actual_int_value));
+ EXPECT_EQ(kTestValue, actual_int_value);
+}
+
TEST(PrefServiceTest, ProxyPolicyOverridesCommandLineOptions) {
CommandLine command_line(CommandLine::NO_PROGRAM);
command_line.AppendSwitchASCII(switches::kProxyBypassList, "123");
@@ -304,10 +330,10 @@ class PrefServiceSetValueTest : public testing::Test {
static const char kValue[];
PrefServiceSetValueTest()
- : null_value_(Value::CreateNullValue()) {}
+ : prefs_(TestingPrefService::CreateTestingPrefService()) {
+ }
- TestingPrefService prefs_;
- scoped_ptr<Value> null_value_;
+ scoped_ptr<TestingPrefService> prefs_;
PrefObserverMock observer_;
};
@@ -317,77 +343,75 @@ const char PrefServiceSetValueTest::kValue[] = "value";
TEST_F(PrefServiceSetValueTest, SetStringValue) {
const char default_string[] = "default";
const StringValue default_value(default_string);
- prefs_.RegisterStringPref(kName, default_string);
+ prefs_->RegisterStringPref(kName, default_string);
PrefChangeRegistrar registrar;
- registrar.Init(&prefs_);
+ registrar.Init(prefs_.get());
registrar.Add(kName, &observer_);
// Changing the controlling store from default to user triggers notification.
- observer_.Expect(&prefs_, kName, &default_value);
- prefs_.Set(kName, default_value);
+ observer_.Expect(prefs_.get(), kName, &default_value);
+ prefs_->Set(kName, default_value);
Mock::VerifyAndClearExpectations(&observer_);
EXPECT_CALL(observer_, Observe(_, _, _)).Times(0);
- prefs_.Set(kName, default_value);
+ prefs_->Set(kName, default_value);
Mock::VerifyAndClearExpectations(&observer_);
StringValue new_value(kValue);
- observer_.Expect(&prefs_, kName, &new_value);
- prefs_.Set(kName, new_value);
+ observer_.Expect(prefs_.get(), kName, &new_value);
+ prefs_->Set(kName, new_value);
Mock::VerifyAndClearExpectations(&observer_);
}
TEST_F(PrefServiceSetValueTest, SetDictionaryValue) {
- prefs_.RegisterDictionaryPref(kName);
+ prefs_->RegisterDictionaryPref(kName);
PrefChangeRegistrar registrar;
- registrar.Init(&prefs_);
+ registrar.Init(prefs_.get());
registrar.Add(kName, &observer_);
- // Dictionary values are special: setting one to NULL is the same as clearing
- // the user value, allowing the NULL default to take (or keep) control.
EXPECT_CALL(observer_, Observe(_, _, _)).Times(0);
- prefs_.Set(kName, *null_value_);
+ prefs_->RemoveUserPref(kName);
Mock::VerifyAndClearExpectations(&observer_);
DictionaryValue new_value;
new_value.SetString(kName, kValue);
- observer_.Expect(&prefs_, kName, &new_value);
- prefs_.Set(kName, new_value);
+ observer_.Expect(prefs_.get(), kName, &new_value);
+ prefs_->Set(kName, new_value);
Mock::VerifyAndClearExpectations(&observer_);
EXPECT_CALL(observer_, Observe(_, _, _)).Times(0);
- prefs_.Set(kName, new_value);
+ prefs_->Set(kName, new_value);
Mock::VerifyAndClearExpectations(&observer_);
- observer_.Expect(&prefs_, kName, null_value_.get());
- prefs_.Set(kName, *null_value_);
+ DictionaryValue empty;
+ observer_.Expect(prefs_.get(), kName, &empty);
+ prefs_->Set(kName, empty);
Mock::VerifyAndClearExpectations(&observer_);
}
TEST_F(PrefServiceSetValueTest, SetListValue) {
- prefs_.RegisterListPref(kName);
+ prefs_->RegisterListPref(kName);
PrefChangeRegistrar registrar;
- registrar.Init(&prefs_);
+ registrar.Init(prefs_.get());
registrar.Add(kName, &observer_);
- // List values are special: setting one to NULL is the same as clearing the
- // user value, allowing the NULL default to take (or keep) control.
EXPECT_CALL(observer_, Observe(_, _, _)).Times(0);
- prefs_.Set(kName, *null_value_);
+ prefs_->RemoveUserPref(kName);
Mock::VerifyAndClearExpectations(&observer_);
ListValue new_value;
new_value.Append(Value::CreateStringValue(kValue));
- observer_.Expect(&prefs_, kName, &new_value);
- prefs_.Set(kName, new_value);
+ observer_.Expect(prefs_.get(), kName, &new_value);
+ prefs_->Set(kName, new_value);
Mock::VerifyAndClearExpectations(&observer_);
EXPECT_CALL(observer_, Observe(_, _, _)).Times(0);
- prefs_.Set(kName, new_value);
+ prefs_->Set(kName, new_value);
Mock::VerifyAndClearExpectations(&observer_);
- observer_.Expect(&prefs_, kName, null_value_.get());
- prefs_.Set(kName, *null_value_);
+ ListValue empty;
+ observer_.Expect(prefs_.get(), kName, &empty);
+ prefs_->Set(kName, empty);
Mock::VerifyAndClearExpectations(&observer_);
}

Powered by Google App Engine
This is Rietveld 408576698