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

Side by Side Diff: content/browser/web_contents/web_contents_view_aura_browsertest.cc

Issue 22293003: Clean up compositor initialization/destruction. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: cleanupcompositor: UseRealGLBindings in NetInternalsTest Created 7 years, 4 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 | Annotate | Revision Log
OLDNEW
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2012 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 "content/browser/web_contents/web_contents_view_aura.h" 5 #include "content/browser/web_contents/web_contents_view_aura.h"
6 6
7 #include "base/command_line.h" 7 #include "base/command_line.h"
8 #include "base/run_loop.h" 8 #include "base/run_loop.h"
9 #include "base/strings/utf_string_conversions.h" 9 #include "base/strings/utf_string_conversions.h"
10 #include "base/test/test_timeouts.h" 10 #include "base/test/test_timeouts.h"
11 #include "base/values.h" 11 #include "base/values.h"
12 #include "content/browser/renderer_host/render_view_host_impl.h" 12 #include "content/browser/renderer_host/render_view_host_impl.h"
13 #include "content/browser/web_contents/navigation_controller_impl.h" 13 #include "content/browser/web_contents/navigation_controller_impl.h"
14 #include "content/browser/web_contents/navigation_entry_impl.h" 14 #include "content/browser/web_contents/navigation_entry_impl.h"
15 #include "content/browser/web_contents/web_contents_impl.h" 15 #include "content/browser/web_contents/web_contents_impl.h"
16 #include "content/browser/web_contents/web_contents_screenshot_manager.h" 16 #include "content/browser/web_contents/web_contents_screenshot_manager.h"
17 #include "content/public/browser/web_contents_view.h" 17 #include "content/public/browser/web_contents_view.h"
18 #include "content/public/common/content_switches.h" 18 #include "content/public/common/content_switches.h"
19 #include "content/public/test/browser_test_utils.h" 19 #include "content/public/test/browser_test_utils.h"
20 #include "content/public/test/test_utils.h" 20 #include "content/public/test/test_utils.h"
21 #include "content/shell/shell.h" 21 #include "content/shell/shell.h"
22 #include "content/test/content_browser_test.h" 22 #include "content/test/content_browser_test.h"
23 #include "content/test/content_browser_test_utils.h" 23 #include "content/test/content_browser_test_utils.h"
24 #include "ui/aura/root_window.h" 24 #include "ui/aura/root_window.h"
25 #include "ui/aura/test/event_generator.h" 25 #include "ui/aura/test/event_generator.h"
26 #include "ui/aura/window.h" 26 #include "ui/aura/window.h"
27 #include "ui/compositor/compositor_setup.h"
28 #include "ui/compositor/scoped_animation_duration_scale_mode.h" 27 #include "ui/compositor/scoped_animation_duration_scale_mode.h"
29 28
30 namespace content { 29 namespace content {
31 30
32 // This class keeps track of the RenderViewHost whose screenshot was captured. 31 // This class keeps track of the RenderViewHost whose screenshot was captured.
33 class ScreenshotTracker : public WebContentsScreenshotManager { 32 class ScreenshotTracker : public WebContentsScreenshotManager {
34 public: 33 public:
35 explicit ScreenshotTracker(NavigationControllerImpl* controller) 34 explicit ScreenshotTracker(NavigationControllerImpl* controller)
36 : WebContentsScreenshotManager(controller), 35 : WebContentsScreenshotManager(controller),
37 screenshot_taken_for_(NULL), 36 screenshot_taken_for_(NULL),
(...skipping 42 matching lines...) Expand 10 before | Expand all | Expand 10 after
80 79
81 DISALLOW_COPY_AND_ASSIGN(ScreenshotTracker); 80 DISALLOW_COPY_AND_ASSIGN(ScreenshotTracker);
82 }; 81 };
83 82
84 class WebContentsViewAuraTest : public ContentBrowserTest { 83 class WebContentsViewAuraTest : public ContentBrowserTest {
85 public: 84 public:
86 WebContentsViewAuraTest() 85 WebContentsViewAuraTest()
87 : screenshot_manager_(NULL) { 86 : screenshot_manager_(NULL) {
88 } 87 }
89 88
89 virtual void SetUp() OVERRIDE {
90 // TODO(jbauman): Remove this. http://crbug.com/268644
91 UseRealGLContexts();
92 }
93
90 // Executes the javascript synchronously and makes sure the returned value is 94 // Executes the javascript synchronously and makes sure the returned value is
91 // freed properly. 95 // freed properly.
92 void ExecuteSyncJSFunction(RenderViewHost* rvh, const std::string& jscript) { 96 void ExecuteSyncJSFunction(RenderViewHost* rvh, const std::string& jscript) {
93 scoped_ptr<base::Value> value = 97 scoped_ptr<base::Value> value =
94 content::ExecuteScriptAndGetValue(rvh, jscript); 98 content::ExecuteScriptAndGetValue(rvh, jscript);
95 } 99 }
96 100
97 // Starts the test server and navigates to the given url. Sets a large enough 101 // Starts the test server and navigates to the given url. Sets a large enough
98 // size to the root window. Returns after the navigation to the url is 102 // size to the root window. Returns after the navigation to the url is
99 // complete. 103 // complete.
(...skipping 219 matching lines...) Expand 10 before | Expand all | Expand 10 after
319 // Do not end the overscroll sequence. 323 // Do not end the overscroll sequence.
320 } 324 }
321 325
322 // Tests that the page has has a screenshot when navigation happens: 326 // Tests that the page has has a screenshot when navigation happens:
323 // - from within the page (from a JS function) 327 // - from within the page (from a JS function)
324 // - interactively, when user does an overscroll gesture 328 // - interactively, when user does an overscroll gesture
325 // - interactively, when user navigates in history without the overscroll 329 // - interactively, when user navigates in history without the overscroll
326 // gesture. 330 // gesture.
327 IN_PROC_BROWSER_TEST_F(WebContentsViewAuraTest, 331 IN_PROC_BROWSER_TEST_F(WebContentsViewAuraTest,
328 OverscrollScreenshot) { 332 OverscrollScreenshot) {
329 // http://crbug.com/268644
330 if (ui::IsTestCompositorEnabled())
331 return;
332 ASSERT_NO_FATAL_FAILURE( 333 ASSERT_NO_FATAL_FAILURE(
333 StartTestWithPage("files/overscroll_navigation.html")); 334 StartTestWithPage("files/overscroll_navigation.html"));
334 WebContentsImpl* web_contents = 335 WebContentsImpl* web_contents =
335 static_cast<WebContentsImpl*>(shell()->web_contents()); 336 static_cast<WebContentsImpl*>(shell()->web_contents());
336 RenderViewHostImpl* view_host = static_cast<RenderViewHostImpl*>( 337 RenderViewHostImpl* view_host = static_cast<RenderViewHostImpl*>(
337 web_contents->GetRenderViewHost()); 338 web_contents->GetRenderViewHost());
338 339
339 set_min_screenshot_interval(0); 340 set_min_screenshot_interval(0);
340 341
341 // Do a few navigations initiated by the page. 342 // Do a few navigations initiated by the page.
(...skipping 74 matching lines...) Expand 10 before | Expand all | Expand 10 after
416 entry = NavigationEntryImpl::FromNavigationEntry( 417 entry = NavigationEntryImpl::FromNavigationEntry(
417 web_contents->GetController().GetEntryAtIndex(4)); 418 web_contents->GetController().GetEntryAtIndex(4));
418 EXPECT_TRUE(entry->screenshot().get()); 419 EXPECT_TRUE(entry->screenshot().get());
419 } 420 }
420 } 421 }
421 422
422 // Tests that screenshot is taken correctly when navigation causes a 423 // Tests that screenshot is taken correctly when navigation causes a
423 // RenderViewHost to be swapped out. 424 // RenderViewHost to be swapped out.
424 IN_PROC_BROWSER_TEST_F(WebContentsViewAuraTest, 425 IN_PROC_BROWSER_TEST_F(WebContentsViewAuraTest,
425 ScreenshotForSwappedOutRenderViews) { 426 ScreenshotForSwappedOutRenderViews) {
426 // http://crbug.com/268644
427 if (ui::IsTestCompositorEnabled())
428 return;
429 ASSERT_NO_FATAL_FAILURE( 427 ASSERT_NO_FATAL_FAILURE(
430 StartTestWithPage("files/overscroll_navigation.html")); 428 StartTestWithPage("files/overscroll_navigation.html"));
431 // Create a new server with a different site. 429 // Create a new server with a different site.
432 net::SpawnedTestServer https_server( 430 net::SpawnedTestServer https_server(
433 net::SpawnedTestServer::TYPE_HTTPS, 431 net::SpawnedTestServer::TYPE_HTTPS,
434 net::SpawnedTestServer::kLocalhost, 432 net::SpawnedTestServer::kLocalhost,
435 base::FilePath(FILE_PATH_LITERAL("content/test/data"))); 433 base::FilePath(FILE_PATH_LITERAL("content/test/data")));
436 ASSERT_TRUE(https_server.Start()); 434 ASSERT_TRUE(https_server.Start());
437 435
438 WebContentsImpl* web_contents = 436 WebContentsImpl* web_contents =
(...skipping 161 matching lines...) Expand 10 before | Expand all | Expand 10 after
600 10); 598 10);
601 string16 actual_title = title_watcher.WaitAndGetTitle(); 599 string16 actual_title = title_watcher.WaitAndGetTitle();
602 EXPECT_EQ(expected_title, actual_title); 600 EXPECT_EQ(expected_title, actual_title);
603 601
604 EXPECT_EQ(2, GetCurrentIndex()); 602 EXPECT_EQ(2, GetCurrentIndex());
605 EXPECT_TRUE(controller.CanGoBack()); 603 EXPECT_TRUE(controller.CanGoBack());
606 EXPECT_FALSE(controller.CanGoForward()); 604 EXPECT_FALSE(controller.CanGoForward());
607 } 605 }
608 606
609 } // namespace content 607 } // namespace content
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698