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

Side by Side Diff: chrome/installer/setup/installer_metrics.cc

Issue 1726873002: Report histogram creation results. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: some 'git cl format' changes Created 4 years, 9 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 unified diff | Download patch
OLDNEW
1 // Copyright 2016 The Chromium Authors. All rights reserved. 1 // Copyright 2016 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/installer/setup/installer_metrics.h" 5 #include "chrome/installer/setup/installer_metrics.h"
6 6
7 #include "base/files/file.h" 7 #include "base/files/file.h"
8 #include "base/files/file_path.h" 8 #include "base/files/file_path.h"
9 #include "base/files/file_util.h" 9 #include "base/files/file_util.h"
10 #include "base/metrics/histogram_base.h" 10 #include "base/metrics/histogram_base.h"
11 #include "base/metrics/histogram_persistence.h" 11 #include "base/metrics/histogram_persistence.h"
12 #include "base/metrics/persistent_memory_allocator.h" 12 #include "base/metrics/persistent_memory_allocator.h"
13 #include "chrome/installer/util/util_constants.h" 13 #include "chrome/installer/util/util_constants.h"
14 14
15 namespace installer { 15 namespace installer {
16 16
17 void BeginPersistentHistogramStorage() { 17 void BeginPersistentHistogramStorage() {
18 base::SetPersistentHistogramMemoryAllocator( 18 base::SetPersistentHistogramMemoryAllocator(
19 new base::LocalPersistentMemoryAllocator( 19 new base::LocalPersistentMemoryAllocator(
20 1 << 20, 0, // 1 MiB 20 1 << 20, 0, // 1 MiB
21 installer::kSetupHistogramAllocatorName)); 21 installer::kSetupHistogramAllocatorName));
22 base::GetPersistentHistogramMemoryAllocator()->CreateTrackingHistograms( 22 base::GetPersistentHistogramMemoryAllocator()->CreateTrackingHistograms(
23 installer::kSetupHistogramAllocatorName); 23 installer::kSetupHistogramAllocatorName);
24
25 // This can't be enabled until after the allocator is configured because
26 // there is no other reporting out of setup other than persistent memory.
27 base::HistogramBase::EnableCreationReportHistogram("setup");
Alexei Svitkine (slow) 2016/03/01 16:41:34 I find it unfortunate that we need an extra call (
bcwhite 2016/03/02 19:14:19 Most of the time, the Report histogram will be ena
Alexei Svitkine (slow) 2016/03/03 17:56:23 You can have a helper function that calls the macr
bcwhite 2016/03/07 13:39:25 I guess I've done so much work on histograms that
Alexei Svitkine (slow) 2016/03/07 16:16:46 Right - my preference is to use the macros because
bcwhite 2016/03/07 20:09:25 Well... We're just going to have to agree to disa
Alexei Svitkine (slow) 2016/03/07 20:26:22 Okay, that's fair. Can you add a comment about thi
bcwhite 2016/03/07 20:47:34 Done.
Alexei Svitkine (slow) 2016/03/07 21:14:50 Yep - I see it! (I was using --gunit_shuffle inste
bcwhite 2016/03/07 22:20:41 Done.
24 } 28 }
25 29
26 void EndPersistentHistogramStorage(const base::FilePath& target_path) { 30 void EndPersistentHistogramStorage(const base::FilePath& target_path) {
27 // For atomicity, first write to a temporary file and then rename it. 31 // For atomicity, first write to a temporary file and then rename it.
28 // The ImportantFileWriter would be good for this except it supports only 32 // The ImportantFileWriter would be good for this except it supports only
29 // std::string for its data. 33 // std::string for its data.
30 base::PersistentMemoryAllocator* allocator = 34 base::PersistentMemoryAllocator* allocator =
31 base::GetPersistentHistogramMemoryAllocator(); 35 base::GetPersistentHistogramMemoryAllocator();
32 allocator->UpdateTrackingHistograms(); 36 allocator->UpdateTrackingHistograms();
33 37
(...skipping 12 matching lines...) Expand all
46 if (base::ReplaceFile(tmp_file_path, file_path, nullptr)) { 50 if (base::ReplaceFile(tmp_file_path, file_path, nullptr)) {
47 VLOG(1) << "Persistent histograms saved in file: " 51 VLOG(1) << "Persistent histograms saved in file: "
48 << file_path.value(); 52 << file_path.value();
49 } 53 }
50 } 54 }
51 base::DeleteFile(tmp_file_path, false); 55 base::DeleteFile(tmp_file_path, false);
52 } 56 }
53 } 57 }
54 58
55 } // namespace installer 59 } // namespace installer
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698