| OLD | NEW |
| 1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2011 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 "chrome/common/pref_names.h" | 5 #include "chrome/common/pref_names.h" |
| 6 #include "chrome/browser/prefs/pref_service.h" | 6 #include "chrome/browser/prefs/pref_service.h" |
| 7 #include "chrome/browser/ui/tab_contents/per_tab_prefs_tab_helper.h" | 7 #include "chrome/browser/ui/prefs/prefs_tab_helper.h" |
| 8 #include "chrome/browser/ui/tab_contents/tab_contents_wrapper.h" | 8 #include "chrome/browser/ui/tab_contents/tab_contents_wrapper.h" |
| 9 #include "chrome/browser/ui/tab_contents/test_tab_contents_wrapper.h" | 9 #include "chrome/browser/ui/tab_contents/test_tab_contents_wrapper.h" |
| 10 #include "content/browser/tab_contents/test_tab_contents.h" | 10 #include "content/browser/tab_contents/test_tab_contents.h" |
| 11 #include "content/test/test_browser_thread.h" | 11 #include "content/test/test_browser_thread.h" |
| 12 | 12 |
| 13 using content::BrowserThread; | 13 using content::BrowserThread; |
| 14 | 14 |
| 15 class TestPerTabPrefsTabHelper : public PerTabPrefsTabHelper { | 15 class TestPrefsTabHelper : public PrefsTabHelper { |
| 16 public: | 16 public: |
| 17 explicit TestPerTabPrefsTabHelper(TabContentsWrapper* tab_contents) | 17 explicit TestPrefsTabHelper(TabContentsWrapper* tab_contents) |
| 18 : PerTabPrefsTabHelper(tab_contents), | 18 : PrefsTabHelper(tab_contents), |
| 19 was_override_web_prefernces_called_(false) { | 19 was_update_web_preferences_called_(false) { |
| 20 } | 20 } |
| 21 virtual ~TestPerTabPrefsTabHelper() { } | 21 virtual ~TestPrefsTabHelper() { } |
| 22 | 22 |
| 23 virtual void OverrideWebPreferences(WebPreferences* prefs) OVERRIDE { | 23 virtual void UpdateWebPreferences() OVERRIDE { |
| 24 was_override_web_prefernces_called_ = true; | 24 was_update_web_preferences_called_ = true; |
| 25 PerTabPrefsTabHelper::OverrideWebPreferences(prefs); | 25 PrefsTabHelper::UpdateWebPreferences(); |
| 26 } | 26 } |
| 27 | 27 |
| 28 void NotifyRenderViewCreated() { | 28 void NotifyRenderViewCreated() { |
| 29 RenderViewCreated(NULL); | 29 RenderViewCreated(NULL); |
| 30 } | 30 } |
| 31 | 31 |
| 32 bool was_override_web_prefernces_called() { | 32 bool was_update_web_preferences_called() { |
| 33 return was_override_web_prefernces_called_; | 33 return was_update_web_preferences_called_; |
| 34 } | 34 } |
| 35 | 35 |
| 36 private: | 36 private: |
| 37 bool was_override_web_prefernces_called_; | 37 bool was_update_web_preferences_called_; |
| 38 }; | 38 }; |
| 39 | 39 |
| 40 class PerTabPrefsTabHelperTest : public TabContentsWrapperTestHarness { | 40 class PrefsTabHelperTest : public TabContentsWrapperTestHarness { |
| 41 public: | 41 public: |
| 42 PerTabPrefsTabHelperTest() | 42 PrefsTabHelperTest() |
| 43 : TabContentsWrapperTestHarness(), | 43 : TabContentsWrapperTestHarness(), |
| 44 ui_thread_(BrowserThread::UI, &message_loop_) {} | 44 ui_thread_(BrowserThread::UI, &message_loop_) {} |
| 45 | 45 |
| 46 virtual ~PerTabPrefsTabHelperTest() {} | 46 virtual ~PrefsTabHelperTest() {} |
| 47 | 47 |
| 48 TabContentsWrapper* contents_wrapper2() { | 48 TabContentsWrapper* contents_wrapper2() { |
| 49 return contents_wrapper2_.get(); | 49 return contents_wrapper2_.get(); |
| 50 } | 50 } |
| 51 | 51 |
| 52 void SetContents2(TestTabContents* contents) { | 52 void SetContents2(TestTabContents* contents) { |
| 53 contents_wrapper2_.reset( | 53 contents_wrapper2_.reset( |
| 54 contents ? new TabContentsWrapper(contents) : NULL); | 54 contents ? new TabContentsWrapper(contents) : NULL); |
| 55 } | 55 } |
| 56 | 56 |
| 57 protected: | 57 protected: |
| 58 virtual void SetUp() OVERRIDE { | 58 virtual void SetUp() OVERRIDE { |
| 59 TabContentsWrapperTestHarness::SetUp(); | 59 TabContentsWrapperTestHarness::SetUp(); |
| 60 SetContents2(CreateTestTabContents()); | 60 SetContents2(CreateTestTabContents()); |
| 61 } | 61 } |
| 62 | 62 |
| 63 virtual void TearDown() OVERRIDE { | 63 virtual void TearDown() OVERRIDE { |
| 64 contents_wrapper2_.reset(); | 64 contents_wrapper2_.reset(); |
| 65 TabContentsWrapperTestHarness::TearDown(); | 65 TabContentsWrapperTestHarness::TearDown(); |
| 66 } | 66 } |
| 67 | 67 |
| 68 private: | 68 private: |
| 69 content::TestBrowserThread ui_thread_; | 69 content::TestBrowserThread ui_thread_; |
| 70 scoped_ptr<TabContentsWrapper> contents_wrapper2_; | 70 scoped_ptr<TabContentsWrapper> contents_wrapper2_; |
| 71 | 71 |
| 72 DISALLOW_COPY_AND_ASSIGN(PerTabPrefsTabHelperTest); | 72 DISALLOW_COPY_AND_ASSIGN(PrefsTabHelperTest); |
| 73 }; | 73 }; |
| 74 | 74 |
| 75 TEST_F(PerTabPrefsTabHelperTest, PerTabJavaScriptEnabled) { | 75 TEST_F(PrefsTabHelperTest, PerTabJavaScriptEnabled) { |
| 76 const char* key = prefs::kWebKitJavascriptEnabled; | 76 const char* key = prefs::kWebKitJavascriptEnabled; |
| 77 PrefService* prefs1 = contents_wrapper()->per_tab_prefs_tab_helper()->prefs(); | 77 PrefService* prefs1 = contents_wrapper()->prefs_tab_helper()->per_tab_prefs(); |
| 78 PrefService* prefs2 = | 78 PrefService* prefs2 = |
| 79 contents_wrapper2()->per_tab_prefs_tab_helper()->prefs(); | 79 contents_wrapper2()->prefs_tab_helper()->per_tab_prefs(); |
| 80 const bool initial_value = prefs1->GetBoolean(key); | 80 const bool initial_value = prefs1->GetBoolean(key); |
| 81 EXPECT_EQ(initial_value, prefs2->GetBoolean(key)); | 81 EXPECT_EQ(initial_value, prefs2->GetBoolean(key)); |
| 82 | 82 |
| 83 prefs1->SetBoolean(key, !initial_value); | 83 prefs1->SetBoolean(key, !initial_value); |
| 84 EXPECT_EQ(!initial_value, prefs1->GetBoolean(key)); | 84 EXPECT_EQ(!initial_value, prefs1->GetBoolean(key)); |
| 85 EXPECT_EQ(initial_value, prefs2->GetBoolean(key)); | 85 EXPECT_EQ(initial_value, prefs2->GetBoolean(key)); |
| 86 | 86 |
| 87 prefs1->SetBoolean(key, initial_value); | 87 prefs1->SetBoolean(key, initial_value); |
| 88 EXPECT_EQ(initial_value, prefs1->GetBoolean(key)); | 88 EXPECT_EQ(initial_value, prefs1->GetBoolean(key)); |
| 89 EXPECT_EQ(initial_value, prefs2->GetBoolean(key)); | 89 EXPECT_EQ(initial_value, prefs2->GetBoolean(key)); |
| 90 | 90 |
| 91 prefs2->SetBoolean(key, !initial_value); | 91 prefs2->SetBoolean(key, !initial_value); |
| 92 EXPECT_EQ(initial_value, prefs1->GetBoolean(key)); | 92 EXPECT_EQ(initial_value, prefs1->GetBoolean(key)); |
| 93 EXPECT_EQ(!initial_value, prefs2->GetBoolean(key)); | 93 EXPECT_EQ(!initial_value, prefs2->GetBoolean(key)); |
| 94 } | 94 } |
| 95 | 95 |
| 96 TEST_F(PerTabPrefsTabHelperTest, OverridePrefsOnViewCreation) { | 96 TEST_F(PrefsTabHelperTest, OverridePrefsOnViewCreation) { |
| 97 TestPerTabPrefsTabHelper* test_prefs_helper = new TestPerTabPrefsTabHelper( | 97 TestPrefsTabHelper* test_prefs_helper = |
| 98 contents_wrapper()); | 98 new TestPrefsTabHelper(contents_wrapper()); |
| 99 contents_wrapper()->per_tab_prefs_tab_helper_.reset(test_prefs_helper); | 99 contents_wrapper()->prefs_tab_helper_.reset(test_prefs_helper); |
| 100 EXPECT_FALSE(test_prefs_helper->was_override_web_prefernces_called()); | 100 EXPECT_FALSE(test_prefs_helper->was_update_web_preferences_called()); |
| 101 test_prefs_helper->NotifyRenderViewCreated(); | 101 test_prefs_helper->NotifyRenderViewCreated(); |
| 102 EXPECT_TRUE(test_prefs_helper->was_override_web_prefernces_called()); | 102 EXPECT_TRUE(test_prefs_helper->was_update_web_preferences_called()); |
| 103 } | 103 } |
| OLD | NEW |