diff options
| author | gfeher@chromium.org <gfeher@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2010-10-07 15:47:04 +0000 |
|---|---|---|
| committer | gfeher@chromium.org <gfeher@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2010-10-07 15:47:04 +0000 |
| commit | f9dfa843574d71652860c3fc096b96dbc41b2fcb (patch) | |
| tree | a9bbe755a8ac1b01770efebdd6e00177e4abb274 /chrome/browser/prefs/session_startup_pref_unittest.cc | |
| parent | 1a3bf6bfb422cf1e80c6d7ece218750a7b82737e (diff) | |
| download | chromium_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.cc | 58 |
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()); +} |
