OLD | NEW |
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 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 | 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 "chrome/browser/prerender/prerender_manager.h" | 5 #include "chrome/browser/prerender/prerender_manager.h" |
6 | 6 |
7 #include <stddef.h> | 7 #include <stddef.h> |
8 | 8 |
9 #include <algorithm> | 9 #include <algorithm> |
10 #include <functional> | 10 #include <functional> |
11 #include <string> | 11 #include <string> |
12 #include <utility> | 12 #include <utility> |
13 #include <vector> | 13 #include <vector> |
14 | 14 |
15 #include "base/bind.h" | 15 #include "base/bind.h" |
16 #include "base/bind_helpers.h" | 16 #include "base/bind_helpers.h" |
17 #include "base/location.h" | 17 #include "base/location.h" |
18 #include "base/logging.h" | 18 #include "base/logging.h" |
19 #include "base/macros.h" | 19 #include "base/macros.h" |
20 #include "base/memory/ptr_util.h" | 20 #include "base/memory/ptr_util.h" |
| 21 #include "base/metrics/field_trial.h" |
21 #include "base/metrics/histogram.h" | 22 #include "base/metrics/histogram.h" |
22 #include "base/single_thread_task_runner.h" | 23 #include "base/single_thread_task_runner.h" |
23 #include "base/sys_info.h" | 24 #include "base/sys_info.h" |
24 #include "base/threading/thread_task_runner_handle.h" | 25 #include "base/threading/thread_task_runner_handle.h" |
25 #include "base/time/time.h" | 26 #include "base/time/time.h" |
26 #include "base/timer/elapsed_timer.h" | 27 #include "base/timer/elapsed_timer.h" |
27 #include "base/values.h" | 28 #include "base/values.h" |
28 #include "chrome/browser/chrome_notification_types.h" | 29 #include "chrome/browser/chrome_notification_types.h" |
29 #include "chrome/browser/net/prediction_options.h" | 30 #include "chrome/browser/net/prediction_options.h" |
30 #include "chrome/browser/prerender/prerender_contents.h" | 31 #include "chrome/browser/prerender/prerender_contents.h" |
(...skipping 844 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
875 // those prerenders is managed by the offliner. | 876 // those prerenders is managed by the offliner. |
876 if (IsLowEndDevice() && origin != ORIGIN_OFFLINE) | 877 if (IsLowEndDevice() && origin != ORIGIN_OFFLINE) |
877 return nullptr; | 878 return nullptr; |
878 | 879 |
879 if ((origin == ORIGIN_LINK_REL_PRERENDER_CROSSDOMAIN || | 880 if ((origin == ORIGIN_LINK_REL_PRERENDER_CROSSDOMAIN || |
880 origin == ORIGIN_LINK_REL_PRERENDER_SAMEDOMAIN) && | 881 origin == ORIGIN_LINK_REL_PRERENDER_SAMEDOMAIN) && |
881 IsGoogleSearchResultURL(referrer.url)) { | 882 IsGoogleSearchResultURL(referrer.url)) { |
882 origin = ORIGIN_GWS_PRERENDER; | 883 origin = ORIGIN_GWS_PRERENDER; |
883 } | 884 } |
884 | 885 |
| 886 if (IsPrerenderSilenceExperiment(origin)) |
| 887 return nullptr; |
| 888 |
885 GURL url = url_arg; | 889 GURL url = url_arg; |
886 GURL alias_url; | 890 GURL alias_url; |
887 if (IsControlGroup() && MaybeGetQueryStringBasedAliasURL(url, &alias_url)) | 891 if (IsControlGroup() && MaybeGetQueryStringBasedAliasURL(url, &alias_url)) |
888 url = alias_url; | 892 url = alias_url; |
889 | 893 |
890 // From here on, we will record a FinalStatus so we need to register with the | 894 // From here on, we will record a FinalStatus so we need to register with the |
891 // histogram tracking. | 895 // histogram tracking. |
892 histograms_->RecordPrerender(origin, url_arg); | 896 histograms_->RecordPrerender(origin, url_arg); |
893 | 897 |
894 if (profile_->GetPrefs()->GetBoolean(prefs::kBlockThirdPartyCookies) && | 898 if (profile_->GetPrefs()->GetBoolean(prefs::kBlockThirdPartyCookies) && |
(...skipping 338 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1233 if (!ActuallyPrerendering()) | 1237 if (!ActuallyPrerendering()) |
1234 return; | 1238 return; |
1235 int64_t recent_profile_bytes = | 1239 int64_t recent_profile_bytes = |
1236 profile_network_bytes_ - last_recorded_profile_network_bytes_; | 1240 profile_network_bytes_ - last_recorded_profile_network_bytes_; |
1237 last_recorded_profile_network_bytes_ = profile_network_bytes_; | 1241 last_recorded_profile_network_bytes_ = profile_network_bytes_; |
1238 DCHECK_GE(recent_profile_bytes, 0); | 1242 DCHECK_GE(recent_profile_bytes, 0); |
1239 histograms_->RecordNetworkBytes( | 1243 histograms_->RecordNetworkBytes( |
1240 origin, used, prerender_bytes, recent_profile_bytes); | 1244 origin, used, prerender_bytes, recent_profile_bytes); |
1241 } | 1245 } |
1242 | 1246 |
| 1247 bool PrerenderManager::IsPrerenderSilenceExperiment(Origin origin) const { |
| 1248 if (origin == ORIGIN_OFFLINE) |
| 1249 return false; |
| 1250 |
| 1251 // The group name should contain expiration time formatted as: |
| 1252 // "ExperimentYes_expires_YYYY-MM-DDTHH:MM:SSZ". |
| 1253 std::string group_name = |
| 1254 base::FieldTrialList::FindFullName("PrerenderSilence"); |
| 1255 const char kExperimentPrefix[] = "ExperimentYes"; |
| 1256 if (!base::StartsWith(group_name, kExperimentPrefix, |
| 1257 base::CompareCase::INSENSITIVE_ASCII)) { |
| 1258 return false; |
| 1259 } |
| 1260 const char kExperimentPrefixWithExpiration[] = "ExperimentYes_expires_"; |
| 1261 if (!base::StartsWith(group_name, kExperimentPrefixWithExpiration, |
| 1262 base::CompareCase::INSENSITIVE_ASCII)) { |
| 1263 // Without expiration day in the group name, behave as a normal experiment, |
| 1264 // i.e. sticky to the Chrome session. |
| 1265 return true; |
| 1266 } |
| 1267 base::Time expiration_time; |
| 1268 if (!base::Time::FromString( |
| 1269 group_name.c_str() + (arraysize(kExperimentPrefixWithExpiration) - 1), |
| 1270 &expiration_time)) { |
| 1271 DLOG(ERROR) << "Could not parse expiration date in group: " << group_name; |
| 1272 return false; |
| 1273 } |
| 1274 return GetCurrentTime() < expiration_time; |
| 1275 } |
| 1276 |
1243 NetworkPredictionStatus PrerenderManager::GetPredictionStatus() const { | 1277 NetworkPredictionStatus PrerenderManager::GetPredictionStatus() const { |
1244 DCHECK_CURRENTLY_ON(BrowserThread::UI); | 1278 DCHECK_CURRENTLY_ON(BrowserThread::UI); |
1245 return CanPrefetchAndPrerenderUI(profile_->GetPrefs()); | 1279 return CanPrefetchAndPrerenderUI(profile_->GetPrefs()); |
1246 } | 1280 } |
1247 | 1281 |
1248 NetworkPredictionStatus PrerenderManager::GetPredictionStatusForOrigin( | 1282 NetworkPredictionStatus PrerenderManager::GetPredictionStatusForOrigin( |
1249 Origin origin) const { | 1283 Origin origin) const { |
1250 DCHECK_CURRENTLY_ON(BrowserThread::UI); | 1284 DCHECK_CURRENTLY_ON(BrowserThread::UI); |
1251 | 1285 |
1252 // <link rel=prerender> origins ignore the network state and the privacy | 1286 // <link rel=prerender> origins ignore the network state and the privacy |
(...skipping 54 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1307 DCHECK_EQ(1u, erased); | 1341 DCHECK_EQ(1u, erased); |
1308 } | 1342 } |
1309 | 1343 |
1310 void PrerenderManager::SetPrerenderContentsFactoryForTest( | 1344 void PrerenderManager::SetPrerenderContentsFactoryForTest( |
1311 PrerenderContents::Factory* prerender_contents_factory) { | 1345 PrerenderContents::Factory* prerender_contents_factory) { |
1312 DCHECK_CURRENTLY_ON(BrowserThread::UI); | 1346 DCHECK_CURRENTLY_ON(BrowserThread::UI); |
1313 prerender_contents_factory_.reset(prerender_contents_factory); | 1347 prerender_contents_factory_.reset(prerender_contents_factory); |
1314 } | 1348 } |
1315 | 1349 |
1316 } // namespace prerender | 1350 } // namespace prerender |
OLD | NEW |