OLD | NEW |
1 // Copyright 2013 The Chromium Authors. All rights reserved. | 1 // Copyright 2013 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 "base/command_line.h" | 5 #include "base/command_line.h" |
6 #include "base/prefs/pref_service.h" | 6 #include "base/prefs/pref_service.h" |
7 #include "base/run_loop.h" | 7 #include "base/run_loop.h" |
8 #include "base/strings/utf_string_conversions.h" | 8 #include "base/strings/utf_string_conversions.h" |
9 #include "chrome/browser/net/prediction_options.h" | 9 #include "chrome/browser/net/prediction_options.h" |
10 #include "chrome/browser/profiles/profile.h" | 10 #include "chrome/browser/profiles/profile.h" |
(...skipping 14 matching lines...) Expand all Loading... |
25 using chrome_browser_net::NetworkPredictionOptions; | 25 using chrome_browser_net::NetworkPredictionOptions; |
26 using content::BrowserThread; | 26 using content::BrowserThread; |
27 using net::NetworkChangeNotifier; | 27 using net::NetworkChangeNotifier; |
28 | 28 |
29 namespace { | 29 namespace { |
30 | 30 |
31 const char kPrefetchPage[] = "files/prerender/simple_prefetch.html"; | 31 const char kPrefetchPage[] = "files/prerender/simple_prefetch.html"; |
32 | 32 |
33 class MockNetworkChangeNotifierWIFI : public NetworkChangeNotifier { | 33 class MockNetworkChangeNotifierWIFI : public NetworkChangeNotifier { |
34 public: | 34 public: |
35 virtual ConnectionType GetCurrentConnectionType() const OVERRIDE { | 35 virtual ConnectionType GetCurrentConnectionType() const override { |
36 return NetworkChangeNotifier::CONNECTION_WIFI; | 36 return NetworkChangeNotifier::CONNECTION_WIFI; |
37 } | 37 } |
38 }; | 38 }; |
39 | 39 |
40 class MockNetworkChangeNotifier4G : public NetworkChangeNotifier { | 40 class MockNetworkChangeNotifier4G : public NetworkChangeNotifier { |
41 public: | 41 public: |
42 virtual ConnectionType GetCurrentConnectionType() const OVERRIDE { | 42 virtual ConnectionType GetCurrentConnectionType() const override { |
43 return NetworkChangeNotifier::CONNECTION_4G; | 43 return NetworkChangeNotifier::CONNECTION_4G; |
44 } | 44 } |
45 }; | 45 }; |
46 | 46 |
47 class PrefetchBrowserTestBase : public InProcessBrowserTest { | 47 class PrefetchBrowserTestBase : public InProcessBrowserTest { |
48 public: | 48 public: |
49 explicit PrefetchBrowserTestBase(bool disabled_via_field_trial) | 49 explicit PrefetchBrowserTestBase(bool disabled_via_field_trial) |
50 : disabled_via_field_trial_(disabled_via_field_trial) {} | 50 : disabled_via_field_trial_(disabled_via_field_trial) {} |
51 | 51 |
52 virtual void SetUpCommandLine(CommandLine* command_line) OVERRIDE { | 52 virtual void SetUpCommandLine(CommandLine* command_line) override { |
53 if (disabled_via_field_trial_) { | 53 if (disabled_via_field_trial_) { |
54 command_line->AppendSwitchASCII(switches::kForceFieldTrials, | 54 command_line->AppendSwitchASCII(switches::kForceFieldTrials, |
55 "Prefetch/ExperimentDisabled/"); | 55 "Prefetch/ExperimentDisabled/"); |
56 } | 56 } |
57 } | 57 } |
58 | 58 |
59 void SetPreference(NetworkPredictionOptions value) { | 59 void SetPreference(NetworkPredictionOptions value) { |
60 browser()->profile()->GetPrefs()->SetInteger( | 60 browser()->profile()->GetPrefs()->SetInteger( |
61 prefs::kNetworkPredictionOptions, value); | 61 prefs::kNetworkPredictionOptions, value); |
62 } | 62 } |
(...skipping 25 matching lines...) Expand all Loading... |
88 }; | 88 }; |
89 | 89 |
90 // URLRequestJob (and associated handler) which hangs. | 90 // URLRequestJob (and associated handler) which hangs. |
91 class HangingURLRequestJob : public net::URLRequestJob { | 91 class HangingURLRequestJob : public net::URLRequestJob { |
92 public: | 92 public: |
93 HangingURLRequestJob(net::URLRequest* request, | 93 HangingURLRequestJob(net::URLRequest* request, |
94 net::NetworkDelegate* network_delegate) | 94 net::NetworkDelegate* network_delegate) |
95 : net::URLRequestJob(request, network_delegate) {} | 95 : net::URLRequestJob(request, network_delegate) {} |
96 | 96 |
97 // net::URLRequestJob implementation | 97 // net::URLRequestJob implementation |
98 virtual void Start() OVERRIDE {} | 98 virtual void Start() override {} |
99 | 99 |
100 private: | 100 private: |
101 virtual ~HangingURLRequestJob() {} | 101 virtual ~HangingURLRequestJob() {} |
102 | 102 |
103 DISALLOW_COPY_AND_ASSIGN(HangingURLRequestJob); | 103 DISALLOW_COPY_AND_ASSIGN(HangingURLRequestJob); |
104 }; | 104 }; |
105 | 105 |
106 class HangingRequestInterceptor : public net::URLRequestInterceptor { | 106 class HangingRequestInterceptor : public net::URLRequestInterceptor { |
107 public: | 107 public: |
108 explicit HangingRequestInterceptor(const base::Closure& callback) | 108 explicit HangingRequestInterceptor(const base::Closure& callback) |
109 : callback_(callback) {} | 109 : callback_(callback) {} |
110 | 110 |
111 virtual ~HangingRequestInterceptor() {} | 111 virtual ~HangingRequestInterceptor() {} |
112 | 112 |
113 virtual net::URLRequestJob* MaybeInterceptRequest( | 113 virtual net::URLRequestJob* MaybeInterceptRequest( |
114 net::URLRequest* request, | 114 net::URLRequest* request, |
115 net::NetworkDelegate* network_delegate) const OVERRIDE { | 115 net::NetworkDelegate* network_delegate) const override { |
116 if (!callback_.is_null()) | 116 if (!callback_.is_null()) |
117 BrowserThread::PostTask(BrowserThread::UI, FROM_HERE, callback_); | 117 BrowserThread::PostTask(BrowserThread::UI, FROM_HERE, callback_); |
118 return new HangingURLRequestJob(request, network_delegate); | 118 return new HangingURLRequestJob(request, network_delegate); |
119 } | 119 } |
120 | 120 |
121 private: | 121 private: |
122 base::Closure callback_; | 122 base::Closure callback_; |
123 }; | 123 }; |
124 | 124 |
125 void CreateHangingRequestInterceptorOnIO(const GURL& url, | 125 void CreateHangingRequestInterceptorOnIO(const GURL& url, |
(...skipping 84 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
210 kHangingUrl, | 210 kHangingUrl, |
211 loop_.QuitClosure())); | 211 loop_.QuitClosure())); |
212 ui_test_utils::NavigateToURL(browser(), GURL("about:blank")); | 212 ui_test_utils::NavigateToURL(browser(), GURL("about:blank")); |
213 content::RenderFrameHost* rfh = | 213 content::RenderFrameHost* rfh = |
214 browser()->tab_strip_model()->GetActiveWebContents()->GetMainFrame(); | 214 browser()->tab_strip_model()->GetActiveWebContents()->GetMainFrame(); |
215 rfh->Send(new PrefetchMsg_Prefetch(rfh->GetRoutingID(), kHangingUrl)); | 215 rfh->Send(new PrefetchMsg_Prefetch(rfh->GetRoutingID(), kHangingUrl)); |
216 loop_.Run(); | 216 loop_.Run(); |
217 } | 217 } |
218 | 218 |
219 } // namespace | 219 } // namespace |
OLD | NEW |