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

Side by Side Diff: chrome/browser/permissions/permission_context_base_unittest.cc

Issue 1337903002: permissions: remove PermissionQueueController and introduce PermissionInfoBarManager (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@callbacks-delegates
Patch Set: Fix compile on desktop Created 5 years, 2 months 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 unified diff | Download patch
OLDNEW
1 // Copyright 2014 The Chromium Authors. All rights reserved. 1 // Copyright 2014 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/browser/permissions/permission_context_base.h" 5 #include "chrome/browser/permissions/permission_context_base.h"
6 6
7 #include "base/bind.h" 7 #include "base/bind.h"
8 #include "base/command_line.h" 8 #include "base/command_line.h"
9 #include "chrome/browser/content_settings/host_content_settings_map_factory.h" 9 #include "chrome/browser/content_settings/host_content_settings_map_factory.h"
10 #include "chrome/browser/infobars/infobar_service.h" 10 #include "chrome/browser/infobars/infobar_service.h"
11 #include "chrome/browser/permissions/permission_queue_controller.h" 11 #include "chrome/browser/permissions/permission_infobar_manager.h"
12 #include "chrome/browser/permissions/permission_infobar_request.h"
12 #include "chrome/browser/permissions/permission_request_id.h" 13 #include "chrome/browser/permissions/permission_request_id.h"
13 #include "chrome/browser/ui/website_settings/permission_bubble_manager.h" 14 #include "chrome/browser/ui/website_settings/permission_bubble_manager.h"
14 #include "chrome/common/chrome_switches.h" 15 #include "chrome/common/chrome_switches.h"
15 #include "chrome/test/base/chrome_render_view_host_test_harness.h" 16 #include "chrome/test/base/chrome_render_view_host_test_harness.h"
16 #include "chrome/test/base/testing_profile.h" 17 #include "chrome/test/base/testing_profile.h"
17 #include "components/content_settings/core/browser/host_content_settings_map.h" 18 #include "components/content_settings/core/browser/host_content_settings_map.h"
18 #include "components/content_settings/core/common/content_settings.h" 19 #include "components/content_settings/core/common/content_settings.h"
19 #include "components/content_settings/core/common/content_settings_types.h" 20 #include "components/content_settings/core/common/content_settings_types.h"
20 #include "content/public/browser/render_frame_host.h" 21 #include "content/public/browser/render_frame_host.h"
21 #include "content/public/browser/web_contents.h" 22 #include "content/public/browser/web_contents.h"
22 #include "content/public/test/mock_render_process_host.h" 23 #include "content/public/test/mock_render_process_host.h"
23 #include "content/public/test/web_contents_tester.h" 24 #include "content/public/test/web_contents_tester.h"
24 #include "testing/gtest/include/gtest/gtest.h" 25 #include "testing/gtest/include/gtest/gtest.h"
25 26
26 class TestPermissionContext : public PermissionContextBase { 27 class TestPermissionContext : public PermissionContextBase {
27 public: 28 public:
28 TestPermissionContext(Profile* profile, 29 TestPermissionContext(Profile* profile,
29 const ContentSettingsType permission_type) 30 const ContentSettingsType permission_type)
30 : PermissionContextBase(profile, permission_type), 31 : PermissionContextBase(profile, permission_type),
31 permission_set_(false), 32 permission_set_(false),
32 permission_granted_(false), 33 permission_granted_(false),
33 tab_context_updated_(false) {} 34 tab_context_updated_(false) {}
34 35
35 ~TestPermissionContext() override {} 36 ~TestPermissionContext() override {}
36 37
37 PermissionQueueController* GetInfoBarController() {
38 return GetQueueController();
39 }
40
41 bool permission_granted() { 38 bool permission_granted() {
42 return permission_granted_; 39 return permission_granted_;
43 } 40 }
44 41
45 bool permission_set() { 42 bool permission_set() {
46 return permission_set_; 43 return permission_set_;
47 } 44 }
48 45
49 bool tab_context_updated() { 46 bool tab_context_updated() {
50 return tab_context_updated_; 47 return tab_context_updated_;
(...skipping 19 matching lines...) Expand all
70 bool permission_set_; 67 bool permission_set_;
71 bool permission_granted_; 68 bool permission_granted_;
72 bool tab_context_updated_; 69 bool tab_context_updated_;
73 }; 70 };
74 71
75 class PermissionContextBaseTests : public ChromeRenderViewHostTestHarness { 72 class PermissionContextBaseTests : public ChromeRenderViewHostTestHarness {
76 protected: 73 protected:
77 PermissionContextBaseTests() {} 74 PermissionContextBaseTests() {}
78 75
79 // Accept or dismiss the permission bubble or infobar. 76 // Accept or dismiss the permission bubble or infobar.
80 void RespondToPermission(TestPermissionContext* context, 77 void RespondToPermission(bool accept) {
81 const PermissionRequestID& id, 78 if (PermissionBubbleManager::Enabled()) {
82 const GURL& url, 79 PermissionBubbleManager* manager =
83 bool accept) { 80 PermissionBubbleManager::FromWebContents(web_contents());
84 if (!PermissionBubbleManager::Enabled()) { 81 if (accept)
85 context->GetInfoBarController()->OnPermissionSet( 82 manager->Accept();
86 id, url, url, accept, accept); 83 else
87 return; 84 manager->Closing();
85 } else {
86 PermissionInfoBarManager* manager =
87 PermissionInfoBarManager::FromWebContents(web_contents());
88 if (accept)
89 manager->current_request_->AcceptForTests();
90 else
91 manager->current_request_->ClosingForTests();
88 } 92 }
89
90 PermissionBubbleManager* manager =
91 PermissionBubbleManager::FromWebContents(web_contents());
92 if (accept)
93 manager->Accept();
94 else
95 manager->Closing();
96 } 93 }
97 94
98 void TestAskAndGrant_TestContent() { 95 void TestAskAndGrant_TestContent() {
99 TestPermissionContext permission_context( 96 TestPermissionContext permission_context(
100 profile(), CONTENT_SETTINGS_TYPE_NOTIFICATIONS); 97 profile(), CONTENT_SETTINGS_TYPE_NOTIFICATIONS);
101 GURL url("http://www.google.com"); 98 GURL url("http://www.google.com");
102 content::WebContentsTester::For(web_contents())->NavigateAndCommit(url); 99 content::WebContentsTester::For(web_contents())->NavigateAndCommit(url);
103 100
104 const PermissionRequestID id( 101 const PermissionRequestID id(
105 web_contents()->GetRenderProcessHost()->GetID(), 102 web_contents()->GetRenderProcessHost()->GetID(),
106 web_contents()->GetMainFrame()->GetRoutingID(), 103 web_contents()->GetMainFrame()->GetRoutingID(),
107 -1); 104 0);
108 permission_context.RequestPermission( 105 permission_context.RequestPermission(
109 web_contents(), 106 web_contents(),
110 id, url, true, 107 id, url, true,
111 base::Bind(&TestPermissionContext::TrackPermissionDecision, 108 base::Bind(&TestPermissionContext::TrackPermissionDecision,
112 base::Unretained(&permission_context))); 109 base::Unretained(&permission_context)));
113 110
114 RespondToPermission(&permission_context, id, url, true); 111 RespondToPermission(true);
115 EXPECT_TRUE(permission_context.permission_set()); 112 EXPECT_TRUE(permission_context.permission_set());
116 EXPECT_TRUE(permission_context.permission_granted()); 113 EXPECT_TRUE(permission_context.permission_granted());
117 EXPECT_TRUE(permission_context.tab_context_updated()); 114 EXPECT_TRUE(permission_context.tab_context_updated());
118 115
119 ContentSetting setting = 116 ContentSetting setting =
120 HostContentSettingsMapFactory::GetForProfile(profile()) 117 HostContentSettingsMapFactory::GetForProfile(profile())
121 ->GetContentSetting(url.GetOrigin(), 118 ->GetContentSetting(url.GetOrigin(),
122 url.GetOrigin(), 119 url.GetOrigin(),
123 CONTENT_SETTINGS_TYPE_NOTIFICATIONS, 120 CONTENT_SETTINGS_TYPE_NOTIFICATIONS,
124 std::string()); 121 std::string());
125 EXPECT_EQ(CONTENT_SETTING_ALLOW, setting); 122 EXPECT_EQ(CONTENT_SETTING_ALLOW, setting);
126 } 123 }
127 124
128 void TestAskAndDismiss_TestContent() { 125 void TestAskAndDismiss_TestContent() {
129 TestPermissionContext permission_context( 126 TestPermissionContext permission_context(
130 profile(), CONTENT_SETTINGS_TYPE_MIDI_SYSEX); 127 profile(), CONTENT_SETTINGS_TYPE_MIDI_SYSEX);
131 GURL url("http://www.google.es"); 128 GURL url("http://www.google.es");
132 content::WebContentsTester::For(web_contents())->NavigateAndCommit(url); 129 content::WebContentsTester::For(web_contents())->NavigateAndCommit(url);
133 130
134 const PermissionRequestID id( 131 const PermissionRequestID id(
135 web_contents()->GetRenderProcessHost()->GetID(), 132 web_contents()->GetRenderProcessHost()->GetID(),
136 web_contents()->GetMainFrame()->GetRoutingID(), 133 web_contents()->GetMainFrame()->GetRoutingID(),
137 -1); 134 0);
138 permission_context.RequestPermission( 135 permission_context.RequestPermission(
139 web_contents(), 136 web_contents(),
140 id, url, true, 137 id, url, true,
141 base::Bind(&TestPermissionContext::TrackPermissionDecision, 138 base::Bind(&TestPermissionContext::TrackPermissionDecision,
142 base::Unretained(&permission_context))); 139 base::Unretained(&permission_context)));
143 140
144 RespondToPermission(&permission_context, id, url, false); 141 RespondToPermission(false);
145 EXPECT_TRUE(permission_context.permission_set()); 142 EXPECT_TRUE(permission_context.permission_set());
146 EXPECT_FALSE(permission_context.permission_granted()); 143 EXPECT_FALSE(permission_context.permission_granted());
147 EXPECT_TRUE(permission_context.tab_context_updated()); 144 EXPECT_TRUE(permission_context.tab_context_updated());
148 145
149 ContentSetting setting = 146 ContentSetting setting =
150 HostContentSettingsMapFactory::GetForProfile(profile()) 147 HostContentSettingsMapFactory::GetForProfile(profile())
151 ->GetContentSetting(url.GetOrigin(), 148 ->GetContentSetting(url.GetOrigin(),
152 url.GetOrigin(), 149 url.GetOrigin(),
153 CONTENT_SETTINGS_TYPE_MIDI_SYSEX, 150 CONTENT_SETTINGS_TYPE_MIDI_SYSEX,
154 std::string()); 151 std::string());
155 EXPECT_EQ(CONTENT_SETTING_ASK, setting); 152 EXPECT_EQ(CONTENT_SETTING_ASK, setting);
156 } 153 }
157 154
158 void TestRequestPermissionInvalidUrl(ContentSettingsType type) { 155 void TestRequestPermissionInvalidUrl(ContentSettingsType type) {
159 TestPermissionContext permission_context(profile(), type); 156 TestPermissionContext permission_context(profile(), type);
160 GURL url; 157 GURL url;
161 ASSERT_FALSE(url.is_valid()); 158 ASSERT_FALSE(url.is_valid());
162 content::WebContentsTester::For(web_contents())->NavigateAndCommit(url); 159 content::WebContentsTester::For(web_contents())->NavigateAndCommit(url);
163 160
164 const PermissionRequestID id( 161 const PermissionRequestID id(
165 web_contents()->GetRenderProcessHost()->GetID(), 162 web_contents()->GetRenderProcessHost()->GetID(),
166 web_contents()->GetMainFrame()->GetRoutingID(), 163 web_contents()->GetMainFrame()->GetRoutingID(),
167 -1); 164 0);
168 permission_context.RequestPermission( 165 permission_context.RequestPermission(
169 web_contents(), 166 web_contents(),
170 id, url, true, 167 id, url, true,
171 base::Bind(&TestPermissionContext::TrackPermissionDecision, 168 base::Bind(&TestPermissionContext::TrackPermissionDecision,
172 base::Unretained(&permission_context))); 169 base::Unretained(&permission_context)));
173 170
174 EXPECT_TRUE(permission_context.permission_set()); 171 EXPECT_TRUE(permission_context.permission_set());
175 EXPECT_FALSE(permission_context.permission_granted()); 172 EXPECT_FALSE(permission_context.permission_granted());
176 EXPECT_TRUE(permission_context.tab_context_updated()); 173 EXPECT_TRUE(permission_context.tab_context_updated());
177 174
178 ContentSetting setting = 175 ContentSetting setting =
179 HostContentSettingsMapFactory::GetForProfile(profile()) 176 HostContentSettingsMapFactory::GetForProfile(profile())
180 ->GetContentSetting(url.GetOrigin(), 177 ->GetContentSetting(url.GetOrigin(),
181 url.GetOrigin(), 178 url.GetOrigin(),
182 type, 179 type,
183 std::string()); 180 std::string());
184 EXPECT_EQ(CONTENT_SETTING_ASK, setting); 181 EXPECT_EQ(CONTENT_SETTING_ASK, setting);
185 } 182 }
186 183
187 void TestGrantAndRevoke_TestContent(ContentSettingsType type, 184 void TestGrantAndRevoke_TestContent(ContentSettingsType type,
188 ContentSetting expected_default) { 185 ContentSetting expected_default) {
189 TestPermissionContext permission_context(profile(), type); 186 TestPermissionContext permission_context(profile(), type);
190 GURL url("https://www.google.com"); 187 GURL url("https://www.google.com");
191 content::WebContentsTester::For(web_contents())->NavigateAndCommit(url); 188 content::WebContentsTester::For(web_contents())->NavigateAndCommit(url);
192 189
193 const PermissionRequestID id( 190 const PermissionRequestID id(
194 web_contents()->GetRenderProcessHost()->GetID(), 191 web_contents()->GetRenderProcessHost()->GetID(),
195 web_contents()->GetMainFrame()->GetRoutingID(), 192 web_contents()->GetMainFrame()->GetRoutingID(),
196 -1); 193 0);
197 permission_context.RequestPermission( 194 permission_context.RequestPermission(
198 web_contents(), 195 web_contents(),
199 id, url, true, 196 id, url, true,
200 base::Bind(&TestPermissionContext::TrackPermissionDecision, 197 base::Bind(&TestPermissionContext::TrackPermissionDecision,
201 base::Unretained(&permission_context))); 198 base::Unretained(&permission_context)));
202 199
203 RespondToPermission(&permission_context, id, url, true); 200 RespondToPermission(true);
204 EXPECT_TRUE(permission_context.permission_set()); 201 EXPECT_TRUE(permission_context.permission_set());
205 EXPECT_TRUE(permission_context.permission_granted()); 202 EXPECT_TRUE(permission_context.permission_granted());
206 EXPECT_TRUE(permission_context.tab_context_updated()); 203 EXPECT_TRUE(permission_context.tab_context_updated());
207 204
208 ContentSetting setting = 205 ContentSetting setting =
209 HostContentSettingsMapFactory::GetForProfile(profile()) 206 HostContentSettingsMapFactory::GetForProfile(profile())
210 ->GetContentSetting(url.GetOrigin(), 207 ->GetContentSetting(url.GetOrigin(),
211 url.GetOrigin(), 208 url.GetOrigin(),
212 type, 209 type,
213 std::string()); 210 std::string());
(...skipping 11 matching lines...) Expand all
225 HostContentSettingsMapFactory::GetForProfile(profile()) 222 HostContentSettingsMapFactory::GetForProfile(profile())
226 ->GetDefaultContentSetting(type, nullptr); 223 ->GetDefaultContentSetting(type, nullptr);
227 EXPECT_EQ(default_setting, setting_after_reset); 224 EXPECT_EQ(default_setting, setting_after_reset);
228 } 225 }
229 226
230 private: 227 private:
231 // ChromeRenderViewHostTestHarness: 228 // ChromeRenderViewHostTestHarness:
232 void SetUp() override { 229 void SetUp() override {
233 ChromeRenderViewHostTestHarness::SetUp(); 230 ChromeRenderViewHostTestHarness::SetUp();
234 InfoBarService::CreateForWebContents(web_contents()); 231 InfoBarService::CreateForWebContents(web_contents());
232 PermissionInfoBarManager::CreateForWebContents(web_contents());
235 PermissionBubbleManager::CreateForWebContents(web_contents()); 233 PermissionBubbleManager::CreateForWebContents(web_contents());
236 } 234 }
237 235
238 DISALLOW_COPY_AND_ASSIGN(PermissionContextBaseTests); 236 DISALLOW_COPY_AND_ASSIGN(PermissionContextBaseTests);
239 }; 237 };
240 238
241 // Simulates clicking Accept. The permission should be granted and 239 // Simulates clicking Accept. The permission should be granted and
242 // saved for future use. 240 // saved for future use.
243 TEST_F(PermissionContextBaseTests, TestAskAndGrant) { 241 TEST_F(PermissionContextBaseTests, TestAskAndGrant) {
244 TestAskAndGrant_TestContent(); 242 TestAskAndGrant_TestContent();
(...skipping 45 matching lines...) Expand 10 before | Expand all | Expand 10 after
290 #if defined(ENABLE_NOTIFICATIONS) 288 #if defined(ENABLE_NOTIFICATIONS)
291 TestGrantAndRevoke_TestContent(CONTENT_SETTINGS_TYPE_NOTIFICATIONS, 289 TestGrantAndRevoke_TestContent(CONTENT_SETTINGS_TYPE_NOTIFICATIONS,
292 CONTENT_SETTING_ASK); 290 CONTENT_SETTING_ASK);
293 #endif 291 #endif
294 TestGrantAndRevoke_TestContent(CONTENT_SETTINGS_TYPE_MIDI_SYSEX, 292 TestGrantAndRevoke_TestContent(CONTENT_SETTINGS_TYPE_MIDI_SYSEX,
295 CONTENT_SETTING_ASK); 293 CONTENT_SETTING_ASK);
296 TestGrantAndRevoke_TestContent(CONTENT_SETTINGS_TYPE_PUSH_MESSAGING, 294 TestGrantAndRevoke_TestContent(CONTENT_SETTINGS_TYPE_PUSH_MESSAGING,
297 CONTENT_SETTING_ASK); 295 CONTENT_SETTING_ASK);
298 } 296 }
299 #endif 297 #endif
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698