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_override_web_preferences_called_(false) { |
20 } | 20 } |
21 virtual ~TestPerTabPrefsTabHelper() { } | 21 virtual ~TestPrefsTabHelper() { } |
22 | 22 |
23 virtual void OverrideWebPreferences(WebPreferences* prefs) OVERRIDE { | 23 virtual void OverrideWebPreferences(WebPreferences* prefs) OVERRIDE { |
mnaganov (inactive)
2011/12/02 20:01:32
I was overriding this method because I couldn't ho
| |
24 was_override_web_prefernces_called_ = true; | 24 was_override_web_preferences_called_ = true; |
25 PerTabPrefsTabHelper::OverrideWebPreferences(prefs); | 25 PrefsTabHelper::OverrideWebPreferences(prefs); |
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_override_web_preferences_called() { |
33 return was_override_web_prefernces_called_; | 33 return was_override_web_preferences_called_; |
34 } | 34 } |
35 | 35 |
36 private: | 36 private: |
37 bool was_override_web_prefernces_called_; | 37 bool was_override_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 = new TestPrefsTabHelper( |
98 contents_wrapper()); | 98 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_override_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_override_web_preferences_called()); |
103 } | 103 } |
OLD | NEW |