diff options
author | Tao Bao <tbao@google.com> | 2016-10-12 21:28:24 +0200 |
---|---|---|
committer | android-build-merger <android-build-merger@google.com> | 2016-10-12 21:28:24 +0200 |
commit | 3ac1995cfd0295bffddb3d56a27a704513a4ac13 (patch) | |
tree | 61b9cd5ea5a627c1fd7217566b94821257f11e0f /tests | |
parent | Merge "Refactor libupdater into a seperate module." (diff) | |
parent | Merge "updater: Kill the duplicate PrintSha1() in install.cpp." (diff) | |
download | android_bootable_recovery-3ac1995cfd0295bffddb3d56a27a704513a4ac13.tar android_bootable_recovery-3ac1995cfd0295bffddb3d56a27a704513a4ac13.tar.gz android_bootable_recovery-3ac1995cfd0295bffddb3d56a27a704513a4ac13.tar.bz2 android_bootable_recovery-3ac1995cfd0295bffddb3d56a27a704513a4ac13.tar.lz android_bootable_recovery-3ac1995cfd0295bffddb3d56a27a704513a4ac13.tar.xz android_bootable_recovery-3ac1995cfd0295bffddb3d56a27a704513a4ac13.tar.zst android_bootable_recovery-3ac1995cfd0295bffddb3d56a27a704513a4ac13.zip |
Diffstat (limited to 'tests')
-rw-r--r-- | tests/component/updater_test.cpp | 43 |
1 files changed, 36 insertions, 7 deletions
diff --git a/tests/component/updater_test.cpp b/tests/component/updater_test.cpp index ec9c29035..bd6534b3b 100644 --- a/tests/component/updater_test.cpp +++ b/tests/component/updater_test.cpp @@ -25,8 +25,7 @@ struct selabel_handle *sehandle = nullptr; -static void expect(const char* expected, const char* expr_str, - ErrorCode error_code, CauseCode cause_code) { +static void expect(const char* expected, const char* expr_str, CauseCode cause_code) { Expr* e; int error_count; EXPECT_EQ(parse_string(expr_str, &e, &error_count), 0); @@ -41,7 +40,10 @@ static void expect(const char* expected, const char* expr_str, EXPECT_STREQ(expected, result); } - EXPECT_EQ(error_code, state.error_code); + // Error code is set in updater/updater.cpp only, by parsing State.errmsg. + EXPECT_EQ(kNoError, state.error_code); + + // Cause code should always be available. EXPECT_EQ(cause_code, state.cause_code); free(result); @@ -59,13 +61,40 @@ class UpdaterTest : public ::testing::Test { TEST_F(UpdaterTest, getprop) { expect(android::base::GetProperty("ro.product.device", "").c_str(), "getprop(\"ro.product.device\")", - kNoError, kNoCause); + kNoCause); expect(android::base::GetProperty("ro.build.fingerprint", "").c_str(), "getprop(\"ro.build.fingerprint\")", - kNoError, kNoCause); + kNoCause); // getprop() accepts only one parameter. - expect(nullptr, "getprop()", kNoError, kArgsParsingFailure); - expect(nullptr, "getprop(\"arg1\", \"arg2\")", kNoError, kArgsParsingFailure); + expect(nullptr, "getprop()", kArgsParsingFailure); + expect(nullptr, "getprop(\"arg1\", \"arg2\")", kArgsParsingFailure); +} + +TEST_F(UpdaterTest, sha1_check) { + // sha1_check(data) returns the SHA-1 of the data. + expect("81fe8bfe87576c3ecb22426f8e57847382917acf", "sha1_check(\"abcd\")", kNoCause); + expect("da39a3ee5e6b4b0d3255bfef95601890afd80709", "sha1_check(\"\")", kNoCause); + + // sha1_check(data, sha1_hex, [sha1_hex, ...]) returns the matched SHA-1. + expect("81fe8bfe87576c3ecb22426f8e57847382917acf", + "sha1_check(\"abcd\", \"81fe8bfe87576c3ecb22426f8e57847382917acf\")", + kNoCause); + + expect("81fe8bfe87576c3ecb22426f8e57847382917acf", + "sha1_check(\"abcd\", \"wrong_sha1\", \"81fe8bfe87576c3ecb22426f8e57847382917acf\")", + kNoCause); + + // Or "" if there's no match. + expect("", + "sha1_check(\"abcd\", \"wrong_sha1\")", + kNoCause); + + expect("", + "sha1_check(\"abcd\", \"wrong_sha1\", \"wrong_sha2\")", + kNoCause); + + // sha1_check() expects at least one argument. + expect(nullptr, "sha1_check()", kArgsParsingFailure); } |