Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(454)

Unified Diff: chrome/browser/predictors/loading_predictor.cc

Issue 2887133003: predictors: Refactor resource_prefetch_predictor triggering. (Closed)
Patch Set: . Created 3 years, 7 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: chrome/browser/predictors/loading_predictor.cc
diff --git a/chrome/browser/predictors/loading_predictor.cc b/chrome/browser/predictors/loading_predictor.cc
index d5bd264009427aead4df1a4926e85807fee38f60..9f19112c52596dbb4a831daf55442b34a1a9ea08 100644
--- a/chrome/browser/predictors/loading_predictor.cc
+++ b/chrome/browser/predictors/loading_predictor.cc
@@ -5,24 +5,39 @@
#include "chrome/browser/predictors/loading_predictor.h"
#include "base/memory/ptr_util.h"
+#include "base/metrics/histogram_macros.h"
+#include "chrome/browser/predictors/resource_prefetch_common.h"
#include "chrome/browser/predictors/resource_prefetch_predictor.h"
namespace predictors {
+using URLRequestSummary = ResourcePrefetchPredictor::URLRequestSummary;
+
LoadingPredictor::LoadingPredictor(const LoadingPredictorConfig& config,
- Profile* profile) {
- resource_prefetch_predictor_ =
- base::MakeUnique<ResourcePrefetchPredictor>(config, profile);
-}
+ Profile* profile)
+ : config_(config),
+ profile_(profile),
+ resource_prefetch_predictor_(
+ base::MakeUnique<ResourcePrefetchPredictor>(config, profile)) {}
LoadingPredictor::~LoadingPredictor() = default;
void LoadingPredictor::PrepareForPageLoad(const GURL& url, HintOrigin origin) {
- resource_prefetch_predictor_->StartPrefetching(url, origin);
+ // To report hint durations.
+ if (active_hints_.find(url) == active_hints_.end())
+ active_hints_.emplace(url, base::TimeTicks::Now());
alexilin 2017/05/30 16:19:14 We used to report a hint duration only for prefetc
Benoit L 2017/05/31 14:34:41 Done.
+
+ if (!config_.IsPrefetchingEnabledForOrigin(profile_, origin) ||
+ !resource_prefetch_predictor_->IsUrlPrefetchable(url)) {
alexilin 2017/05/30 16:19:14 nit: There is no real need to check for IsUrlPrefe
Benoit L 2017/05/31 14:34:42 Kept the check anyway, both for tracking and also
+ return;
+ }
+
+ resource_prefetch_predictor_->StartPrefetching(url);
alexilin 2017/05/30 16:19:14 Should we do something if the url is already in ac
Benoit L 2017/05/31 14:34:41 Done.
}
void LoadingPredictor::CancelPageLoadHint(const GURL& url) {
- resource_prefetch_predictor_->StopPrefetching(url);
+ auto it = active_hints_.find(url);
+ CancelActiveHint(it);
alexilin 2017/05/30 16:19:14 tiny tiny nit: Why not in one line? CancelActiveHi
Benoit L 2017/05/31 14:34:41 Done.
}
void LoadingPredictor::StartInitialization() {
@@ -38,4 +53,80 @@ void LoadingPredictor::Shutdown() {
resource_prefetch_predictor_->Shutdown();
}
+void LoadingPredictor::OnMainFrameRequest(const URLRequestSummary& summary) {
+ const NavigationID& navigation_id = summary.navigation_id;
+ CleanupAbandonedHintsAndNavigations(navigation_id);
+ active_navigations_.emplace(
alexilin 2017/05/30 11:55:27 Shouldn't it be a part of LoadingDataCollector? I'
Benoit L 2017/05/31 14:34:42 After offline discussion, decided to keep it this
+ navigation_id,
+ std::make_pair(navigation_id.main_frame_url, base::TimeTicks::Now()));
alexilin 2017/05/30 16:19:14 The second member of the pair is unused. You're us
Benoit L 2017/05/31 14:34:41 Done.
+ PrepareForPageLoad(navigation_id.main_frame_url, HintOrigin::NAVIGATION);
+}
+
+void LoadingPredictor::OnMainFrameRedirect(const URLRequestSummary& summary) {
+ auto it = active_navigations_.find(summary.navigation_id);
+ if (it != active_navigations_.end()) {
+ NavigationID navigation_id = summary.navigation_id;
+ navigation_id.main_frame_url = summary.redirect_url;
alexilin 2017/05/30 16:19:14 What if redirect_url == main_frame_url? I know red
Benoit L 2017/05/31 14:34:42 That's likely filtered lower in the stack (as unle
alexilin 2017/05/31 16:02:03 Well, a redirect response could set a new cookie s
+ active_navigations_.emplace(navigation_id, it->second);
+ active_navigations_.erase(it);
+ }
+}
+
+void LoadingPredictor::OnMainFrameResponse(const URLRequestSummary& summary) {
+ const NavigationID& navigation_id = summary.navigation_id;
+ auto it = active_navigations_.find(navigation_id);
+ if (it != active_navigations_.end()) {
+ const auto& initial_url = it->second.first;
alexilin 2017/05/30 16:19:14 nit: s/auto/GURL/ since it's the same number of ch
Benoit L 2017/05/31 14:34:42 Done.
+ CancelPageLoadHint(initial_url);
+ active_navigations_.erase(it);
+ } else {
+ CancelPageLoadHint(navigation_id.main_frame_url);
+ }
+}
+
+std::map<GURL, base::TimeTicks>::iterator LoadingPredictor::CancelActiveHint(
+ std::map<GURL, base::TimeTicks>::iterator hint_it) {
+ if (hint_it == active_hints_.end())
+ return hint_it;
+
+ const GURL& url = hint_it->first;
+ resource_prefetch_predictor_->StopPrefetching(url);
+
+ UMA_HISTOGRAM_TIMES(
+ internal::kResourcePrefetchPredictorPrefetchingDurationHistogram,
+ base::TimeTicks::Now() - hint_it->second);
+ return active_hints_.erase(hint_it);
+}
+
+void LoadingPredictor::CleanupAbandonedHintsAndNavigations(
+ const NavigationID& navigation_id) {
+ base::TimeTicks time_now = base::TimeTicks::Now();
+ const base::TimeDelta max_navigation_age =
+ base::TimeDelta::FromSeconds(config_.max_navigation_lifetime_seconds);
+
+ // Hints.
+ for (auto it = active_hints_.begin(); it != active_hints_.end();) {
+ base::TimeDelta prefetch_age = time_now - it->second;
+ if (prefetch_age > max_navigation_age) {
+ // Will to the last bucket meaning that the duration was unlimited.
alexilin 2017/05/30 15:06:00 nit: Delete the comment because it isn't relevant.
Benoit L 2017/05/31 14:34:41 I actually wanted to point that out, clarified the
alexilin 2017/05/31 16:02:03 s/Will to/Will go to/ Initially I was confused by
+ it = CancelActiveHint(it);
+ } else {
+ ++it;
+ }
+ }
+
+ // Navigations.
+ for (auto it = active_navigations_.begin();
+ it != active_navigations_.end();) {
+ if ((it->first.tab_id == navigation_id.tab_id) ||
+ (time_now - it->first.creation_time > max_navigation_age)) {
+ const GURL& initial_url = it->second.first;
+ CancelActiveHint(active_hints_.find(initial_url));
alexilin 2017/05/30 16:19:14 nit: CancelPageLoadHint(initial_url) since we don'
Benoit L 2017/05/31 14:34:41 I would prefer to keep it as is to be consistent w
+ it = active_navigations_.erase(it);
+ } else {
+ ++it;
+ }
+ }
+}
+
} // namespace predictors

Powered by Google App Engine
This is Rietveld 408576698