cygprofile: increase timeouts to allow showing web contents
[chromium-blink-merge.git] / chrome / test / gpu / webgl_infobar_browsertest.cc
blobc82736c0b173342b5ba5e7438faeaaeb19d413a5
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
3 // found in the LICENSE file.
5 #include "base/command_line.h"
6 #include "base/path_service.h"
7 #include "base/strings/utf_string_conversions.h"
8 #include "chrome/browser/chrome_notification_types.h"
9 #include "chrome/browser/infobars/infobar_service.h"
10 #include "chrome/browser/ui/browser.h"
11 #include "chrome/browser/ui/browser_commands.h"
12 #include "chrome/browser/ui/browser_navigator.h"
13 #include "chrome/browser/ui/tabs/tab_strip_model.h"
14 #include "chrome/common/chrome_paths.h"
15 #include "chrome/common/chrome_switches.h"
16 #include "chrome/common/url_constants.h"
17 #include "chrome/test/base/in_process_browser_test.h"
18 #include "chrome/test/base/test_launcher_utils.h"
19 #include "chrome/test/base/test_switches.h"
20 #include "chrome/test/base/ui_test_utils.h"
21 #include "components/infobars/core/confirm_infobar_delegate.h"
22 #include "components/infobars/core/infobar.h"
23 #include "content/public/browser/gpu_data_manager.h"
24 #include "content/public/browser/notification_service.h"
25 #include "content/public/browser/notification_types.h"
26 #include "content/public/common/content_paths.h"
27 #include "content/public/test/browser_test_utils.h"
28 #include "gpu/config/gpu_test_config.h"
29 #include "testing/gtest/include/gtest/gtest.h"
30 #include "ui/base/page_transition_types.h"
31 #include "ui/gl/gl_implementation.h"
33 namespace {
35 void SimulateGPUCrash(Browser* browser) {
36 // None of the ui_test_utils entry points supports what we need to
37 // do here: navigate with the PAGE_TRANSITION_FROM_ADDRESS_BAR flag,
38 // without waiting for the navigation. It would be painful to change
39 // either of the NavigateToURL entry points to support these two
40 // constraints, so we use chrome::Navigate directly.
41 chrome::NavigateParams params(
42 browser,
43 GURL(content::kChromeUIGpuCrashURL),
44 ui::PageTransitionFromInt(
45 ui::PAGE_TRANSITION_TYPED |
46 ui::PAGE_TRANSITION_FROM_ADDRESS_BAR));
47 params.disposition = NEW_BACKGROUND_TAB;
48 chrome::Navigate(&params);
51 } // namespace
53 class WebGLInfoBarTest : public InProcessBrowserTest {
54 protected:
55 void SetUpInProcessBrowserTestFixture() override {
56 base::FilePath test_dir;
57 ASSERT_TRUE(PathService::Get(content::DIR_TEST_DATA, &test_dir));
58 gpu_test_dir_ = test_dir.AppendASCII("gpu");
60 base::FilePath gpu_test_dir_;
63 // This test is flaky. http://crbug.com/324555
64 IN_PROC_BROWSER_TEST_F(WebGLInfoBarTest, DISABLED_ContextLossRaisesInfoBar) {
65 #undef MAYBE_ContextLossRaisesInfoBard
66 #if defined(OS_WIN) && defined(USE_ASH)
67 // Disable this test in Metro+Ash for now (http://crbug.com/262796).
68 if (base::CommandLine::ForCurrentProcess()->HasSwitch(
69 switches::kAshBrowserTests))
70 return;
71 #endif
73 if (gpu::GPUTestBotConfig::CurrentConfigMatches("XP"))
74 return;
76 // Load page and wait for it to load.
77 content::WindowedNotificationObserver observer(
78 content::NOTIFICATION_LOAD_STOP,
79 content::NotificationService::AllSources());
80 ui_test_utils::NavigateToURL(
81 browser(),
82 content::GetFileUrlWithQuery(
83 gpu_test_dir_.AppendASCII("webgl.html"), "query=kill"));
84 observer.Wait();
86 content::WindowedNotificationObserver infobar_added(
87 chrome::NOTIFICATION_TAB_CONTENTS_INFOBAR_ADDED,
88 content::NotificationService::AllSources());
89 SimulateGPUCrash(browser());
90 infobar_added.Wait();
91 EXPECT_EQ(1u,
92 InfoBarService::FromWebContents(
93 browser()->tab_strip_model()->GetActiveWebContents())->
94 infobar_count());
97 // This test is flaky. http://crbug.com/324555
98 IN_PROC_BROWSER_TEST_F(WebGLInfoBarTest, DISABLED_ContextLossInfoBarReload) {
99 #if defined(OS_WIN) && defined(USE_ASH)
100 // Disable this test in Metro+Ash for now (http://crbug.com/262796).
101 if (base::CommandLine::ForCurrentProcess()->HasSwitch(
102 switches::kAshBrowserTests))
103 return;
104 #endif
106 if (gpu::GPUTestBotConfig::CurrentConfigMatches("XP"))
107 return;
109 content::DOMMessageQueue message_queue;
111 // Load page and wait for it to load.
112 content::WindowedNotificationObserver observer(
113 content::NOTIFICATION_LOAD_STOP,
114 content::NotificationService::AllSources());
115 ui_test_utils::NavigateToURL(
116 browser(),
117 content::GetFileUrlWithQuery(
118 gpu_test_dir_.AppendASCII("webgl.html"),
119 "query=kill_after_notification"));
120 observer.Wait();
122 std::string m;
123 ASSERT_TRUE(message_queue.WaitForMessage(&m));
124 EXPECT_EQ("\"LOADED\"", m);
126 message_queue.ClearQueue();
128 content::WindowedNotificationObserver infobar_added(
129 chrome::NOTIFICATION_TAB_CONTENTS_INFOBAR_ADDED,
130 content::NotificationService::AllSources());
131 SimulateGPUCrash(browser());
132 infobar_added.Wait();
133 InfoBarService* infobar_service = InfoBarService::FromWebContents(
134 browser()->tab_strip_model()->GetActiveWebContents());
135 ASSERT_EQ(1u, infobar_service->infobar_count());
136 infobars::InfoBarDelegate* delegate =
137 infobar_service->infobar_at(0)->delegate();
138 ASSERT_TRUE(delegate->AsThreeDAPIInfoBarDelegate());
139 delegate->AsConfirmInfoBarDelegate()->Cancel();
141 // The page should reload and another message sent to the
142 // DomAutomationController.
143 m.clear();
144 ASSERT_TRUE(message_queue.WaitForMessage(&m));
145 EXPECT_EQ("\"LOADED\"", m);
148 // There isn't any point in adding a test which calls Accept() on the
149 // ThreeDAPIInfoBarDelegate; doing so doesn't remove the infobar, and
150 // there's no concrete event that could be observed in response.