diff options
author | Amin Hassani <ahassani@chromium.org> | 2020-09-16 11:19:28 -0700 |
---|---|---|
committer | Amin Hassani <ahassani@chromium.org> | 2020-09-17 10:17:36 -0700 |
commit | e53b39b8b9c5c0871841bbbb86f23657c0b7f91b (patch) | |
tree | 12746e5e7e4716ba7fc94d3ed5c1a36c4d47d474 /hardware_android_unittest.cc | |
parent | a02a1f1dc837f22226499d9856a949fb180d099a (diff) | |
parent | 9956320ffa4edb340d20bd7f3c852a9e87437bd3 (diff) |
update_engine: Merge remote-tracking branch 'cros/upstream' into cros/master
Done with:
git merge cros/upstream --commit -s recursive
- Added EC key support and its unittests.
- Resolved a conlict on error codes. Since Android versions are not
uploading any UMA metrics, I gave the priority to the Android version
Since they can't be changed.
- Changed the openssl functions to get1 version (from get0) version
because of a current issue with gale. Once the issue is resolved we
need to change them back.
- Some remaining styling issues fixed by clang-format
BUG=b:163153182
TEST=CQ passes
TEST=unittests
Change-Id: Ib95034422b92433ce26e28336bc4806b34910d38
Diffstat (limited to 'hardware_android_unittest.cc')
-rw-r--r-- | hardware_android_unittest.cc | 67 |
1 files changed, 67 insertions, 0 deletions
diff --git a/hardware_android_unittest.cc b/hardware_android_unittest.cc new file mode 100644 index 00000000..9a491f3c --- /dev/null +++ b/hardware_android_unittest.cc @@ -0,0 +1,67 @@ +// +// Copyright (C) 2020 The Android Open Source Project +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +// + +#include <gtest/gtest.h> + +#include "update_engine/common/error_code.h" +#include "update_engine/common/test_utils.h" +#include "update_engine/hardware_android.h" + +namespace chromeos_update_engine { + +TEST(HardwareAndroidTest, IsKernelUpdateValid) { + EXPECT_EQ(ErrorCode::kSuccess, + HardwareAndroid::IsKernelUpdateValid("5.4.42-not-gki", "")) + << "Legacy update should be fine"; + + EXPECT_EQ(ErrorCode::kSuccess, + HardwareAndroid::IsKernelUpdateValid("5.4.42-not-gki", + "5.4.42-android12-0")) + << "Update to GKI should be fine"; + + EXPECT_EQ( + ErrorCode::kDownloadManifestParseError, + HardwareAndroid::IsKernelUpdateValid("5.4.42-not-gki", "5.4.42-not-gki")) + << "Should report parse error for invalid version field"; + + EXPECT_EQ(ErrorCode::kSuccess, + HardwareAndroid::IsKernelUpdateValid( + "5.4.42-android12-0-something", "5.4.42-android12-0-something")) + << "Self update should be fine"; + + EXPECT_EQ(ErrorCode::kSuccess, + HardwareAndroid::IsKernelUpdateValid( + "5.4.42-android12-0-something", "5.4.43-android12-0-something")) + << "Sub-level update should be fine"; + + EXPECT_EQ( + ErrorCode::kSuccess, + HardwareAndroid::IsKernelUpdateValid("5.4.42-android12-0-something", + "5.10.10-android12-0-something")) + << "KMI version update should be fine"; + + EXPECT_EQ(ErrorCode::kPayloadTimestampError, + HardwareAndroid::IsKernelUpdateValid("5.4.42-android12-0-something", + "5.4.5-android12-0-something")) + << "Should detect sub-level downgrade"; + + EXPECT_EQ(ErrorCode::kPayloadTimestampError, + HardwareAndroid::IsKernelUpdateValid("5.4.42-android12-0-something", + "5.1.5-android12-0-something")) + << "Should detect KMI version downgrade"; +} + +} // namespace chromeos_update_engine |