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

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

Issue 2896713003: Create LoadingDataCollector class and have observers rely on it instead of ResourcePrefetchPredictor (Closed)
Patch Set: Rebase Created 3 years, 6 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/resource_prefetch_predictor_test_util.cc
diff --git a/chrome/browser/predictors/resource_prefetch_predictor_test_util.cc b/chrome/browser/predictors/resource_prefetch_predictor_test_util.cc
deleted file mode 100644
index 4f6e93cdda46c89f8257f544feab52245949c405..0000000000000000000000000000000000000000
--- a/chrome/browser/predictors/resource_prefetch_predictor_test_util.cc
+++ /dev/null
@@ -1,405 +0,0 @@
-// Copyright 2016 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 "chrome/browser/predictors/resource_prefetch_predictor_test_util.h"
-
-#include <cmath>
-
-namespace {
-
-bool AlmostEqual(const double x, const double y) {
- return std::fabs(x - y) <= 1e-6; // Arbitrary but close enough.
-}
-
-} // namespace
-
-namespace predictors {
-
-using URLRequestSummary = ResourcePrefetchPredictor::URLRequestSummary;
-using PageRequestSummary = ResourcePrefetchPredictor::PageRequestSummary;
-using Prediction = ResourcePrefetchPredictor::Prediction;
-
-MockResourcePrefetchPredictor::MockResourcePrefetchPredictor(
- const LoadingPredictorConfig& config,
- Profile* profile)
- : ResourcePrefetchPredictor(config, profile) {}
-
-MockResourcePrefetchPredictor::~MockResourcePrefetchPredictor() = default;
-
-void InitializeResourceData(ResourceData* resource,
- const std::string& resource_url,
- content::ResourceType resource_type,
- int number_of_hits,
- int number_of_misses,
- int consecutive_misses,
- double average_position,
- net::RequestPriority priority,
- bool has_validators,
- bool always_revalidate) {
- resource->set_resource_url(resource_url);
- resource->set_resource_type(
- static_cast<ResourceData::ResourceType>(resource_type));
- resource->set_number_of_hits(number_of_hits);
- resource->set_number_of_misses(number_of_misses);
- resource->set_consecutive_misses(consecutive_misses);
- resource->set_average_position(average_position);
- resource->set_priority(static_cast<ResourceData::Priority>(priority));
- resource->set_before_first_contentful_paint(true);
- resource->set_has_validators(has_validators);
- resource->set_always_revalidate(always_revalidate);
-}
-
-void InitializeRedirectStat(RedirectStat* redirect,
- const std::string& url,
- int number_of_hits,
- int number_of_misses,
- int consecutive_misses) {
- redirect->set_url(url);
- redirect->set_number_of_hits(number_of_hits);
- redirect->set_number_of_misses(number_of_misses);
- redirect->set_consecutive_misses(consecutive_misses);
-}
-
-void InitializePrecacheResource(precache::PrecacheResource* resource,
- const std::string& url,
- double weight_ratio,
- precache::PrecacheResource::Type type) {
- resource->set_url(url);
- resource->set_weight_ratio(weight_ratio);
- resource->set_type(type);
-}
-
-void InitializeOriginStat(OriginStat* origin_stat,
- const std::string& origin,
- int number_of_hits,
- int number_of_misses,
- int consecutive_misses,
- double average_position,
- bool always_access_network,
- bool accessed_network) {
- origin_stat->set_origin(origin);
- origin_stat->set_number_of_hits(number_of_hits);
- origin_stat->set_number_of_misses(number_of_misses);
- origin_stat->set_consecutive_misses(consecutive_misses);
- origin_stat->set_average_position(average_position);
- origin_stat->set_always_access_network(always_access_network);
- origin_stat->set_accessed_network(accessed_network);
-}
-
-void InitializeExperiment(precache::PrecacheManifest* manifest,
- uint32_t experiment_id,
- const std::vector<bool>& bitset) {
- std::string binary_bitset;
- for (size_t i = 0; i < (bitset.size() + 7) / 8; ++i) {
- char c = 0;
- for (size_t j = 0; j < 8; ++j) {
- if (i * 8 + j < bitset.size() && bitset[i * 8 + j])
- c |= (1 << j);
- }
- binary_bitset.push_back(c);
- }
-
- precache::PrecacheResourceSelection prs;
- prs.set_bitset(binary_bitset);
- (*manifest->mutable_experiments()
- ->mutable_resources_by_experiment_group())[experiment_id] = prs;
-}
-
-PrefetchData CreatePrefetchData(const std::string& primary_key,
- uint64_t last_visit_time) {
- PrefetchData data;
- data.set_primary_key(primary_key);
- data.set_last_visit_time(last_visit_time);
- return data;
-}
-
-RedirectData CreateRedirectData(const std::string& primary_key,
- uint64_t last_visit_time) {
- RedirectData data;
- data.set_primary_key(primary_key);
- data.set_last_visit_time(last_visit_time);
- return data;
-}
-
-precache::PrecacheManifest CreateManifestData(int64_t id) {
- precache::PrecacheManifest manifest;
- manifest.mutable_id()->set_id(id);
- return manifest;
-}
-
-OriginData CreateOriginData(const std::string& host, uint64_t last_visit_time) {
- OriginData data;
- data.set_host(host);
- data.set_last_visit_time(last_visit_time);
- return data;
-}
-
-NavigationID CreateNavigationID(SessionID::id_type tab_id,
- const std::string& main_frame_url) {
- NavigationID navigation_id;
- navigation_id.tab_id = tab_id;
- navigation_id.main_frame_url = GURL(main_frame_url);
- navigation_id.creation_time = base::TimeTicks::Now();
- return navigation_id;
-}
-
-PageRequestSummary CreatePageRequestSummary(
- const std::string& main_frame_url,
- const std::string& initial_url,
- const std::vector<URLRequestSummary>& subresource_requests) {
- GURL main_frame_gurl(main_frame_url);
- PageRequestSummary summary(main_frame_gurl);
- summary.initial_url = GURL(initial_url);
- summary.subresource_requests = subresource_requests;
- return summary;
-}
-
-URLRequestSummary CreateURLRequestSummary(SessionID::id_type tab_id,
- const std::string& main_frame_url,
- const std::string& resource_url,
- content::ResourceType resource_type,
- net::RequestPriority priority,
- const std::string& mime_type,
- bool was_cached,
- const std::string& redirect_url,
- bool has_validators,
- bool always_revalidate) {
- URLRequestSummary summary;
- summary.navigation_id = CreateNavigationID(tab_id, main_frame_url);
- summary.resource_url =
- resource_url.empty() ? GURL(main_frame_url) : GURL(resource_url);
- summary.request_url = summary.resource_url;
- summary.resource_type = resource_type;
- summary.priority = priority;
- summary.before_first_contentful_paint = true;
- summary.mime_type = mime_type;
- summary.was_cached = was_cached;
- if (!redirect_url.empty())
- summary.redirect_url = GURL(redirect_url);
- summary.has_validators = has_validators;
- summary.always_revalidate = always_revalidate;
- summary.is_no_store = false;
- summary.network_accessed = true;
- return summary;
-}
-
-ResourcePrefetchPredictor::Prediction CreatePrediction(
- const std::string& main_frame_key,
- std::vector<GURL> subresource_urls) {
- Prediction prediction;
- prediction.main_frame_key = main_frame_key;
- prediction.subresource_urls = subresource_urls;
- prediction.is_host = true;
- prediction.is_redirected = false;
- return prediction;
-}
-
-void PopulateTestConfig(LoadingPredictorConfig* config, bool small_db) {
- if (small_db) {
- config->max_urls_to_track = 3;
- config->max_hosts_to_track = 2;
- config->min_url_visit_count = 2;
- config->max_resources_per_entry = 4;
- config->max_consecutive_misses = 2;
- config->max_redirect_consecutive_misses = 2;
- config->min_resource_confidence_to_trigger_prefetch = 0.5;
- }
- config->is_url_learning_enabled = true;
- config->is_manifests_enabled = true;
- config->is_origin_learning_enabled = true;
- config->mode = LoadingPredictorConfig::LEARNING;
-}
-
-std::ostream& operator<<(std::ostream& os, const PrefetchData& data) {
- os << "[" << data.primary_key() << "," << data.last_visit_time() << "]"
- << std::endl;
- for (const ResourceData& resource : data.resources())
- os << "\t\t" << resource << std::endl;
- return os;
-}
-
-std::ostream& operator<<(std::ostream& os, const ResourceData& resource) {
- return os << "[" << resource.resource_url() << "," << resource.resource_type()
- << "," << resource.number_of_hits() << ","
- << resource.number_of_misses() << ","
- << resource.consecutive_misses() << ","
- << resource.average_position() << "," << resource.priority() << ","
- << resource.before_first_contentful_paint() << ","
- << resource.has_validators() << "," << resource.always_revalidate()
- << "]";
-}
-
-std::ostream& operator<<(std::ostream& os, const RedirectData& data) {
- os << "[" << data.primary_key() << "," << data.last_visit_time() << "]"
- << std::endl;
- for (const RedirectStat& redirect : data.redirect_endpoints())
- os << "\t\t" << redirect << std::endl;
- return os;
-}
-
-std::ostream& operator<<(std::ostream& os, const RedirectStat& redirect) {
- return os << "[" << redirect.url() << "," << redirect.number_of_hits() << ","
- << redirect.number_of_misses() << ","
- << redirect.consecutive_misses() << "]";
-}
-
-std::ostream& operator<<(std::ostream& os, const OriginData& data) {
- os << "[" << data.host() << "," << data.last_visit_time() << "]" << std::endl;
- for (const OriginStat& origin : data.origins())
- os << "\t\t" << origin << std::endl;
- return os;
-}
-
-std::ostream& operator<<(std::ostream& os, const OriginStat& origin) {
- return os << "[" << origin.origin() << "," << origin.number_of_hits() << ","
- << origin.number_of_misses() << "," << origin.consecutive_misses()
- << "," << origin.average_position() << ","
- << origin.always_access_network() << ","
- << origin.accessed_network() << "]";
-}
-
-std::ostream& operator<<(std::ostream& os, const PageRequestSummary& summary) {
- os << "[" << summary.main_frame_url << "," << summary.initial_url << "]"
- << std::endl;
- for (const auto& request : summary.subresource_requests)
- os << "\t\t" << request << std::endl;
- return os;
-}
-
-std::ostream& operator<<(std::ostream& os, const URLRequestSummary& summary) {
- return os << "[" << summary.navigation_id << "," << summary.resource_url
- << "," << summary.resource_type << "," << summary.priority << ","
- << summary.before_first_contentful_paint << "," << summary.mime_type
- << "," << summary.was_cached << "," << summary.redirect_url << ","
- << summary.has_validators << "," << summary.always_revalidate
- << "]";
-}
-
-std::ostream& operator<<(std::ostream& os, const NavigationID& navigation_id) {
- return os << navigation_id.tab_id << "," << navigation_id.main_frame_url;
-}
-
-bool operator==(const PrefetchData& lhs, const PrefetchData& rhs) {
- bool equal = lhs.primary_key() == rhs.primary_key() &&
- lhs.resources_size() == rhs.resources_size();
-
- if (!equal)
- return false;
-
- for (int i = 0; i < lhs.resources_size(); ++i)
- equal = equal && lhs.resources(i) == rhs.resources(i);
-
- return equal;
-}
-
-bool operator==(const ResourceData& lhs, const ResourceData& rhs) {
- return lhs.resource_url() == rhs.resource_url() &&
- lhs.resource_type() == rhs.resource_type() &&
- lhs.number_of_hits() == rhs.number_of_hits() &&
- lhs.number_of_misses() == rhs.number_of_misses() &&
- lhs.consecutive_misses() == rhs.consecutive_misses() &&
- AlmostEqual(lhs.average_position(), rhs.average_position()) &&
- lhs.priority() == rhs.priority() &&
- lhs.before_first_contentful_paint() ==
- rhs.before_first_contentful_paint() &&
- lhs.has_validators() == rhs.has_validators() &&
- lhs.always_revalidate() == rhs.always_revalidate();
-}
-
-bool operator==(const RedirectData& lhs, const RedirectData& rhs) {
- bool equal = lhs.primary_key() == rhs.primary_key() &&
- lhs.redirect_endpoints_size() == rhs.redirect_endpoints_size();
-
- if (!equal)
- return false;
-
- for (int i = 0; i < lhs.redirect_endpoints_size(); ++i)
- equal = equal && lhs.redirect_endpoints(i) == rhs.redirect_endpoints(i);
-
- return equal;
-}
-
-bool operator==(const RedirectStat& lhs, const RedirectStat& rhs) {
- return lhs.url() == rhs.url() &&
- lhs.number_of_hits() == rhs.number_of_hits() &&
- lhs.number_of_misses() == rhs.number_of_misses() &&
- lhs.consecutive_misses() == rhs.consecutive_misses();
-}
-
-bool operator==(const PageRequestSummary& lhs, const PageRequestSummary& rhs) {
- return lhs.main_frame_url == rhs.main_frame_url &&
- lhs.initial_url == rhs.initial_url &&
- lhs.subresource_requests == rhs.subresource_requests;
-}
-
-bool operator==(const URLRequestSummary& lhs, const URLRequestSummary& rhs) {
- return lhs.navigation_id == rhs.navigation_id &&
- lhs.resource_url == rhs.resource_url &&
- lhs.resource_type == rhs.resource_type &&
- lhs.priority == rhs.priority && lhs.mime_type == rhs.mime_type &&
- lhs.before_first_contentful_paint ==
- rhs.before_first_contentful_paint &&
- lhs.was_cached == rhs.was_cached &&
- lhs.redirect_url == rhs.redirect_url &&
- lhs.has_validators == rhs.has_validators &&
- lhs.always_revalidate == rhs.always_revalidate;
-}
-
-bool operator==(const OriginData& lhs, const OriginData& rhs) {
- bool equal =
- lhs.host() == rhs.host() && lhs.origins_size() == rhs.origins_size();
- if (!equal)
- return false;
-
- for (int i = 0; i < lhs.origins_size(); ++i)
- equal = equal && lhs.origins(i) == rhs.origins(i);
-
- return equal;
-}
-
-bool operator==(const OriginStat& lhs, const OriginStat& rhs) {
- return lhs.origin() == rhs.origin() &&
- lhs.number_of_hits() == rhs.number_of_hits() &&
- lhs.number_of_misses() == rhs.number_of_misses() &&
- lhs.consecutive_misses() == rhs.consecutive_misses() &&
- AlmostEqual(lhs.average_position(), rhs.average_position()) &&
- lhs.always_access_network() == rhs.always_access_network() &&
- lhs.accessed_network() == rhs.accessed_network();
-}
-
-} // namespace predictors
-
-namespace precache {
-
-std::ostream& operator<<(std::ostream& os, const PrecacheManifest& manifest) {
- os << "[" << manifest.id().id() << "]" << std::endl;
- for (const PrecacheResource& resource : manifest.resource())
- os << "\t\t" << resource << std::endl;
- return os;
-}
-
-std::ostream& operator<<(std::ostream& os, const PrecacheResource& resource) {
- return os << "[" << resource.url() << "," << resource.top_host_name() << ","
- << resource.weight_ratio() << "," << resource.weight() << "]";
-}
-
-bool operator==(const PrecacheManifest& lhs, const PrecacheManifest& rhs) {
- bool equal = lhs.id().id() == rhs.id().id() &&
- lhs.resource_size() == rhs.resource_size();
-
- if (!equal)
- return false;
-
- for (int i = 0; i < lhs.resource_size(); ++i)
- equal = equal && lhs.resource(i) == rhs.resource(i);
-
- return equal;
-}
-
-bool operator==(const PrecacheResource& lhs, const PrecacheResource& rhs) {
- return lhs.url() == rhs.url() &&
- AlmostEqual(lhs.weight_ratio(), rhs.weight_ratio());
-}
-
-} // namespace precache

Powered by Google App Engine
This is Rietveld 408576698