blob: d57bf0bae8560a4c3314cc5e2c8b289f09655d9a [file] [log] [blame]
[email protected]871dc682012-06-11 19:35:331// Copyright (c) 2012 The Chromium Authors. All rights reserved.
[email protected]3a4f7032009-07-08 20:43:532// Use of this source code is governed by a BSD-style license that can be
3// found in the LICENSE file.
4
dchenge73d8520c2015-12-27 01:19:095#include <utility>
6
brettwf1958912015-10-07 19:43:127#include "base/base_switches.h"
Sebastien Marchandf1349f52019-01-25 03:16:418#include "base/bind.h"
[email protected]9c29c4652014-05-22 17:33:529#include "base/command_line.h"
[email protected]57999812013-02-24 05:40:5210#include "base/files/file_path.h"
avie4d7b6f2015-12-26 00:59:1811#include "base/macros.h"
[email protected]a8ff8ed2014-01-09 07:32:2612#include "base/strings/stringprintf.h"
avie4d7b6f2015-12-26 00:59:1813#include "build/build_config.h"
[email protected]440348f2010-11-16 00:30:1914#include "chrome/browser/ui/browser.h"
[email protected]a37d4b02012-06-25 21:56:1015#include "chrome/browser/ui/browser_commands.h"
[email protected]cc872372013-01-28 21:57:0716#include "chrome/browser/ui/tabs/tab_strip_model.h"
[email protected]76543b92009-08-31 17:27:4517#include "chrome/common/url_constants.h"
[email protected]af44e7fb2011-07-29 18:32:3218#include "chrome/test/base/in_process_browser_test.h"
19#include "chrome/test/base/ui_test_utils.h"
jam0b18f832016-10-14 19:08:1020#include "content/public/browser/navigation_controller.h"
21#include "content/public/browser/navigation_entry.h"
[email protected]ad50def52011-10-19 23:17:0722#include "content/public/browser/notification_service.h"
[email protected]0d6e9bd2011-10-18 04:29:1623#include "content/public/browser/notification_types.h"
jam8e07fc92017-03-17 00:34:1424#include "content/public/browser/render_frame_host.h"
25#include "content/public/browser/render_process_host.h"
26#include "content/public/browser/render_widget_host_view.h"
[email protected]83ff91c2012-01-05 20:54:1327#include "content/public/browser/web_contents.h"
[email protected]9a001bc2014-03-12 07:59:2128#include "content/public/test/browser_test_utils.h"
Lukasz Anforowicz7ea1dbd2019-06-12 12:26:2429#include "content/public/test/no_renderer_crashes_assertion.h"
[email protected]a8ff8ed2014-01-09 07:32:2630#include "net/test/embedded_test_server/embedded_test_server.h"
31#include "net/test/embedded_test_server/http_request.h"
32#include "net/test/embedded_test_server/http_response.h"
[email protected]3a4f7032009-07-08 20:43:5333#include "testing/gtest/include/gtest/gtest.h"
Sylvain Defresnec6ccc77d2014-09-19 10:19:3534#include "ui/base/page_transition_types.h"
[email protected]3a4f7032009-07-08 20:43:5335
[email protected]e5d549d2011-12-28 01:29:2036using content::OpenURLParams;
37using content::Referrer;
[email protected]9a001bc2014-03-12 07:59:2138using content::WebContents;
[email protected]e5d549d2011-12-28 01:29:2039
[email protected]bc947b82014-03-18 07:29:1840// TODO(jam): http://crbug.com/350550
41#if !(defined(OS_CHROMEOS) && defined(ADDRESS_SANITIZER))
42
[email protected]3a4f7032009-07-08 20:43:5343namespace {
44
[email protected]3a4f7032009-07-08 20:43:5345void SimulateRendererCrash(Browser* browser) {
[email protected]a7fe9112012-07-20 02:34:4546 content::WindowedNotificationObserver observer(
[email protected]fbc5e5f92012-01-02 06:08:3247 content::NOTIFICATION_WEB_CONTENTS_DISCONNECTED,
[email protected]ad50def52011-10-19 23:17:0748 content::NotificationService::AllSources());
nick3b04f322016-08-31 19:29:1949 browser->OpenURL(OpenURLParams(GURL(content::kChromeUICrashURL), Referrer(),
50 WindowOpenDisposition::CURRENT_TAB,
51 ui::PAGE_TRANSITION_TYPED, false));
[email protected]6b4e8e42011-08-17 19:36:0652 observer.Wait();
[email protected]3a4f7032009-07-08 20:43:5353}
54
[email protected]a8ff8ed2014-01-09 07:32:2655// A request handler which returns a different result each time but stays fresh
56// into the far future.
57class CacheMaxAgeHandler {
58 public:
59 explicit CacheMaxAgeHandler(const std::string& path)
60 : path_(path), request_count_(0) { }
61
dcheng4af48582016-04-19 00:29:3562 std::unique_ptr<net::test_server::HttpResponse> HandleRequest(
[email protected]a8ff8ed2014-01-09 07:32:2663 const net::test_server::HttpRequest& request) {
64 if (request.relative_url != path_)
dcheng4af48582016-04-19 00:29:3565 return std::unique_ptr<net::test_server::HttpResponse>();
[email protected]a8ff8ed2014-01-09 07:32:2666
67 request_count_++;
dcheng4af48582016-04-19 00:29:3568 std::unique_ptr<net::test_server::BasicHttpResponse> response(
[email protected]a8ff8ed2014-01-09 07:32:2669 new net::test_server::BasicHttpResponse);
70 response->set_content(base::StringPrintf("<title>%d</title>",
71 request_count_));
72 response->set_content_type("text/html");
73 response->AddCustomHeader("Cache-Control", "max-age=99999");
dchenge73d8520c2015-12-27 01:19:0974 return std::move(response);
[email protected]a8ff8ed2014-01-09 07:32:2675 }
76 private:
77 std::string path_;
78 int request_count_;
[email protected]a8ff8ed2014-01-09 07:32:2679
[email protected]9c29c4652014-05-22 17:33:5280 DISALLOW_COPY_AND_ASSIGN(CacheMaxAgeHandler);
81};
[email protected]3a4f7032009-07-08 20:43:5382
83class CrashRecoveryBrowserTest : public InProcessBrowserTest {
[email protected]9a001bc2014-03-12 07:59:2184 protected:
85 WebContents* GetActiveWebContents() {
86 return browser()->tab_strip_model()->GetActiveWebContents();
87 }
[email protected]9c29c4652014-05-22 17:33:5288
89 private:
Daniel Chenga542fca2014-10-21 09:51:2990 void SetUpCommandLine(base::CommandLine* command_line) override {
[email protected]9c29c4652014-05-22 17:33:5291 command_line->AppendSwitch(switches::kDisableBreakpad);
92 }
Lukasz Anforowicz7ea1dbd2019-06-12 12:26:2493
94 content::ScopedAllowRendererCrashes scoped_allow_renderer_crashes_;
[email protected]3a4f7032009-07-08 20:43:5395};
96
97// Test that reload works after a crash.
Greg Thompsonce8736b2019-07-18 10:52:3198// Flaky timeouts on Win7 Tests (dbg)(1); see https://crbug.com/985255.
99#if defined(OS_WIN) && !defined(NDEBUG)
100#define MAYBE_Reload DISABLED_Reload
101#else
102#define MAYBE_Reload Reload
103#endif
104IN_PROC_BROWSER_TEST_F(CrashRecoveryBrowserTest, MAYBE_Reload) {
[email protected]3a4f7032009-07-08 20:43:53105 // The title of the active tab should change each time this URL is loaded.
106 GURL url(
107 "data:text/html,<script>document.title=new Date().valueOf()</script>");
108 ui_test_utils::NavigateToURL(browser(), url);
109
[email protected]96920152013-12-04 21:00:16110 base::string16 title_before_crash;
111 base::string16 title_after_crash;
[email protected]3a4f7032009-07-08 20:43:53112
113 ASSERT_TRUE(ui_test_utils::GetCurrentTabTitle(browser(),
114 &title_before_crash));
115 SimulateRendererCrash(browser());
nick3b04f322016-08-31 19:29:19116 chrome::Reload(browser(), WindowOpenDisposition::CURRENT_TAB);
[email protected]9a001bc2014-03-12 07:59:21117 content::WaitForLoadStop(GetActiveWebContents());
[email protected]3a4f7032009-07-08 20:43:53118 ASSERT_TRUE(ui_test_utils::GetCurrentTabTitle(browser(),
119 &title_after_crash));
120 EXPECT_NE(title_before_crash, title_after_crash);
jam8e07fc92017-03-17 00:34:14121 ASSERT_TRUE(GetActiveWebContents()->GetMainFrame()->GetView()->IsShowing());
Lukasz Anforowicz57ade7c2017-09-28 20:26:33122 ASSERT_FALSE(GetActiveWebContents()
123 ->GetMainFrame()
124 ->GetProcess()
125 ->IsProcessBackgrounded());
[email protected]3a4f7032009-07-08 20:43:53126}
127
[email protected]a8ff8ed2014-01-09 07:32:26128// Test that reload after a crash forces a cache revalidation.
129IN_PROC_BROWSER_TEST_F(CrashRecoveryBrowserTest, ReloadCacheRevalidate) {
130 const char kTestPath[] = "/test";
131
132 // Use the test server so as not to bypass cache behavior. The title of the
133 // active tab should change only when this URL is reloaded.
[email protected]a8ff8ed2014-01-09 07:32:26134 embedded_test_server()->RegisterRequestHandler(
135 base::Bind(&CacheMaxAgeHandler::HandleRequest,
136 base::Owned(new CacheMaxAgeHandler(kTestPath))));
martijnbb41e732016-11-23 16:55:34137 ASSERT_TRUE(embedded_test_server()->Start());
[email protected]a8ff8ed2014-01-09 07:32:26138 ui_test_utils::NavigateToURL(browser(),
139 embedded_test_server()->GetURL(kTestPath));
140
141 base::string16 title_before_crash;
142 base::string16 title_after_crash;
143
144 ASSERT_TRUE(ui_test_utils::GetCurrentTabTitle(browser(),
145 &title_before_crash));
146 SimulateRendererCrash(browser());
nick3b04f322016-08-31 19:29:19147 chrome::Reload(browser(), WindowOpenDisposition::CURRENT_TAB);
[email protected]9a001bc2014-03-12 07:59:21148 content::WaitForLoadStop(GetActiveWebContents());
[email protected]a8ff8ed2014-01-09 07:32:26149 ASSERT_TRUE(ui_test_utils::GetCurrentTabTitle(browser(),
150 &title_after_crash));
151 EXPECT_NE(title_before_crash, title_after_crash);
152}
153
[email protected]3a4f7032009-07-08 20:43:53154// Tests that loading a crashed page in a new tab correctly updates the title.
155// There was an earlier bug (1270510) in process-per-site in which the max page
156// ID of the RenderProcessHost was stale, so the NavigationEntry in the new tab
157// was not committed. This prevents regression of that bug.
Greg Thompsonce8736b2019-07-18 10:52:31158// Flaky timeouts on Win7 Tests (dbg)(1); see https://crbug.com/985255.
159#if defined(OS_WIN) && !defined(NDEBUG)
160#define MAYBE_LoadInNewTab DISABLED_LoadInNewTab
161#else
162#define MAYBE_LoadInNewTab LoadInNewTab
163#endif
164IN_PROC_BROWSER_TEST_F(CrashRecoveryBrowserTest, MAYBE_LoadInNewTab) {
[email protected]9c29c4652014-05-22 17:33:52165 const base::FilePath::CharType kTitle2File[] =
[email protected]650b2d52013-02-10 03:41:45166 FILE_PATH_LITERAL("title2.html");
[email protected]5a1454362010-03-31 08:56:47167
jam0b18f832016-10-14 19:08:10168 GURL url(ui_test_utils::GetTestUrl(
169 base::FilePath(base::FilePath::kCurrentDirectory),
170 base::FilePath(kTitle2File)));
171 ui_test_utils::NavigateToURL(browser(), url);
[email protected]3a4f7032009-07-08 20:43:53172
[email protected]96920152013-12-04 21:00:16173 base::string16 title_before_crash;
174 base::string16 title_after_crash;
[email protected]3a4f7032009-07-08 20:43:53175
176 ASSERT_TRUE(ui_test_utils::GetCurrentTabTitle(browser(),
177 &title_before_crash));
178 SimulateRendererCrash(browser());
jam0b18f832016-10-14 19:08:10179 ASSERT_EQ(GURL(content::kChromeUICrashURL),
180 GetActiveWebContents()->GetController().GetVisibleEntry()->
181 GetVirtualURL());
nick3b04f322016-08-31 19:29:19182 chrome::Reload(browser(), WindowOpenDisposition::CURRENT_TAB);
[email protected]9a001bc2014-03-12 07:59:21183 content::WaitForLoadStop(GetActiveWebContents());
[email protected]3a4f7032009-07-08 20:43:53184 ASSERT_TRUE(ui_test_utils::GetCurrentTabTitle(browser(),
185 &title_after_crash));
186 EXPECT_EQ(title_before_crash, title_after_crash);
187}
[email protected]9a001bc2014-03-12 07:59:21188
189// Tests that reloads of navigation errors behave correctly after a crash.
190// Regression test for http://crbug.com/348918
191IN_PROC_BROWSER_TEST_F(CrashRecoveryBrowserTest, DoubleReloadWithError) {
Matt Siembor39462b32019-05-07 20:20:44192 GURL url(content::GetWebUIURL("bogus"));
[email protected]9a001bc2014-03-12 07:59:21193 ui_test_utils::NavigateToURL(browser(), url);
194 ASSERT_EQ(url, GetActiveWebContents()->GetVisibleURL());
195
196 SimulateRendererCrash(browser());
197
nick3b04f322016-08-31 19:29:19198 chrome::Reload(browser(), WindowOpenDisposition::CURRENT_TAB);
[email protected]9a001bc2014-03-12 07:59:21199 content::WaitForLoadStop(GetActiveWebContents());
200 ASSERT_EQ(url, GetActiveWebContents()->GetVisibleURL());
201
nick3b04f322016-08-31 19:29:19202 chrome::Reload(browser(), WindowOpenDisposition::CURRENT_TAB);
[email protected]9a001bc2014-03-12 07:59:21203 content::WaitForLoadStop(GetActiveWebContents());
204 ASSERT_EQ(url, GetActiveWebContents()->GetVisibleURL());
205}
[email protected]bc947b82014-03-18 07:29:18206
jamb618e0bb22016-10-01 05:28:22207// Tests that a beforeunload handler doesn't run if user navigates to
208// chrome::crash.
209IN_PROC_BROWSER_TEST_F(CrashRecoveryBrowserTest, BeforeUnloadNotRun) {
210 const char* kBeforeUnloadHTML =
211 "<html><body>"
212 "<script>window.onbeforeunload=function(e){return 'foo'}</script>"
213 "</body></html>";
214 GURL url(std::string("data:text/html,") + kBeforeUnloadHTML);
215 ui_test_utils::NavigateToURL(browser(), url);
216 SimulateRendererCrash(browser());
217}
218
[email protected]9c29c4652014-05-22 17:33:52219} // namespace
220
[email protected]bc947b82014-03-18 07:29:18221#endif