OLD | NEW |
1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 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/loader/mime_sniffing_resource_handler.h" | 5 #include "content/browser/loader/mime_sniffing_resource_handler.h" |
6 | 6 |
7 #include <stdint.h> | 7 #include <stdint.h> |
8 | 8 |
9 #include <memory> | 9 #include <memory> |
10 | 10 |
11 #include "base/files/file_path.h" | 11 #include "base/files/file_path.h" |
12 #include "base/location.h" | 12 #include "base/location.h" |
13 #include "base/logging.h" | 13 #include "base/logging.h" |
14 #include "base/macros.h" | 14 #include "base/macros.h" |
15 #include "base/memory/ptr_util.h" | 15 #include "base/memory/ptr_util.h" |
16 #include "base/single_thread_task_runner.h" | 16 #include "base/single_thread_task_runner.h" |
17 #include "base/threading/thread_task_runner_handle.h" | 17 #include "base/threading/thread_task_runner_handle.h" |
18 #include "content/browser/loader/intercepting_resource_handler.h" | 18 #include "content/browser/loader/intercepting_resource_handler.h" |
19 #include "content/browser/loader/resource_dispatcher_host_impl.h" | 19 #include "content/browser/loader/resource_dispatcher_host_impl.h" |
20 #include "content/browser/loader/test_resource_handler.h" | 20 #include "content/browser/loader/test_resource_handler.h" |
21 #include "content/public/browser/resource_controller.h" | 21 #include "content/public/browser/resource_controller.h" |
22 #include "content/public/browser/resource_dispatcher_host_delegate.h" | 22 #include "content/public/browser/resource_dispatcher_host_delegate.h" |
23 #include "content/public/browser/resource_request_info.h" | 23 #include "content/public/browser/resource_request_info.h" |
24 #include "content/public/common/resource_response.h" | 24 #include "content/public/common/resource_response.h" |
25 #include "content/public/common/webplugininfo.h" | 25 #include "content/public/common/webplugininfo.h" |
26 #include "content/public/test/test_browser_thread_bundle.h" | 26 #include "content/public/test/test_browser_thread_bundle.h" |
27 #include "content/public/test/test_utils.h" | 27 #include "content/public/test/test_utils.h" |
28 #include "content/test/fake_plugin_service.h" | 28 #include "content/test/fake_plugin_service.h" |
29 #include "net/url_request/url_request_context.h" | 29 #include "net/url_request/url_request_context.h" |
| 30 #include "ppapi/features/features.h" |
30 #include "testing/gtest/include/gtest/gtest.h" | 31 #include "testing/gtest/include/gtest/gtest.h" |
31 #include "url/gurl.h" | 32 #include "url/gurl.h" |
32 #include "url/origin.h" | 33 #include "url/origin.h" |
33 | 34 |
34 namespace content { | 35 namespace content { |
35 | 36 |
36 namespace { | 37 namespace { |
37 | 38 |
38 class TestResourceDispatcherHostDelegate | 39 class TestResourceDispatcherHostDelegate |
39 : public ResourceDispatcherHostDelegate { | 40 : public ResourceDispatcherHostDelegate { |
(...skipping 621 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
661 net::URLRequestContext context; | 662 net::URLRequestContext context; |
662 std::unique_ptr<net::URLRequest> request(context.CreateRequest( | 663 std::unique_ptr<net::URLRequest> request(context.CreateRequest( |
663 GURL("http://www.google.com"), net::DEFAULT_PRIORITY, nullptr)); | 664 GURL("http://www.google.com"), net::DEFAULT_PRIORITY, nullptr)); |
664 request->SetExtraRequestHeaderByName("Accept", "*", true); | 665 request->SetExtraRequestHeaderByName("Accept", "*", true); |
665 EXPECT_EQ("*", TestAcceptHeaderSettingWithURLRequest(RESOURCE_TYPE_XHR, | 666 EXPECT_EQ("*", TestAcceptHeaderSettingWithURLRequest(RESOURCE_TYPE_XHR, |
666 request.get())); | 667 request.get())); |
667 } | 668 } |
668 | 669 |
669 // Test that stream requests are correctly intercepted under the right | 670 // Test that stream requests are correctly intercepted under the right |
670 // circumstances. Test is not relevent when plugins are disabled. | 671 // circumstances. Test is not relevent when plugins are disabled. |
671 #if defined(ENABLE_PLUGINS) | 672 #if BUILDFLAG(ENABLE_PLUGINS) |
672 TEST_F(MimeSniffingResourceHandlerTest, StreamHandling) { | 673 TEST_F(MimeSniffingResourceHandlerTest, StreamHandling) { |
673 bool allow_download; | 674 bool allow_download; |
674 bool must_download; | 675 bool must_download; |
675 ResourceType resource_type; | 676 ResourceType resource_type; |
676 | 677 |
677 // Ensure the stream is handled by MaybeInterceptAsStream in the | 678 // Ensure the stream is handled by MaybeInterceptAsStream in the |
678 // ResourceDispatcherHost. | 679 // ResourceDispatcherHost. |
679 set_stream_has_handler(true); | 680 set_stream_has_handler(true); |
680 set_plugin_available(true); | 681 set_plugin_available(true); |
681 | 682 |
(...skipping 310 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
992 // mime sniffing is disabled and the wrapped resource handler returns false | 993 // mime sniffing is disabled and the wrapped resource handler returns false |
993 // on OnResponseStarted. | 994 // on OnResponseStarted. |
994 EXPECT_FALSE( | 995 EXPECT_FALSE( |
995 mime_sniffing_handler->OnResponseStarted(response.get(), &defer)); | 996 mime_sniffing_handler->OnResponseStarted(response.get(), &defer)); |
996 | 997 |
997 // Process all messages to ensure proper test teardown. | 998 // Process all messages to ensure proper test teardown. |
998 content::RunAllPendingInMessageLoop(); | 999 content::RunAllPendingInMessageLoop(); |
999 } | 1000 } |
1000 | 1001 |
1001 } // namespace content | 1002 } // namespace content |
OLD | NEW |