blob: b6ffccee7c830f7fc7b9f369019abb84c1847747 [file] [log] [blame]
Tianjie Xu282aa1f2017-09-05 13:42:45 -07001//
2// Copyright (C) 2017 The Android Open Source Project
3//
4// Licensed under the Apache License, Version 2.0 (the "License");
5// you may not use this file except in compliance with the License.
6// You may obtain a copy of the License at
7//
8// http://www.apache.org/licenses/LICENSE-2.0
9//
10// Unless required by applicable law or agreed to in writing, software
11// distributed under the License is distributed on an "AS IS" BASIS,
12// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13// See the License for the specific language governing permissions and
14// limitations under the License.
15//
16
Amin Hassaniec7bc112020-10-29 16:47:58 -070017#ifndef UPDATE_ENGINE_CROS_METRICS_REPORTER_OMAHA_H_
18#define UPDATE_ENGINE_CROS_METRICS_REPORTER_OMAHA_H_
Tianjie Xu282aa1f2017-09-05 13:42:45 -070019
Tianjie Xu98333a82017-09-22 21:29:29 -070020#include <memory>
Marton Hunyadya0302682018-05-16 18:52:13 +020021#include <string>
Tianjie Xu98333a82017-09-22 21:29:29 -070022
Tianjie Xu282aa1f2017-09-05 13:42:45 -070023#include <base/time/time.h>
Amin Hassaniec7bc112020-10-29 16:47:58 -070024#include <gtest/gtest_prod.h> // for FRIEND_TEST
Tianjie Xu282aa1f2017-09-05 13:42:45 -070025#include <metrics/metrics_library.h>
26
27#include "update_engine/certificate_checker.h"
28#include "update_engine/common/constants.h"
29#include "update_engine/common/error_code.h"
Amin Hassaniec7bc112020-10-29 16:47:58 -070030#include "update_engine/common/metrics_constants.h"
31#include "update_engine/common/metrics_reporter_interface.h"
Tianjie Xu282aa1f2017-09-05 13:42:45 -070032
33namespace chromeos_update_engine {
34
35class SystemState;
36
Tianjie Xu98333a82017-09-22 21:29:29 -070037namespace metrics {
38
39// UpdateEngine.Daily.* metrics.
40extern const char kMetricDailyOSAgeDays[];
41
42// UpdateEngine.Check.* metrics.
43extern const char kMetricCheckDownloadErrorCode[];
44extern const char kMetricCheckReaction[];
45extern const char kMetricCheckResult[];
Marton Hunyadya0302682018-05-16 18:52:13 +020046extern const char kMetricCheckTargetVersion[];
47extern const char kMetricCheckRollbackTargetVersion[];
Tianjie Xu98333a82017-09-22 21:29:29 -070048extern const char kMetricCheckTimeSinceLastCheckMinutes[];
49extern const char kMetricCheckTimeSinceLastCheckUptimeMinutes[];
50
51// UpdateEngine.Attempt.* metrics.
52extern const char kMetricAttemptNumber[];
53extern const char kMetricAttemptPayloadType[];
54extern const char kMetricAttemptPayloadSizeMiB[];
55extern const char kMetricAttemptConnectionType[];
56extern const char kMetricAttemptDurationMinutes[];
57extern const char kMetricAttemptDurationUptimeMinutes[];
58extern const char kMetricAttemptTimeSinceLastAttemptMinutes[];
59extern const char kMetricAttemptTimeSinceLastAttemptUptimeMinutes[];
60extern const char kMetricAttemptPayloadBytesDownloadedMiB[];
61extern const char kMetricAttemptPayloadDownloadSpeedKBps[];
62extern const char kMetricAttemptDownloadSource[];
63extern const char kMetricAttemptResult[];
64extern const char kMetricAttemptInternalErrorCode[];
65extern const char kMetricAttemptDownloadErrorCode[];
66
67// UpdateEngine.SuccessfulUpdate.* metrics.
68extern const char kMetricSuccessfulUpdateAttemptCount[];
69extern const char kMetricSuccessfulUpdateBytesDownloadedMiB[];
70extern const char kMetricSuccessfulUpdateDownloadOverheadPercentage[];
71extern const char kMetricSuccessfulUpdateDownloadSourcesUsed[];
May Lippert60aa3ca2018-08-15 16:55:29 -070072extern const char kMetricSuccessfulUpdateDurationFromSeenDays[];
73extern const char kMetricSuccessfulUpdateDurationFromSeenTimeRestrictedDays[];
Tianjie Xu98333a82017-09-22 21:29:29 -070074extern const char kMetricSuccessfulUpdatePayloadType[];
75extern const char kMetricSuccessfulUpdatePayloadSizeMiB[];
76extern const char kMetricSuccessfulUpdateRebootCount[];
77extern const char kMetricSuccessfulUpdateTotalDurationMinutes[];
Sen Jiang8712e962018-05-08 12:12:28 -070078extern const char kMetricSuccessfulUpdateTotalDurationUptimeMinutes[];
Tianjie Xu98333a82017-09-22 21:29:29 -070079extern const char kMetricSuccessfulUpdateUpdatesAbandonedCount[];
80extern const char kMetricSuccessfulUpdateUrlSwitchCount[];
81
82// UpdateEngine.Rollback.* metric.
83extern const char kMetricRollbackResult[];
84
Marton Hunyadya0302682018-05-16 18:52:13 +020085// UpdateEngine.EnterpriseRollback.* metrics.
86extern const char kMetricEnterpriseRollbackFailure[];
87extern const char kMetricEnterpriseRollbackSuccess[];
88
Tianjie Xu98333a82017-09-22 21:29:29 -070089// UpdateEngine.CertificateCheck.* metrics.
90extern const char kMetricCertificateCheckUpdateCheck[];
91extern const char kMetricCertificateCheckDownload[];
92
Marton Hunyadyffbfdfb2018-05-30 13:03:29 +020093// UpdateEngine.KernelKey.* metrics.
94extern const char kMetricKernelMinVersion[];
95extern const char kMetricKernelMaxRollforwardVersion[];
96extern const char kMetricKernelMaxRollforwardSetSuccess[];
97
Tianjie Xu98333a82017-09-22 21:29:29 -070098// UpdateEngine.* metrics.
99extern const char kMetricFailedUpdateCount[];
100extern const char kMetricInstallDateProvisioningSource[];
101extern const char kMetricTimeToRebootMinutes[];
102
103} // namespace metrics
104
Tianjie Xu282aa1f2017-09-05 13:42:45 -0700105class MetricsReporterOmaha : public MetricsReporterInterface {
106 public:
Tianjie Xu98333a82017-09-22 21:29:29 -0700107 MetricsReporterOmaha();
Tianjie Xu282aa1f2017-09-05 13:42:45 -0700108
109 ~MetricsReporterOmaha() override = default;
110
Tianjie Xu282aa1f2017-09-05 13:42:45 -0700111 void ReportRollbackMetrics(metrics::RollbackResult result) override;
112
Marton Hunyadya0302682018-05-16 18:52:13 +0200113 void ReportEnterpriseRollbackMetrics(
114 bool success, const std::string& rollback_version) override;
115
Tianjie Xu282aa1f2017-09-05 13:42:45 -0700116 void ReportDailyMetrics(base::TimeDelta os_age) override;
117
118 void ReportUpdateCheckMetrics(
Tianjie Xu282aa1f2017-09-05 13:42:45 -0700119 metrics::CheckResult result,
120 metrics::CheckReaction reaction,
121 metrics::DownloadErrorCode download_error_code) override;
122
Amin Hassani538bd592020-11-04 20:46:08 -0800123 void ReportUpdateAttemptMetrics(int attempt_number,
Tianjie Xu1f93d092017-10-09 12:13:29 -0700124 PayloadType payload_type,
125 base::TimeDelta duration,
126 base::TimeDelta duration_uptime,
127 int64_t payload_size,
128 metrics::AttemptResult attempt_result,
129 ErrorCode internal_error_code) override;
130
131 void ReportUpdateAttemptDownloadMetrics(
Tianjie Xu282aa1f2017-09-05 13:42:45 -0700132 int64_t payload_bytes_downloaded,
133 int64_t payload_download_speed_bps,
134 DownloadSource download_source,
Tianjie Xu282aa1f2017-09-05 13:42:45 -0700135 metrics::DownloadErrorCode payload_download_error_code,
136 metrics::ConnectionType connection_type) override;
137
138 void ReportAbnormallyTerminatedUpdateAttemptMetrics() override;
139
140 void ReportSuccessfulUpdateMetrics(
141 int attempt_count,
142 int updates_abandoned_count,
143 PayloadType payload_type,
144 int64_t payload_size,
145 int64_t num_bytes_downloaded[kNumDownloadSources],
146 int download_overhead_percentage,
147 base::TimeDelta total_duration,
Sen Jiang8712e962018-05-08 12:12:28 -0700148 base::TimeDelta total_duration_uptime,
Tianjie Xu282aa1f2017-09-05 13:42:45 -0700149 int reboot_count,
150 int url_switch_count) override;
151
152 void ReportCertificateCheckMetrics(ServerToCheck server_to_check,
153 CertificateCheckResult result) override;
154
155 void ReportFailedUpdateCount(int target_attempt) override;
156
157 void ReportTimeToReboot(int time_to_reboot_minutes) override;
158
159 void ReportInstallDateProvisioningSource(int source, int max) override;
160
Amin Hassani80f4d4c2018-05-16 13:34:00 -0700161 void ReportInternalErrorCode(ErrorCode error_code) override;
162
Marton Hunyadyffbfdfb2018-05-30 13:03:29 +0200163 void ReportKeyVersionMetrics(int kernel_min_version,
164 int kernel_max_rollforward_version,
165 bool kernel_max_rollforward_success) override;
166
May Lippert60aa3ca2018-08-15 16:55:29 -0700167 void ReportEnterpriseUpdateSeenToDownloadDays(
168 bool has_time_restriction_policy, int time_to_update_days) override;
169
Tianjie Xu282aa1f2017-09-05 13:42:45 -0700170 private:
Tianjie Xu98333a82017-09-22 21:29:29 -0700171 friend class MetricsReporterOmahaTest;
Amin Hassaniec7bc112020-10-29 16:47:58 -0700172 FRIEND_TEST(MetricsReporterOmahaTest, WallclockDurationHelper);
173 FRIEND_TEST(MetricsReporterOmahaTest, MonotonicDurationHelper);
174
175 // This function returns the duration on the wallclock since the last
176 // time it was called for the same |state_variable_key| value.
177 //
178 // If the function returns |true|, the duration (always non-negative)
179 // is returned in |out_duration|. If the function returns |false|
180 // something went wrong or there was no previous measurement.
Amin Hassani538bd592020-11-04 20:46:08 -0800181 bool WallclockDurationHelper(const std::string& state_variable_key,
Amin Hassaniec7bc112020-10-29 16:47:58 -0700182 base::TimeDelta* out_duration);
183
184 // This function returns the duration on the monotonic clock since the
185 // last time it was called for the same |storage| pointer.
186 //
187 // You should pass a pointer to a 64-bit integer in |storage| which
188 // should be initialized to 0.
189 //
190 // If the function returns |true|, the duration (always non-negative)
191 // is returned in |out_duration|. If the function returns |false|
192 // something went wrong or there was no previous measurement.
Amin Hassani538bd592020-11-04 20:46:08 -0800193 bool MonotonicDurationHelper(int64_t* storage, base::TimeDelta* out_duration);
Tianjie Xu98333a82017-09-22 21:29:29 -0700194
195 std::unique_ptr<MetricsLibraryInterface> metrics_lib_;
Tianjie Xu282aa1f2017-09-05 13:42:45 -0700196
197 DISALLOW_COPY_AND_ASSIGN(MetricsReporterOmaha);
198}; // class metrics
199
200} // namespace chromeos_update_engine
201
Amin Hassaniec7bc112020-10-29 16:47:58 -0700202#endif // UPDATE_ENGINE_CROS_METRICS_REPORTER_OMAHA_H_