Send UMA Stats for update engine error codes.
With the latest addition of new optional security checks for the update
manifest and operations checked in, we now want to track the number of
failures, if any, over time to help us decide when it is safe to make
the new security checks mandatory. This CL adds the UMA metric for
reporting the new (as well as the old) error codes to UMA for the first
time.
There's no change to the existing errors that are being sent to Omaha.
Due to UMA restrictions, some Omaha codes will be aggregated when being
sent to UMA.
BUG=chromium-os:34299
TEST=Unit tests pass, tested on real ZGB, all stats show up in
chrome://histograms correctly for both dev mode and normal mode.
Change-Id: I3ce4645636311cedbb33f601e775951966c0a545
Reviewed-on: https://gerrit.chromium.org/gerrit/36408
Commit-Ready: Jay Srinivasan <jaysri@chromium.org>
Reviewed-by: Jay Srinivasan <jaysri@chromium.org>
Tested-by: Jay Srinivasan <jaysri@chromium.org>
diff --git a/main.cc b/main.cc
index 596b04d..43ee5b4 100644
--- a/main.cc
+++ b/main.cc
@@ -172,8 +172,11 @@
LOG_IF(ERROR, !prefs.Init(FilePath("/var/lib/update_engine/prefs")))
<< "Failed to initialize preferences.";
+ chromeos_update_engine::RealSystemState real_system_state;
+
MetricsLibrary metrics_lib;
metrics_lib.Init();
+ real_system_state.set_metrics_lib(&metrics_lib);
// Sets static members for the certificate checker.
chromeos_update_engine::CertificateChecker::set_metrics_lib(&metrics_lib);
@@ -193,9 +196,7 @@
// Create the update attempter:
chromeos_update_engine::ConcreteDbusGlib dbus;
- chromeos_update_engine::RealSystemState real_system_state;
chromeos_update_engine::UpdateAttempter update_attempter(&prefs,
- &metrics_lib,
&dbus,
&gpio_handler,
&real_system_state);