blob: 5b3fdb160f8a5c9da418f8d279f82827784af31c [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"
32#include "update_engine/common/system_state.h"
Tianjie Xu282aa1f2017-09-05 13:42:45 -070033
34namespace chromeos_update_engine {
35
36class SystemState;
37
Tianjie Xu98333a82017-09-22 21:29:29 -070038namespace metrics {
39
40// UpdateEngine.Daily.* metrics.
41extern const char kMetricDailyOSAgeDays[];
42
43// UpdateEngine.Check.* metrics.
44extern const char kMetricCheckDownloadErrorCode[];
45extern const char kMetricCheckReaction[];
46extern const char kMetricCheckResult[];
Marton Hunyadya0302682018-05-16 18:52:13 +020047extern const char kMetricCheckTargetVersion[];
48extern const char kMetricCheckRollbackTargetVersion[];
Tianjie Xu98333a82017-09-22 21:29:29 -070049extern const char kMetricCheckTimeSinceLastCheckMinutes[];
50extern const char kMetricCheckTimeSinceLastCheckUptimeMinutes[];
51
52// UpdateEngine.Attempt.* metrics.
53extern const char kMetricAttemptNumber[];
54extern const char kMetricAttemptPayloadType[];
55extern const char kMetricAttemptPayloadSizeMiB[];
56extern const char kMetricAttemptConnectionType[];
57extern const char kMetricAttemptDurationMinutes[];
58extern const char kMetricAttemptDurationUptimeMinutes[];
59extern const char kMetricAttemptTimeSinceLastAttemptMinutes[];
60extern const char kMetricAttemptTimeSinceLastAttemptUptimeMinutes[];
61extern const char kMetricAttemptPayloadBytesDownloadedMiB[];
62extern const char kMetricAttemptPayloadDownloadSpeedKBps[];
63extern const char kMetricAttemptDownloadSource[];
64extern const char kMetricAttemptResult[];
65extern const char kMetricAttemptInternalErrorCode[];
66extern const char kMetricAttemptDownloadErrorCode[];
67
68// UpdateEngine.SuccessfulUpdate.* metrics.
69extern const char kMetricSuccessfulUpdateAttemptCount[];
70extern const char kMetricSuccessfulUpdateBytesDownloadedMiB[];
71extern const char kMetricSuccessfulUpdateDownloadOverheadPercentage[];
72extern const char kMetricSuccessfulUpdateDownloadSourcesUsed[];
May Lippert60aa3ca2018-08-15 16:55:29 -070073extern const char kMetricSuccessfulUpdateDurationFromSeenDays[];
74extern const char kMetricSuccessfulUpdateDurationFromSeenTimeRestrictedDays[];
Tianjie Xu98333a82017-09-22 21:29:29 -070075extern const char kMetricSuccessfulUpdatePayloadType[];
76extern const char kMetricSuccessfulUpdatePayloadSizeMiB[];
77extern const char kMetricSuccessfulUpdateRebootCount[];
78extern const char kMetricSuccessfulUpdateTotalDurationMinutes[];
Sen Jiang8712e962018-05-08 12:12:28 -070079extern const char kMetricSuccessfulUpdateTotalDurationUptimeMinutes[];
Tianjie Xu98333a82017-09-22 21:29:29 -070080extern const char kMetricSuccessfulUpdateUpdatesAbandonedCount[];
81extern const char kMetricSuccessfulUpdateUrlSwitchCount[];
82
83// UpdateEngine.Rollback.* metric.
84extern const char kMetricRollbackResult[];
85
Marton Hunyadya0302682018-05-16 18:52:13 +020086// UpdateEngine.EnterpriseRollback.* metrics.
87extern const char kMetricEnterpriseRollbackFailure[];
88extern const char kMetricEnterpriseRollbackSuccess[];
89
Tianjie Xu98333a82017-09-22 21:29:29 -070090// UpdateEngine.CertificateCheck.* metrics.
91extern const char kMetricCertificateCheckUpdateCheck[];
92extern const char kMetricCertificateCheckDownload[];
93
Marton Hunyadyffbfdfb2018-05-30 13:03:29 +020094// UpdateEngine.KernelKey.* metrics.
95extern const char kMetricKernelMinVersion[];
96extern const char kMetricKernelMaxRollforwardVersion[];
97extern const char kMetricKernelMaxRollforwardSetSuccess[];
98
Tianjie Xu98333a82017-09-22 21:29:29 -070099// UpdateEngine.* metrics.
100extern const char kMetricFailedUpdateCount[];
101extern const char kMetricInstallDateProvisioningSource[];
102extern const char kMetricTimeToRebootMinutes[];
103
104} // namespace metrics
105
Tianjie Xu282aa1f2017-09-05 13:42:45 -0700106class MetricsReporterOmaha : public MetricsReporterInterface {
107 public:
Tianjie Xu98333a82017-09-22 21:29:29 -0700108 MetricsReporterOmaha();
Tianjie Xu282aa1f2017-09-05 13:42:45 -0700109
110 ~MetricsReporterOmaha() override = default;
111
Tianjie Xu282aa1f2017-09-05 13:42:45 -0700112 void ReportRollbackMetrics(metrics::RollbackResult result) override;
113
Marton Hunyadya0302682018-05-16 18:52:13 +0200114 void ReportEnterpriseRollbackMetrics(
115 bool success, const std::string& rollback_version) override;
116
Tianjie Xu282aa1f2017-09-05 13:42:45 -0700117 void ReportDailyMetrics(base::TimeDelta os_age) override;
118
119 void ReportUpdateCheckMetrics(
120 SystemState* system_state,
121 metrics::CheckResult result,
122 metrics::CheckReaction reaction,
123 metrics::DownloadErrorCode download_error_code) override;
124
Tianjie Xu1f93d092017-10-09 12:13:29 -0700125 void ReportUpdateAttemptMetrics(SystemState* system_state,
126 int attempt_number,
127 PayloadType payload_type,
128 base::TimeDelta duration,
129 base::TimeDelta duration_uptime,
130 int64_t payload_size,
131 metrics::AttemptResult attempt_result,
132 ErrorCode internal_error_code) override;
133
134 void ReportUpdateAttemptDownloadMetrics(
Tianjie Xu282aa1f2017-09-05 13:42:45 -0700135 int64_t payload_bytes_downloaded,
136 int64_t payload_download_speed_bps,
137 DownloadSource download_source,
Tianjie Xu282aa1f2017-09-05 13:42:45 -0700138 metrics::DownloadErrorCode payload_download_error_code,
139 metrics::ConnectionType connection_type) override;
140
141 void ReportAbnormallyTerminatedUpdateAttemptMetrics() override;
142
143 void ReportSuccessfulUpdateMetrics(
144 int attempt_count,
145 int updates_abandoned_count,
146 PayloadType payload_type,
147 int64_t payload_size,
148 int64_t num_bytes_downloaded[kNumDownloadSources],
149 int download_overhead_percentage,
150 base::TimeDelta total_duration,
Sen Jiang8712e962018-05-08 12:12:28 -0700151 base::TimeDelta total_duration_uptime,
Tianjie Xu282aa1f2017-09-05 13:42:45 -0700152 int reboot_count,
153 int url_switch_count) override;
154
155 void ReportCertificateCheckMetrics(ServerToCheck server_to_check,
156 CertificateCheckResult result) override;
157
158 void ReportFailedUpdateCount(int target_attempt) override;
159
160 void ReportTimeToReboot(int time_to_reboot_minutes) override;
161
162 void ReportInstallDateProvisioningSource(int source, int max) override;
163
Amin Hassani80f4d4c2018-05-16 13:34:00 -0700164 void ReportInternalErrorCode(ErrorCode error_code) override;
165
Marton Hunyadyffbfdfb2018-05-30 13:03:29 +0200166 void ReportKeyVersionMetrics(int kernel_min_version,
167 int kernel_max_rollforward_version,
168 bool kernel_max_rollforward_success) override;
169
May Lippert60aa3ca2018-08-15 16:55:29 -0700170 void ReportEnterpriseUpdateSeenToDownloadDays(
171 bool has_time_restriction_policy, int time_to_update_days) override;
172
Tianjie Xu282aa1f2017-09-05 13:42:45 -0700173 private:
Tianjie Xu98333a82017-09-22 21:29:29 -0700174 friend class MetricsReporterOmahaTest;
Amin Hassaniec7bc112020-10-29 16:47:58 -0700175 FRIEND_TEST(MetricsReporterOmahaTest, WallclockDurationHelper);
176 FRIEND_TEST(MetricsReporterOmahaTest, MonotonicDurationHelper);
177
178 // This function returns the duration on the wallclock since the last
179 // time it was called for the same |state_variable_key| value.
180 //
181 // If the function returns |true|, the duration (always non-negative)
182 // is returned in |out_duration|. If the function returns |false|
183 // something went wrong or there was no previous measurement.
184 bool WallclockDurationHelper(SystemState* system_state,
185 const std::string& state_variable_key,
186 base::TimeDelta* out_duration);
187
188 // This function returns the duration on the monotonic clock since the
189 // last time it was called for the same |storage| pointer.
190 //
191 // You should pass a pointer to a 64-bit integer in |storage| which
192 // should be initialized to 0.
193 //
194 // If the function returns |true|, the duration (always non-negative)
195 // is returned in |out_duration|. If the function returns |false|
196 // something went wrong or there was no previous measurement.
197 bool MonotonicDurationHelper(SystemState* system_state,
198 int64_t* storage,
199 base::TimeDelta* out_duration);
Tianjie Xu98333a82017-09-22 21:29:29 -0700200
201 std::unique_ptr<MetricsLibraryInterface> metrics_lib_;
Tianjie Xu282aa1f2017-09-05 13:42:45 -0700202
203 DISALLOW_COPY_AND_ASSIGN(MetricsReporterOmaha);
204}; // class metrics
205
206} // namespace chromeos_update_engine
207
Amin Hassaniec7bc112020-10-29 16:47:58 -0700208#endif // UPDATE_ENGINE_CROS_METRICS_REPORTER_OMAHA_H_