Update API: initial support
Initial pieces of the Update API callback framework.
- move the status callback params to a new object, UpdateEngineStatus to
allow for the easier addition of new params in the future.
- switch the IUpdateEngineStatusCallback to provide a
ParcelableUpdateEngineStatus instead of a series of individual params
- move the various GetStatus() methods to use the UpdateEngineStatus
object instead of a series of params (which will need future expansion)
- Add current and new product/os versions to both the UpdateEngineStatus
and the ParcelableUpdateEngineStatus.
Bug: 64808702
Test: unit tests, and performing OTAs via a test app calling
IUpdateEngine::AttemptUpdate() via UpdateManager::performUpdateNow()
Change-Id: I53f66f3511049f0809855814e1e758023cd8cc08
(cherry picked from commit 4f96ebf85022837603f2e10100a044d234b7d86f)
diff --git a/parcelable_update_engine_status.cc b/parcelable_update_engine_status.cc
index d8eb6db..d3e7eaa 100644
--- a/parcelable_update_engine_status.cc
+++ b/parcelable_update_engine_status.cc
@@ -15,12 +15,27 @@
//
#include "update_engine/parcelable_update_engine_status.h"
+#include "update_engine/update_status_utils.h"
#include <binder/Parcel.h>
+using update_engine::UpdateEngineStatus;
+
namespace android {
namespace brillo {
+ParcelableUpdateEngineStatus::ParcelableUpdateEngineStatus(
+ const UpdateEngineStatus& status)
+ : last_checked_time_(status.last_checked_time_ms),
+ current_operation_(
+ chromeos_update_engine::UpdateStatusToString(status.status)),
+ progress_(status.progress),
+ current_version_(String16{status.current_version.c_str()}),
+ current_system_version_(String16{status.current_system_version.c_str()}),
+ new_size_(status.new_size_bytes),
+ new_version_(String16{status.new_version.c_str()}),
+ new_system_version_(String16{status.new_system_version.c_str()}) {}
+
status_t ParcelableUpdateEngineStatus::writeToParcel(Parcel* parcel) const {
status_t status;
@@ -29,12 +44,27 @@
return status;
}
+ status = parcel->writeString16(current_operation_);
+ if (status != OK) {
+ return status;
+ }
+
status = parcel->writeDouble(progress_);
if (status != OK) {
return status;
}
- status = parcel->writeString16(current_operation_);
+ status = parcel->writeString16(current_version_);
+ if (status != OK) {
+ return status;
+ }
+
+ status = parcel->writeString16(current_system_version_);
+ if (status != OK) {
+ return status;
+ }
+
+ status = parcel->writeInt64(new_size_);
if (status != OK) {
return status;
}
@@ -44,7 +74,7 @@
return status;
}
- return parcel->writeInt64(new_size_);
+ return parcel->writeString16(new_system_version_);
}
status_t ParcelableUpdateEngineStatus::readFromParcel(const Parcel* parcel) {
@@ -55,12 +85,27 @@
return status;
}
+ status = parcel->readString16(¤t_operation_);
+ if (status != OK) {
+ return status;
+ }
+
status = parcel->readDouble(&progress_);
if (status != OK) {
return status;
}
- status = parcel->readString16(¤t_operation_);
+ status = parcel->readString16(¤t_version_);
+ if (status != OK) {
+ return status;
+ }
+
+ status = parcel->readString16(¤t_system_version_);
+ if (status != OK) {
+ return status;
+ }
+
+ status = parcel->readInt64(&new_size_);
if (status != OK) {
return status;
}
@@ -70,7 +115,7 @@
return status;
}
- return parcel->readInt64(&new_size_);
+ return parcel->readString16(&new_system_version_);
}
} // namespace brillo