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

Side by Side Diff: chrome/browser/ui/browser_unittest.cc

Issue 2975593002: [vr] Deny permission requests in VR mode
Patch Set: . Created 3 years, 5 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
« no previous file with comments | « chrome/browser/ui/browser.cc ('k') | chrome/browser/ui/tab_helpers.cc » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright 2013 The Chromium Authors. All rights reserved. 1 // Copyright 2013 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/ui/browser.h" 5 #include "chrome/browser/ui/browser.h"
6 6
7 #include "base/macros.h" 7 #include "base/macros.h"
8 #include "chrome/app/chrome_command_ids.h" 8 #include "chrome/app/chrome_command_ids.h"
9 #include "chrome/browser/custom_handlers/protocol_handler_registry.h"
10 #include "chrome/browser/custom_handlers/protocol_handler_registry_factory.h"
9 #include "chrome/browser/ui/browser_command_controller.h" 11 #include "chrome/browser/ui/browser_command_controller.h"
10 #include "chrome/browser/ui/browser_commands.h" 12 #include "chrome/browser/ui/browser_commands.h"
11 #include "chrome/browser/ui/tabs/tab_strip_model.h" 13 #include "chrome/browser/ui/tabs/tab_strip_model.h"
14 #include "chrome/browser/vr/vr_tab_helper.h"
12 #include "chrome/test/base/browser_with_test_window_test.h" 15 #include "chrome/test/base/browser_with_test_window_test.h"
13 #include "components/zoom/zoom_controller.h" 16 #include "components/zoom/zoom_controller.h"
14 #include "content/public/browser/render_widget_host_view.h" 17 #include "content/public/browser/render_widget_host_view.h"
15 #include "content/public/browser/site_instance.h" 18 #include "content/public/browser/site_instance.h"
16 #include "content/public/browser/web_contents.h" 19 #include "content/public/browser/web_contents.h"
17 #include "content/public/test/web_contents_tester.h" 20 #include "content/public/test/web_contents_tester.h"
21 #include "device/vr/features/features.h"
18 #include "third_party/skia/include/core/SkColor.h" 22 #include "third_party/skia/include/core/SkColor.h"
19 23
20 using content::SiteInstance; 24 using content::SiteInstance;
21 using content::WebContents; 25 using content::WebContents;
22 using content::WebContentsTester; 26 using content::WebContentsTester;
23 27
24 class BrowserUnitTest : public BrowserWithTestWindowTest { 28 class BrowserUnitTest : public BrowserWithTestWindowTest {
25 public: 29 public:
26 BrowserUnitTest() {} 30 BrowserUnitTest() {}
27 ~BrowserUnitTest() override {} 31 ~BrowserUnitTest() override {}
(...skipping 114 matching lines...) Expand 10 before | Expand all | Expand 10 after
142 146
143 contents->SetIsCrashed(base::TERMINATION_STATUS_PROCESS_CRASHED, -1); 147 contents->SetIsCrashed(base::TERMINATION_STATUS_PROCESS_CRASHED, -1);
144 148
145 EXPECT_TRUE(contents->IsCrashed()); 149 EXPECT_TRUE(contents->IsCrashed());
146 EXPECT_FALSE(command_updater->IsCommandEnabled(IDC_ZOOM_PLUS)); 150 EXPECT_FALSE(command_updater->IsCommandEnabled(IDC_ZOOM_PLUS));
147 EXPECT_FALSE(command_updater->IsCommandEnabled(IDC_ZOOM_MINUS)); 151 EXPECT_FALSE(command_updater->IsCommandEnabled(IDC_ZOOM_MINUS));
148 EXPECT_FALSE(chrome::CanZoomIn(contents)); 152 EXPECT_FALSE(chrome::CanZoomIn(contents));
149 EXPECT_FALSE(chrome::CanZoomOut(contents)); 153 EXPECT_FALSE(chrome::CanZoomOut(contents));
150 } 154 }
151 155
156 TEST_F(BrowserUnitTest, RegisterProtocolHandlerInVR) {
157 TabStripModel* tab_strip_model = browser()->tab_strip_model();
158
159 WebContents* contents = CreateTestWebContents();
160 vr::VrTabHelper::CreateForWebContents(contents);
161 tab_strip_model->AppendWebContents(contents, true);
162 WebContentsTester::For(contents)->NavigateAndCommit(GURL("about:blank"));
163
164 ProtocolHandlerRegistry* registry =
165 ProtocolHandlerRegistryFactory::GetForBrowserContext(
166 contents->GetBrowserContext());
167
168 std::string protocol("mailto");
169 GURL gurl("http://www.toplevel.example/");
170 size_t num_handlers = registry->GetHandlersFor(protocol).size();
171
172 vr::VrTabHelper* vr_tab_helper = vr::VrTabHelper::FromWebContents(contents);
173 vr_tab_helper->SetIsInVr(true);
174
175 content::WebContentsDelegate* delegate =
176 static_cast<content::WebContentsDelegate*>(browser());
177 delegate->RegisterProtocolHandler(contents, protocol, gurl, false);
178 EXPECT_EQ(num_handlers, registry->GetHandlersFor(protocol).size());
179
180 vr_tab_helper->SetIsInVr(false);
181
182 delegate->RegisterProtocolHandler(contents, protocol, gurl, false);
183 EXPECT_EQ(num_handlers + 1, registry->GetHandlersFor(protocol).size());
184 }
185
152 class BrowserBookmarkBarTest : public BrowserWithTestWindowTest { 186 class BrowserBookmarkBarTest : public BrowserWithTestWindowTest {
153 public: 187 public:
154 BrowserBookmarkBarTest() {} 188 BrowserBookmarkBarTest() {}
155 ~BrowserBookmarkBarTest() override {} 189 ~BrowserBookmarkBarTest() override {}
156 190
157 protected: 191 protected:
158 BookmarkBar::State window_bookmark_bar_state() const { 192 BookmarkBar::State window_bookmark_bar_state() const {
159 return static_cast<BookmarkBarStateTestBrowserWindow*>( 193 return static_cast<BookmarkBarStateTestBrowserWindow*>(
160 browser()->window())->bookmark_bar_state(); 194 browser()->window())->bookmark_bar_state();
161 } 195 }
(...skipping 86 matching lines...) Expand 10 before | Expand all | Expand 10 after
248 // Activate the 1st tab which is NTP. 282 // Activate the 1st tab which is NTP.
249 browser()->tab_strip_model()->ActivateTabAt(0, true); 283 browser()->tab_strip_model()->ActivateTabAt(0, true);
250 EXPECT_EQ(BookmarkBar::SHOW, browser()->bookmark_bar_state()); 284 EXPECT_EQ(BookmarkBar::SHOW, browser()->bookmark_bar_state());
251 EXPECT_EQ(BookmarkBar::SHOW, window_bookmark_bar_state()); 285 EXPECT_EQ(BookmarkBar::SHOW, window_bookmark_bar_state());
252 286
253 // Activate the 2nd tab which is non-NTP. 287 // Activate the 2nd tab which is non-NTP.
254 browser()->tab_strip_model()->ActivateTabAt(1, true); 288 browser()->tab_strip_model()->ActivateTabAt(1, true);
255 EXPECT_EQ(BookmarkBar::SHOW, browser()->bookmark_bar_state()); 289 EXPECT_EQ(BookmarkBar::SHOW, browser()->bookmark_bar_state());
256 EXPECT_EQ(BookmarkBar::SHOW, window_bookmark_bar_state()); 290 EXPECT_EQ(BookmarkBar::SHOW, window_bookmark_bar_state());
257 } 291 }
OLDNEW
« no previous file with comments | « chrome/browser/ui/browser.cc ('k') | chrome/browser/ui/tab_helpers.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698