summaryrefslogtreecommitdiffstats
path: root/chrome/browser/prefs/session_startup_pref_unittest.cc
diff options
context:
space:
mode:
authorgfeher@chromium.org <gfeher@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2010-10-07 15:47:04 +0000
committergfeher@chromium.org <gfeher@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2010-10-07 15:47:04 +0000
commitf9dfa843574d71652860c3fc096b96dbc41b2fcb (patch)
treea9bbe755a8ac1b01770efebdd6e00177e4abb274 /chrome/browser/prefs/session_startup_pref_unittest.cc
parent1a3bf6bfb422cf1e80c6d7ece218750a7b82737e (diff)
downloadchromium_src-f9dfa843574d71652860c3fc096b96dbc41b2fcb.zip
chromium_src-f9dfa843574d71652860c3fc096b96dbc41b2fcb.tar.gz
chromium_src-f9dfa843574d71652860c3fc096b96dbc41b2fcb.tar.bz2
Fix regression of startup URL policy
Make the policy that overrides the list of URLs be effective again, and add a unit test for it. BUG=57997 TEST=SessionStartupPrefUnittest.URLListManagedOverridesUser Review URL: http://codereview.chromium.org/3621008 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@61792 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'chrome/browser/prefs/session_startup_pref_unittest.cc')
-rw-r--r--chrome/browser/prefs/session_startup_pref_unittest.cc58
1 files changed, 58 insertions, 0 deletions
diff --git a/chrome/browser/prefs/session_startup_pref_unittest.cc b/chrome/browser/prefs/session_startup_pref_unittest.cc
new file mode 100644
index 0000000..3732f58
--- /dev/null
+++ b/chrome/browser/prefs/session_startup_pref_unittest.cc
@@ -0,0 +1,58 @@
+// Copyright (c) 2010 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/prefs/session_startup_pref.h"
+#include "chrome/common/pref_names.h"
+#include "chrome/test/testing_pref_service.h"
+#include "testing/gmock/include/gmock/gmock.h"
+#include "testing/gtest/include/gtest/gtest.h"
+
+// Unit tests for SessionStartupPref.
+class SessionStartupPrefTest : public testing::Test {
+ public:
+ virtual void SetUp() {
+ pref_service_.reset(new TestingPrefService);
+ SessionStartupPref::RegisterUserPrefs(pref_service_.get());
+ }
+
+ scoped_ptr<TestingPrefService> pref_service_;
+};
+
+TEST_F(SessionStartupPrefTest, URLListIsFixedUp) {
+ ListValue* url_pref_list = new ListValue;
+ url_pref_list->Set(0, Value::CreateStringValue("google.com"));
+ url_pref_list->Set(1, Value::CreateStringValue("chromium.org"));
+ pref_service_->SetUserPref(prefs::kURLsToRestoreOnStartup, url_pref_list);
+
+ SessionStartupPref result =
+ SessionStartupPref::GetStartupPref(pref_service_.get());
+ EXPECT_EQ(2u, result.urls.size());
+ EXPECT_EQ("http://google.com/", result.urls[0].spec());
+ EXPECT_EQ("http://chromium.org/", result.urls[1].spec());
+}
+
+TEST_F(SessionStartupPrefTest, URLListManagedOverridesUser) {
+ ListValue* url_pref_list1 = new ListValue;
+ url_pref_list1->Set(0, Value::CreateStringValue("chromium.org"));
+ pref_service_->SetUserPref(prefs::kURLsToRestoreOnStartup, url_pref_list1);
+
+ ListValue* url_pref_list2 = new ListValue;
+ url_pref_list2->Set(0, Value::CreateStringValue("chromium.org"));
+ url_pref_list2->Set(1, Value::CreateStringValue("chromium.org"));
+ url_pref_list2->Set(2, Value::CreateStringValue("chromium.org"));
+ pref_service_->SetManagedPref(prefs::kURLsToRestoreOnStartup,
+ url_pref_list2);
+
+ SessionStartupPref result =
+ SessionStartupPref::GetStartupPref(pref_service_.get());
+ EXPECT_EQ(3u, result.urls.size());
+
+ SessionStartupPref override_test =
+ SessionStartupPref::SessionStartupPref(SessionStartupPref::URLS);
+ override_test.urls.push_back(GURL("dev.chromium.org"));
+ SessionStartupPref::SetStartupPref(pref_service_.get(), override_test);
+
+ result = SessionStartupPref::GetStartupPref(pref_service_.get());
+ EXPECT_EQ(3u, result.urls.size());
+}