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 #include "chrome/browser/metrics/chrome_metrics_service_client.h" | 5 #include "chrome/browser/metrics/chrome_metrics_service_client.h" |
6 | 6 |
7 #include <stddef.h> | 7 #include <stddef.h> |
8 | 8 |
9 #include <set> | 9 #include <set> |
10 #include <utility> | 10 #include <utility> |
11 #include <vector> | 11 #include <vector> |
12 | 12 |
13 #include "base/bind.h" | 13 #include "base/bind.h" |
14 #include "base/callback.h" | 14 #include "base/callback.h" |
15 #include "base/command_line.h" | 15 #include "base/command_line.h" |
16 #include "base/files/file_path.h" | 16 #include "base/files/file_path.h" |
17 #include "base/files/file_util.h" | 17 #include "base/files/file_util.h" |
18 #include "base/lazy_instance.h" | 18 #include "base/lazy_instance.h" |
19 #include "base/logging.h" | 19 #include "base/logging.h" |
20 #include "base/memory/ptr_util.h" | 20 #include "base/memory/ptr_util.h" |
21 #include "base/metrics/field_trial_params.h" | 21 #include "base/metrics/field_trial_params.h" |
22 #include "base/metrics/histogram_macros.h" | 22 #include "base/metrics/histogram_macros.h" |
23 #include "base/metrics/persistent_histogram_allocator.h" | 23 #include "base/metrics/persistent_histogram_allocator.h" |
24 #include "base/metrics/persistent_memory_allocator.h" | 24 #include "base/metrics/persistent_memory_allocator.h" |
25 #include "base/metrics/statistics_recorder.h" | 25 #include "base/metrics/statistics_recorder.h" |
26 #include "base/path_service.h" | 26 #include "base/path_service.h" |
27 #include "base/rand_util.h" | 27 #include "base/rand_util.h" |
28 #include "base/strings/string16.h" | 28 #include "base/strings/string16.h" |
| 29 #include "base/task_scheduler/post_task.h" |
| 30 #include "base/task_scheduler/task_traits.h" |
29 #include "base/threading/platform_thread.h" | 31 #include "base/threading/platform_thread.h" |
30 #include "base/threading/sequenced_worker_pool.h" | |
31 #include "base/threading/thread_task_runner_handle.h" | 32 #include "base/threading/thread_task_runner_handle.h" |
32 #include "build/build_config.h" | 33 #include "build/build_config.h" |
33 #include "chrome/browser/browser_process.h" | 34 #include "chrome/browser/browser_process.h" |
34 #include "chrome/browser/chrome_notification_types.h" | 35 #include "chrome/browser/chrome_notification_types.h" |
35 #include "chrome/browser/google/google_brand.h" | 36 #include "chrome/browser/google/google_brand.h" |
36 #include "chrome/browser/history/history_service_factory.h" | 37 #include "chrome/browser/history/history_service_factory.h" |
37 #include "chrome/browser/metrics/chrome_metrics_service_accessor.h" | 38 #include "chrome/browser/metrics/chrome_metrics_service_accessor.h" |
38 #include "chrome/browser/metrics/chrome_stability_metrics_provider.h" | 39 #include "chrome/browser/metrics/chrome_stability_metrics_provider.h" |
39 #include "chrome/browser/metrics/https_engagement_metrics_provider.h" | 40 #include "chrome/browser/metrics/https_engagement_metrics_provider.h" |
40 #include "chrome/browser/metrics/metrics_reporting_state.h" | 41 #include "chrome/browser/metrics/metrics_reporting_state.h" |
(...skipping 130 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
171 } | 172 } |
172 | 173 |
173 // Constructs the name of a persistent metrics file from a directory and metrics | 174 // Constructs the name of a persistent metrics file from a directory and metrics |
174 // name, and either registers that file as associated with a previous run if | 175 // name, and either registers that file as associated with a previous run if |
175 // metrics reporting is enabled, or deletes it if not. | 176 // metrics reporting is enabled, or deletes it if not. |
176 void RegisterOrRemovePreviousRunMetricsFile( | 177 void RegisterOrRemovePreviousRunMetricsFile( |
177 bool metrics_reporting_enabled, | 178 bool metrics_reporting_enabled, |
178 const base::FilePath& dir, | 179 const base::FilePath& dir, |
179 base::StringPiece metrics_name, | 180 base::StringPiece metrics_name, |
180 metrics::FileMetricsProvider::SourceAssociation association, | 181 metrics::FileMetricsProvider::SourceAssociation association, |
181 scoped_refptr<base::TaskRunner> task_runner, | |
182 metrics::FileMetricsProvider* file_metrics_provider) { | 182 metrics::FileMetricsProvider* file_metrics_provider) { |
183 base::FilePath metrics_file; | 183 base::FilePath metrics_file; |
184 base::GlobalHistogramAllocator::ConstructFilePaths( | 184 base::GlobalHistogramAllocator::ConstructFilePaths( |
185 dir, metrics_name, &metrics_file, nullptr, nullptr); | 185 dir, metrics_name, &metrics_file, nullptr, nullptr); |
186 | 186 |
187 if (metrics_reporting_enabled) { | 187 if (metrics_reporting_enabled) { |
188 // Enable reading any existing saved metrics. | 188 // Enable reading any existing saved metrics. |
189 file_metrics_provider->RegisterSource( | 189 file_metrics_provider->RegisterSource( |
190 metrics_file, | 190 metrics_file, |
191 metrics::FileMetricsProvider::SOURCE_HISTOGRAMS_ATOMIC_FILE, | 191 metrics::FileMetricsProvider::SOURCE_HISTOGRAMS_ATOMIC_FILE, |
192 association, metrics_name); | 192 association, metrics_name); |
193 } else { | 193 } else { |
194 // When metrics reporting is not enabled, any existing file should be | 194 // When metrics reporting is not enabled, any existing file should be |
195 // deleted in order to preserve user privacy. | 195 // deleted in order to preserve user privacy. |
196 task_runner->PostTask(FROM_HERE, | 196 base::PostTaskWithTraits( |
197 base::BindOnce(base::IgnoreResult(&base::DeleteFile), | 197 FROM_HERE, |
198 metrics_file, /*recursive=*/false)); | 198 {base::MayBlock(), base::TaskPriority::BACKGROUND, |
| 199 base::TaskShutdownBehavior::CONTINUE_ON_SHUTDOWN}, |
| 200 base::BindOnce(base::IgnoreResult(&base::DeleteFile), metrics_file, |
| 201 /*recursive=*/false)); |
199 } | 202 } |
200 } | 203 } |
201 | 204 |
202 std::unique_ptr<metrics::FileMetricsProvider> CreateFileMetricsProvider( | 205 std::unique_ptr<metrics::FileMetricsProvider> CreateFileMetricsProvider( |
203 bool metrics_reporting_enabled) { | 206 bool metrics_reporting_enabled) { |
204 // Fetch a worker-pool for performing I/O tasks that are not allowed on | |
205 // the main UI thread. | |
206 scoped_refptr<base::TaskRunner> task_runner = | |
207 content::BrowserThread::GetBlockingPool() | |
208 ->GetTaskRunnerWithShutdownBehavior( | |
209 base::SequencedWorkerPool::CONTINUE_ON_SHUTDOWN); | |
210 | |
211 // Create an object to monitor files of metrics and include them in reports. | 207 // Create an object to monitor files of metrics and include them in reports. |
212 std::unique_ptr<metrics::FileMetricsProvider> file_metrics_provider( | 208 std::unique_ptr<metrics::FileMetricsProvider> file_metrics_provider( |
213 new metrics::FileMetricsProvider(task_runner, | 209 new metrics::FileMetricsProvider(g_browser_process->local_state())); |
214 g_browser_process->local_state())); | |
215 | 210 |
216 base::FilePath user_data_dir; | 211 base::FilePath user_data_dir; |
217 if (base::PathService::Get(chrome::DIR_USER_DATA, &user_data_dir)) { | 212 if (base::PathService::Get(chrome::DIR_USER_DATA, &user_data_dir)) { |
218 // Reporting of persistent histograms from last session is controlled by | 213 // Reporting of persistent histograms from last session is controlled by |
219 // a feature param. TODO(bcwhite): The current default is not to upload | 214 // a feature param. TODO(bcwhite): The current default is not to upload |
220 // until some issues are resolved. See crbug.com/706422 for details. | 215 // until some issues are resolved. See crbug.com/706422 for details. |
221 std::string send_unreported = base::GetFieldTrialParamValueByFeature( | 216 std::string send_unreported = base::GetFieldTrialParamValueByFeature( |
222 base::kPersistentHistogramsFeature, "send_unreported_metrics"); | 217 base::kPersistentHistogramsFeature, "send_unreported_metrics"); |
223 bool report_previous_persistent_histograms = | 218 bool report_previous_persistent_histograms = |
224 metrics_reporting_enabled && (send_unreported == "yes"); | 219 metrics_reporting_enabled && (send_unreported == "yes"); |
225 RegisterOrRemovePreviousRunMetricsFile( | 220 RegisterOrRemovePreviousRunMetricsFile( |
226 report_previous_persistent_histograms, user_data_dir, | 221 report_previous_persistent_histograms, user_data_dir, |
227 ChromeMetricsServiceClient::kBrowserMetricsName, | 222 ChromeMetricsServiceClient::kBrowserMetricsName, |
228 metrics::FileMetricsProvider::ASSOCIATE_INTERNAL_PROFILE, task_runner, | 223 metrics::FileMetricsProvider::ASSOCIATE_INTERNAL_PROFILE, |
229 file_metrics_provider.get()); | 224 file_metrics_provider.get()); |
230 | 225 |
231 // Register the Crashpad metrics files. | 226 // Register the Crashpad metrics files. |
232 // Register the data from the previous run if crashpad_handler didn't exit | 227 // Register the data from the previous run if crashpad_handler didn't exit |
233 // cleanly. | 228 // cleanly. |
234 RegisterOrRemovePreviousRunMetricsFile( | 229 RegisterOrRemovePreviousRunMetricsFile( |
235 metrics_reporting_enabled, user_data_dir, | 230 metrics_reporting_enabled, user_data_dir, |
236 kCrashpadHistogramAllocatorName, | 231 kCrashpadHistogramAllocatorName, |
237 metrics::FileMetricsProvider:: | 232 metrics::FileMetricsProvider:: |
238 ASSOCIATE_INTERNAL_PROFILE_OR_PREVIOUS_RUN, | 233 ASSOCIATE_INTERNAL_PROFILE_OR_PREVIOUS_RUN, |
239 task_runner, file_metrics_provider.get()); | 234 file_metrics_provider.get()); |
240 if (metrics_reporting_enabled) { | 235 if (metrics_reporting_enabled) { |
241 base::FilePath active_path; | 236 base::FilePath active_path; |
242 base::GlobalHistogramAllocator::ConstructFilePaths( | 237 base::GlobalHistogramAllocator::ConstructFilePaths( |
243 user_data_dir, kCrashpadHistogramAllocatorName, nullptr, &active_path, | 238 user_data_dir, kCrashpadHistogramAllocatorName, nullptr, &active_path, |
244 nullptr); | 239 nullptr); |
245 // Register data that will be populated for the current run. "Active" | 240 // Register data that will be populated for the current run. "Active" |
246 // files need an empty "prefs_key" because they update the file itself. | 241 // files need an empty "prefs_key" because they update the file itself. |
247 file_metrics_provider->RegisterSource( | 242 file_metrics_provider->RegisterSource( |
248 active_path, | 243 active_path, |
249 metrics::FileMetricsProvider::SOURCE_HISTOGRAMS_ACTIVE_FILE, | 244 metrics::FileMetricsProvider::SOURCE_HISTOGRAMS_ACTIVE_FILE, |
(...skipping 758 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1008 ukm_service_->Purge(); | 1003 ukm_service_->Purge(); |
1009 ukm_service_->ResetClientId(); | 1004 ukm_service_->ResetClientId(); |
1010 } | 1005 } |
1011 // Signal service manager to enable/disable UKM based on new state. | 1006 // Signal service manager to enable/disable UKM based on new state. |
1012 UpdateRunningServices(); | 1007 UpdateRunningServices(); |
1013 } | 1008 } |
1014 | 1009 |
1015 bool ChromeMetricsServiceClient::IsHistorySyncEnabledOnAllProfiles() { | 1010 bool ChromeMetricsServiceClient::IsHistorySyncEnabledOnAllProfiles() { |
1016 return SyncDisableObserver::IsHistorySyncEnabledOnAllProfiles(); | 1011 return SyncDisableObserver::IsHistorySyncEnabledOnAllProfiles(); |
1017 } | 1012 } |
OLD | NEW |