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

Unified Diff: chrome/browser/net/nqe/ui_network_quality_estimator_service.cc

Issue 2369673004: Wire NQE Prefs to Profile (Closed)
Patch Set: More fixups Created 4 years, 2 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/net/nqe/ui_network_quality_estimator_service.cc
diff --git a/chrome/browser/net/nqe/ui_network_quality_estimator_service.cc b/chrome/browser/net/nqe/ui_network_quality_estimator_service.cc
index 87c4a6afb39338ae235989d703ccf75c5d0bd012..6e00352acd3e916b9f5fc6170364fc3b2866164e 100644
--- a/chrome/browser/net/nqe/ui_network_quality_estimator_service.cc
+++ b/chrome/browser/net/nqe/ui_network_quality_estimator_service.cc
@@ -4,10 +4,99 @@
#include "chrome/browser/net/nqe/ui_network_quality_estimator_service.h"
+#include <string>
+
#include "base/bind.h"
+#include "base/memory/ptr_util.h"
+#include "base/metrics/histogram_macros.h"
+#include "base/threading/thread_checker.h"
+#include "base/values.h"
#include "chrome/browser/browser_process.h"
#include "chrome/browser/io_thread.h"
+#include "chrome/browser/profiles/profile.h"
+#include "chrome/common/pref_names.h"
+#include "components/prefs/pref_registry.h"
+#include "components/prefs/pref_registry_simple.h"
+#include "components/prefs/pref_service.h"
+#include "components/variations/variations_associated_data.h"
#include "content/public/browser/browser_thread.h"
+#include "net/nqe/network_qualities_prefs_manager.h"
+
+namespace {
+
+// Returns the variation value for |parameter_name|. If the value is
+// unavailable, |default_value| is returned.
+std::string GetStringValueForVariationParamWithDefaultValue(
+ const std::string& parameter_name,
+ const std::string& default_value) {
+ std::map<std::string, std::string> network_quality_estimator_params;
+ // Name of the network quality estimator field trial.
+ variations::GetVariationParams("NetworkQualityEstimator",
+ &network_quality_estimator_params);
+
+ const auto it = network_quality_estimator_params.find(parameter_name);
+ return it == network_quality_estimator_params.end() ? default_value
+ : it->second;
+}
+
+// Returns true if persistent caching has been enabled in the field trial.
+bool persistent_caching_enabled() {
+ return GetStringValueForVariationParamWithDefaultValue(
+ "persistent_caching_enabled", "false") == "true";
+}
+
+// PrefDelegateImpl writes the provided dictionary value to the network quality
+// estimator prefs on the disk.
+class PrefDelegateImpl
+ : public net::NetworkQualitiesPrefsManager::PrefDelegate {
+ public:
+ // |pref_service| is used to read and write prefs from/to the disk.
+ explicit PrefDelegateImpl(PrefService* pref_service)
+ : pref_service_(pref_service), path_(prefs::kNetworkQualities) {
+ DCHECK(pref_service_);
+ }
+ ~PrefDelegateImpl() override {}
+
+ void SetDictionaryValue(const base::DictionaryValue& value) override {
+ DCHECK(thread_checker_.CalledOnValidThread());
+ if (!persistent_caching_enabled())
+ return;
+
+ pref_service_->Set(path_, value);
+ UMA_HISTOGRAM_COUNTS_1000("NQE.Prefs.WriteCount", 1);
+ }
+
+ const base::DictionaryValue& GetDictionaryValue() override {
+ DCHECK(thread_checker_.CalledOnValidThread());
+ UMA_HISTOGRAM_COUNTS_1000("NQE.Prefs.ReadCount", 1);
+ return *pref_service_->GetDictionary(path_);
+ }
+
+ private:
+ PrefService* pref_service_;
+
+ // |path_| is the location of the network quality estimator prefs.
+ const std::string path_;
+
+ base::ThreadChecker thread_checker_;
+
+ DISALLOW_COPY_AND_ASSIGN(PrefDelegateImpl);
+};
+
+// Initializes |pref_manager| on |io_thread|.
+void SetNQEOnIOThread(net::NetworkQualitiesPrefsManager* prefs_manager,
+ IOThread* io_thread) {
+ DCHECK_CURRENTLY_ON(content::BrowserThread::IO);
+
+ // Avoid null pointer referencing during browser shutdown.
+ if (!io_thread->globals()->network_quality_estimator)
+ return;
+
+ prefs_manager->InitializeOnNetworkThread(
+ io_thread->globals()->network_quality_estimator.get());
+}
+
+} // namespace
// A class that sets itself as an observer of the EffectiveconnectionType for
// the browser IO thread. It reports any change in EffectiveConnectionType back
@@ -16,9 +105,9 @@
class UINetworkQualityEstimatorService::IONetworkQualityObserver
: public net::NetworkQualityEstimator::EffectiveConnectionTypeObserver {
public:
- IONetworkQualityObserver(
+ explicit IONetworkQualityObserver(
base::WeakPtr<UINetworkQualityEstimatorService> service)
- : service_(service) {
+ : service_(service), network_quality_estimator_(nullptr) {
DCHECK_CURRENTLY_ON(content::BrowserThread::UI);
}
@@ -64,20 +153,29 @@ class UINetworkQualityEstimatorService::IONetworkQualityObserver
DISALLOW_COPY_AND_ASSIGN(IONetworkQualityObserver);
};
-UINetworkQualityEstimatorService::UINetworkQualityEstimatorService()
- : type_(net::EFFECTIVE_CONNECTION_TYPE_UNKNOWN),
- io_observer_(nullptr),
- weak_factory_(this) {
- DCHECK_CURRENTLY_ON(content::BrowserThread::UI);
+UINetworkQualityEstimatorService::UINetworkQualityEstimatorService(
+ Profile* profile)
+ : type_(net::EFFECTIVE_CONNECTION_TYPE_UNKNOWN), weak_factory_(this) {
+ DCHECK(profile);
// If this is running in a context without an IOThread, don't try to create
// the IO object.
if (!g_browser_process->io_thread())
return;
- io_observer_ = new IONetworkQualityObserver(weak_factory_.GetWeakPtr());
+ io_observer_ = base::WrapUnique(
+ new IONetworkQualityObserver(weak_factory_.GetWeakPtr()));
+ std::unique_ptr<PrefDelegateImpl> pref_delegate(
+ new PrefDelegateImpl(profile->GetPrefs()));
+ prefs_manager_ = base::WrapUnique(
+ new net::NetworkQualitiesPrefsManager(std::move(pref_delegate)));
+
content::BrowserThread::PostTask(
content::BrowserThread::IO, FROM_HERE,
base::Bind(&IONetworkQualityObserver::InitializeOnIOThread,
- base::Unretained(io_observer_),
+ base::Unretained(io_observer_.get()),
+ g_browser_process->io_thread()));
+ content::BrowserThread::PostTask(
+ content::BrowserThread::IO, FROM_HERE,
+ base::Bind(&SetNQEOnIOThread, prefs_manager_.get(),
g_browser_process->io_thread()));
}
@@ -88,8 +186,21 @@ UINetworkQualityEstimatorService::~UINetworkQualityEstimatorService() {
void UINetworkQualityEstimatorService::Shutdown() {
DCHECK_CURRENTLY_ON(content::BrowserThread::UI);
weak_factory_.InvalidateWeakPtrs();
- DCHECK(content::BrowserThread::DeleteSoon(content::BrowserThread::IO,
- FROM_HERE, io_observer_));
+ if (io_observer_) {
+ bool deleted = content::BrowserThread::DeleteSoon(
+ content::BrowserThread::IO, FROM_HERE, io_observer_.release());
+ DCHECK(deleted);
+ // Silence unused variable warning in release builds.
+ (void)deleted;
+ }
+ if (prefs_manager_) {
+ prefs_manager_->ShutdownOnPrefThread();
+ bool deleted = content::BrowserThread::DeleteSoon(
+ content::BrowserThread::IO, FROM_HERE, prefs_manager_.release());
+ DCHECK(deleted);
+ // Silence unused variable warning in release builds.
+ (void)deleted;
+ }
}
void UINetworkQualityEstimatorService::EffectiveConnectionTypeChanged(
@@ -109,3 +220,20 @@ UINetworkQualityEstimatorService::GetEffectiveConnectionType() const {
DCHECK_CURRENTLY_ON(content::BrowserThread::UI);
return type_;
}
+
+// static
+void UINetworkQualityEstimatorService::RegisterProfilePrefs(
+ PrefRegistrySimple* registry) {
+ registry->RegisterDictionaryPref(prefs::kNetworkQualities,
+ PrefRegistry::LOSSY_PREF);
+}
+
+std::map<net::nqe::internal::NetworkID,
+ net::nqe::internal::CachedNetworkQuality>
+UINetworkQualityEstimatorService::ForceReadPrefsForTesting() const {
+ if (!prefs_manager_) {
+ return std::map<net::nqe::internal::NetworkID,
+ net::nqe::internal::CachedNetworkQuality>();
+ }
+ return prefs_manager_->ForceReadPrefsForTesting();
+}

Powered by Google App Engine
This is Rietveld 408576698