Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 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 #ifndef COMPONENTS_DOMAIN_RELIABILITY_CONTEXT_H_ | 5 #ifndef COMPONENTS_DOMAIN_RELIABILITY_CONTEXT_H_ |
| 6 #define COMPONENTS_DOMAIN_RELIABILITY_CONTEXT_H_ | 6 #define COMPONENTS_DOMAIN_RELIABILITY_CONTEXT_H_ |
| 7 | 7 |
| 8 #include <deque> | 8 #include <deque> |
| 9 #include <vector> | 9 #include <vector> |
| 10 | 10 |
| (...skipping 35 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 46 const std::string& upload_reporter_string, | 46 const std::string& upload_reporter_string, |
| 47 const base::TimeTicks* last_network_change_time, | 47 const base::TimeTicks* last_network_change_time, |
| 48 DomainReliabilityDispatcher* dispatcher, | 48 DomainReliabilityDispatcher* dispatcher, |
| 49 DomainReliabilityUploader* uploader, | 49 DomainReliabilityUploader* uploader, |
| 50 scoped_ptr<const DomainReliabilityConfig> config); | 50 scoped_ptr<const DomainReliabilityConfig> config); |
| 51 ~DomainReliabilityContext(); | 51 ~DomainReliabilityContext(); |
| 52 | 52 |
| 53 // Notifies the context of a beacon on its domain(s); may or may not save the | 53 // Notifies the context of a beacon on its domain(s); may or may not save the |
| 54 // actual beacon to be uploaded, depending on the sample rates in the config, | 54 // actual beacon to be uploaded, depending on the sample rates in the config, |
| 55 // but will increment one of the request counters in any case. | 55 // but will increment one of the request counters in any case. |
| 56 void OnBeacon(const GURL& url, const DomainReliabilityBeacon& beacon); | 56 void OnBeacon(scoped_ptr<DomainReliabilityBeacon> beacon); |
| 57 | 57 |
| 58 // Called to clear browsing data, since beacons are like browsing history. | 58 // Called to clear browsing data, since beacons are like browsing history. |
| 59 void ClearBeacons(); | 59 void ClearBeacons(); |
| 60 | 60 |
| 61 // Gets a Value containing data that can be formatted into a web page for | 61 // Gets a Value containing data that can be formatted into a web page for |
| 62 // debugging purposes. | 62 // debugging purposes. |
| 63 scoped_ptr<base::Value> GetWebUIData() const; | 63 scoped_ptr<base::Value> GetWebUIData() const; |
| 64 | 64 |
| 65 void GetQueuedBeaconsForTesting( | 65 void GetQueuedBeaconsForTesting( |
| 66 std::vector<DomainReliabilityBeacon>* beacons_out) const; | 66 std::vector<const DomainReliabilityBeacon*>* beacons_out) const; |
|
davidben
2015/10/20 23:35:54
What is the lifetime story for these pointers? (Sh
Deprecated (see juliatuttle)
2015/10/26 19:08:41
Done.
| |
| 67 | |
| 68 void GetRequestCountsForTesting( | |
| 69 size_t resource_index, | |
| 70 uint32* successful_requests_out, | |
| 71 uint32* failed_requests_out) const; | |
| 72 | 67 |
| 73 const DomainReliabilityConfig& config() const { return *config_.get(); } | 68 const DomainReliabilityConfig& config() const { return *config_.get(); } |
| 74 | 69 |
| 75 // Maximum number of beacons queued per context; if more than this many are | 70 // Maximum number of beacons queued per context; if more than this many are |
| 76 // queued; the oldest beacons will be removed. | 71 // queued; the oldest beacons will be removed. |
| 77 static const size_t kMaxQueuedBeacons; | 72 static const size_t kMaxQueuedBeacons; |
| 78 | 73 |
| 79 private: | 74 private: |
| 80 class ResourceState; | 75 typedef std::deque<DomainReliabilityBeacon*> BeaconDeque; |
| 76 typedef BeaconDeque::iterator BeaconIterator; | |
| 77 typedef BeaconDeque::const_iterator BeaconConstIterator; | |
|
davidben
2015/10/20 23:35:54
Nit: I don't think BeaconConstIterator is used at
Deprecated (see juliatuttle)
2015/10/26 19:08:41
Done.
| |
| 81 | 78 |
| 82 typedef std::deque<DomainReliabilityBeacon> BeaconDeque; | |
| 83 typedef ScopedVector<ResourceState> ResourceStateVector; | |
| 84 typedef ResourceStateVector::const_iterator ResourceStateIterator; | |
| 85 | |
| 86 void InitializeResourceStates(); | |
| 87 void ScheduleUpload(base::TimeDelta min_delay, base::TimeDelta max_delay); | 79 void ScheduleUpload(base::TimeDelta min_delay, base::TimeDelta max_delay); |
| 88 void StartUpload(); | 80 void StartUpload(); |
| 89 void OnUploadComplete(const DomainReliabilityUploader::UploadResult& result); | 81 void OnUploadComplete(const DomainReliabilityUploader::UploadResult& result); |
| 90 | 82 |
| 91 scoped_ptr<const base::Value> CreateReport(base::TimeTicks upload_time) const; | 83 scoped_ptr<const base::Value> CreateReport(base::TimeTicks upload_time, |
| 84 const GURL& collector_url) const; | |
| 92 | 85 |
| 93 // Remembers the current state of the context when an upload starts. Can be | 86 // Remembers the current state of the context when an upload starts. Can be |
| 94 // called multiple times in a row (without |CommitUpload|) if uploads fail | 87 // called multiple times in a row (without |CommitUpload|) if uploads fail |
| 95 // and are retried. | 88 // and are retried. |
| 96 void MarkUpload(); | 89 void MarkUpload(); |
| 97 | 90 |
| 98 // Uses the state remembered by |MarkUpload| to remove successfully uploaded | 91 // Uses the state remembered by |MarkUpload| to remove successfully uploaded |
| 99 // data but keep beacons and request counts added after the upload started. | 92 // data but keep beacons and request counts added after the upload started. |
| 100 void CommitUpload(); | 93 void CommitUpload(); |
| 101 | 94 |
| 102 void RollbackUpload(); | 95 void RollbackUpload(); |
| 103 | 96 |
| 104 // Finds and removes the oldest beacon. DCHECKs if there is none. (Called | 97 // Finds and removes the oldest beacon. DCHECKs if there is none. (Called |
| 105 // when there are too many beacons queued.) | 98 // when there are too many beacons queued.) |
| 106 void RemoveOldestBeacon(); | 99 void RemoveOldestBeacon(); |
| 107 | 100 |
| 108 scoped_ptr<const DomainReliabilityConfig> config_; | 101 scoped_ptr<const DomainReliabilityConfig> config_; |
| 109 MockableTime* time_; | 102 MockableTime* time_; |
| 110 const std::string& upload_reporter_string_; | 103 const std::string& upload_reporter_string_; |
| 111 DomainReliabilityScheduler scheduler_; | 104 DomainReliabilityScheduler scheduler_; |
| 112 DomainReliabilityDispatcher* dispatcher_; | 105 DomainReliabilityDispatcher* dispatcher_; |
| 113 DomainReliabilityUploader* uploader_; | 106 DomainReliabilityUploader* uploader_; |
| 114 | 107 |
| 115 BeaconDeque beacons_; | 108 BeaconDeque beacons_; |
| 116 size_t uploading_beacons_size_; | 109 size_t uploading_beacons_size_; |
| 117 // Each ResourceState in |states_| corresponds to the Resource of the same | |
| 118 // index in the config. | |
| 119 ResourceStateVector states_; | |
| 120 base::TimeTicks upload_time_; | 110 base::TimeTicks upload_time_; |
| 121 base::TimeTicks last_upload_time_; | 111 base::TimeTicks last_upload_time_; |
| 122 // The last network change time is not tracked per-context, so this is a | 112 // The last network change time is not tracked per-context, so this is a |
| 123 // pointer to that value in a wider (e.g. per-Monitor or unittest) scope. | 113 // pointer to that value in a wider (e.g. per-Monitor or unittest) scope. |
| 124 const base::TimeTicks* last_network_change_time_; | 114 const base::TimeTicks* last_network_change_time_; |
| 125 | 115 |
| 126 base::WeakPtrFactory<DomainReliabilityContext> weak_factory_; | 116 base::WeakPtrFactory<DomainReliabilityContext> weak_factory_; |
| 127 | 117 |
| 128 DISALLOW_COPY_AND_ASSIGN(DomainReliabilityContext); | 118 DISALLOW_COPY_AND_ASSIGN(DomainReliabilityContext); |
| 129 }; | 119 }; |
| 130 | 120 |
| 131 } // namespace domain_reliability | 121 } // namespace domain_reliability |
| 132 | 122 |
| 133 #endif // COMPONENTS_DOMAIN_RELIABILITY_CONTEXT_H_ | 123 #endif // COMPONENTS_DOMAIN_RELIABILITY_CONTEXT_H_ |
| OLD | NEW |