| // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 
 | // Use of this source code is governed by a BSD-style license that can be | 
 | // found in the LICENSE file. | 
 |  | 
 | #include "base/bind.h" | 
 | #include "content/browser/web_contents/web_contents_impl.h" | 
 | #include "content/public/browser/web_contents.h" | 
 | #include "content/public/test/content_browser_test.h" | 
 | #include "content/public/test/content_browser_test_utils.h" | 
 | #include "content/public/test/url_loader_interceptor.h" | 
 | #include "content/shell/browser/shell.h" | 
 | #include "net/http/http_util.h" | 
 | #include "net/test/embedded_test_server/embedded_test_server.h" | 
 |  | 
 | namespace content { | 
 | namespace { | 
 |  | 
 | constexpr char kAsyncScriptThatAbortsOnEndPage[] = | 
 |     "/webkit/async_script_abort_on_end.html"; | 
 |  | 
 | constexpr char k400AbortOnEndUrl[] = "http://url.handled.by.abort.on.end/400"; | 
 |  | 
 | bool AbortOnEndInterceptor(URLLoaderInterceptor::RequestParams* params) { | 
 |   if (params->url_request.url.spec() != k400AbortOnEndUrl) | 
 |     return false; | 
 |  | 
 |   std::string headers = | 
 |       "HTTP/1.1 400 This is not OK\n" | 
 |       "Content-type: text/plain\n"; | 
 |   net::HttpResponseInfo info; | 
 |   info.headers = new net::HttpResponseHeaders( | 
 |       net::HttpUtil::AssembleRawHeaders(headers.c_str(), headers.length())); | 
 |   network::ResourceResponseHead response; | 
 |   response.headers = info.headers; | 
 |   response.headers->GetMimeType(&response.mime_type); | 
 |   params->client->OnReceiveResponse(response); | 
 |  | 
 |   std::string body = "some data\r\n"; | 
 |   uint32_t bytes_written = body.size(); | 
 |   mojo::DataPipe data_pipe(body.size()); | 
 |   CHECK_EQ(MOJO_RESULT_OK, | 
 |            data_pipe.producer_handle->WriteData( | 
 |                body.data(), &bytes_written, MOJO_WRITE_DATA_FLAG_ALL_OR_NONE)); | 
 |   params->client->OnStartLoadingResponseBody( | 
 |       std::move(data_pipe.consumer_handle)); | 
 |  | 
 |   params->client->OnComplete( | 
 |       network::URLLoaderCompletionStatus(net::ERR_CONNECTION_ABORTED)); | 
 |   return true; | 
 | } | 
 |  | 
 | }  // namespace | 
 |  | 
 | using WebKitBrowserTest = ContentBrowserTest; | 
 |  | 
 | // This is a browser test because it is hard to reproduce reliably in a | 
 | // web test without races. http://crbug.com/75604 deals with a request | 
 | // for an async script which gets data in the response and immediately | 
 | // after aborts. This test creates that condition, and it is passed | 
 | // if chrome does not crash. | 
 |  | 
 | IN_PROC_BROWSER_TEST_F(WebKitBrowserTest, AbortOnEnd) { | 
 |   ASSERT_TRUE(embedded_test_server()->Start()); | 
 |   URLLoaderInterceptor interceptor(base::BindRepeating(&AbortOnEndInterceptor)); | 
 |   GURL url = embedded_test_server()->GetURL(kAsyncScriptThatAbortsOnEndPage); | 
 |  | 
 |   NavigateToURL(shell(), url); | 
 |  | 
 |   // If you are seeing this test fail, please strongly investigate the | 
 |   // possibility that http://crbug.com/75604 and | 
 |   // https://bugs.webkit.org/show_bug.cgi?id=71122 have reverted before | 
 |   // marking this as flakey. | 
 |   EXPECT_FALSE(shell()->web_contents()->IsCrashed()); | 
 | } | 
 |  | 
 | // This is a browser test because the test_runner framework holds | 
 | // onto a Document* reference that blocks this reproduction from | 
 | // destroying the Document, so it is not a use after free unless | 
 | // you don't have test_runner loaded. | 
 |  | 
 | // TODO(gavinp): remove this browser_test if we can get good web test | 
 | // coverage of the same issue. | 
 | const char kXsltBadImportPage[] = "/webkit/xslt-bad-import.html"; | 
 | IN_PROC_BROWSER_TEST_F(WebKitBrowserTest, XsltBadImport) { | 
 |   ASSERT_TRUE(embedded_test_server()->Start()); | 
 |   URLLoaderInterceptor interceptor(base::BindRepeating(&AbortOnEndInterceptor)); | 
 |   GURL url = embedded_test_server()->GetURL(kXsltBadImportPage); | 
 |  | 
 |   NavigateToURL(shell(), url); | 
 |  | 
 |   EXPECT_FALSE(shell()->web_contents()->IsCrashed()); | 
 | } | 
 |  | 
 | // This is a browser test because test_runner has a PrerendererClient | 
 | // implementation, and the purpose of this test is to ensure that content_shell | 
 | // does not crash when prerender elements are encountered with no Prererering | 
 | // implementation supplied to WebKit. | 
 |  | 
 | // TODO(gavinp,jochen): This browser_test depends on there not being a | 
 | // prerendering client and prerendering platform provided by the test_shell. | 
 | // But both will exist when we use content_shell to run web tests. We must | 
 | // then add a mechanism to start content_shell without these, or else this | 
 | // test is not very interesting. | 
 | const char kPrerenderNoCrashPage[] = "/prerender/prerender-no-crash.html"; | 
 | IN_PROC_BROWSER_TEST_F(WebKitBrowserTest, PrerenderNoCrash) { | 
 |   ASSERT_TRUE(embedded_test_server()->Start()); | 
 |   GURL url = embedded_test_server()->GetURL(kPrerenderNoCrashPage); | 
 |  | 
 |   NavigateToURL(shell(), url); | 
 |  | 
 |   EXPECT_FALSE(shell()->web_contents()->IsCrashed()); | 
 | } | 
 |  | 
 | }  // namespace content |