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

Unified Diff: net/base/network_quality_estimator.h

Issue 1316863006: Populate EEP estimate in NQE (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Minor fix Created 5 years, 4 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: net/base/network_quality_estimator.h
diff --git a/net/base/network_quality_estimator.h b/net/base/network_quality_estimator.h
index e244eb3d3763ceb7ecd8497fa9f5b9f6d6bc6e90..88da9b27743b50b5046368b8ba820bbcf6c55250 100644
--- a/net/base/network_quality_estimator.h
+++ b/net/base/network_quality_estimator.h
@@ -14,6 +14,7 @@
#include "base/gtest_prod_util.h"
#include "base/macros.h"
#include "base/memory/scoped_ptr.h"
+#include "base/memory/weak_ptr.h"
#include "base/threading/thread_checker.h"
#include "base/time/time.h"
#include "net/base/external_estimate_provider.h"
@@ -140,6 +141,9 @@ class NET_EXPORT_PRIVATE NetworkQualityEstimator
void OnConnectionTypeChanged(
NetworkChangeNotifier::ConnectionType type) override;
+ // ExternalEstimateProvider::UpdatedEstimateObserver implementation.
+ void OnUpdatedEstimateAvailable() override;
+
private:
FRIEND_TEST_ALL_PREFIXES(NetworkQualityEstimatorTest, StoreObservations);
FRIEND_TEST_ALL_PREFIXES(NetworkQualityEstimatorTest, TestKbpsRTTUpdates);
@@ -343,12 +347,20 @@ class NET_EXPORT_PRIVATE NetworkQualityEstimator
// Maximum number of observations that can be held in the ObservationBuffer.
static const size_t kMaximumObservationsBufferSize = 300;
+ // Minimum time duration (in milliseconds) between consecutive queries to
+ // external estimate provider.
+ static const int kExternalEstimateProviderQueryIntervalMsec = 5 * 60 * 1000;
+
// Returns the RTT value to be used when the valid RTT is unavailable. Readers
// should discard RTT if it is set to the value returned by |InvalidRTT()|.
static const base::TimeDelta InvalidRTT();
- // ExternalEstimateProvider::UpdatedEstimateObserver implementation.
- void OnUpdatedEstimateAvailable() override;
+ // Queries the external estimate provider for the latest network quality
+ // estimates, and adds those estimates to the current observation buffer.
+ void QueryExternalEstimateProvider();
+
+ // Called when the posted task to query external estimate provider is ran.
+ void RunExternalEstimateProviderDelayedTask();
// Obtains operating parameters from the field trial parameters.
void ObtainOperatingParams(
@@ -432,8 +444,30 @@ class NET_EXPORT_PRIVATE NetworkQualityEstimator
// system APIs. May be NULL.
const scoped_ptr<ExternalEstimateProvider> external_estimates_provider_;
+ // Time when the external estimate provider (eep) was last queried.
+ base::TimeTicks eep_queried_;
+
+ // True if a delayed task querying the external estimate provider has been
+ // posted.
+ bool eep_delayed_task_posted_;
bengr 2015/09/02 20:27:56 How about external_estimate_pending_?
tbansal1 2015/09/03 00:22:40 Done.
+
+ // Values of external estimate provider status.
+ // This enum must remain synchronized with the enum of the same name in
+ // metrics/histograms/histograms.xml.
+ enum NQEExternalEstimateProviderStatus {
+ EXTERNAL_ESTIMATE_PROVIDER_STATUS_NOT_AVAILABLE,
+ EXTERNAL_ESTIMATE_PROVIDER_STATUS_AVAILABLE,
+ EXTERNAL_ESTIMATE_PROVIDER_STATUS_QUERIED,
+ EXTERNAL_ESTIMATE_PROVIDER_STATUS_QUERY_SUCCESSFUL,
+ EXTERNAL_ESTIMATE_PROVIDER_STATUS_CALLBACK,
+ EXTERNAL_ESTIMATE_PROVIDER_STATUS_BOUNDARY
+ };
+
base::ThreadChecker thread_checker_;
+ // Used for posting tasks.
+ base::WeakPtrFactory<NetworkQualityEstimator> weak_factory_;
+
DISALLOW_COPY_AND_ASSIGN(NetworkQualityEstimator);
};

Powered by Google App Engine
This is Rietveld 408576698