Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit a7995d75 authored by Tao Bao's avatar Tao Bao Committed by Gerrit Code Review
Browse files

Merge "Refactor libupdater into a seperate module."

parents 2bd94433 0c7839ac
Loading
Loading
Loading
Loading
+22 −6
Original line number Diff line number Diff line
@@ -41,25 +41,41 @@ LOCAL_ADDITIONAL_DEPENDENCIES := $(LOCAL_PATH)/Android.mk
LOCAL_MODULE := recovery_component_test
LOCAL_C_INCLUDES := bootable/recovery
LOCAL_SRC_FILES := \
    component/applypatch_test.cpp \
    component/edify_test.cpp \
    component/verifier_test.cpp \
    component/applypatch_test.cpp
    component/updater_test.cpp \
    component/verifier_test.cpp
LOCAL_FORCE_STATIC_EXECUTABLE := true

tune2fs_static_libraries := \
    libext2_com_err \
    libext2_blkid \
    libext2_quota \
    libext2_uuid_static \
    libext2_e2p \
    libext2fs

LOCAL_STATIC_LIBRARIES := \
    libapplypatch \
    libedify \
    libotafault \
    libupdater \
    libverifier \
    libcrypto_utils \
    libcrypto \
    libminui \
    libminzip \
    libmounts \
    liblog \
    libselinux \
    libext4_utils_static \
    libsparse_static \
    libcrypto_utils \
    libcrypto \
    libcutils \
    libbz \
    libz \
    libc \
    libbase \
    liblog
    libtune2fs \
    $(tune2fs_static_libraries)

testdata_out_path := $(TARGET_OUT_DATA_NATIVE_TESTS)/recovery
testdata_files := $(call find-subdir-files, testdata/*)
+71 −0
Original line number Diff line number Diff line
/*
 * Copyright (C) 2016 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 <string>

#include <android-base/properties.h>
#include <gtest/gtest.h>

#include "edify/expr.h"
#include "error_code.h"
#include "updater/install.h"

struct selabel_handle *sehandle = nullptr;

static void expect(const char* expected, const char* expr_str,
                   ErrorCode error_code, CauseCode cause_code) {
    Expr* e;
    int error_count;
    EXPECT_EQ(parse_string(expr_str, &e, &error_count), 0);

    State state(expr_str, nullptr);

    char* result = Evaluate(&state, e);

    if (expected == nullptr) {
        EXPECT_EQ(nullptr, result);
    } else {
        EXPECT_STREQ(expected, result);
    }

    EXPECT_EQ(error_code, state.error_code);
    EXPECT_EQ(cause_code, state.cause_code);

    free(result);
}

class UpdaterTest : public ::testing::Test {
  protected:
    virtual void SetUp() {
        RegisterBuiltins();
        RegisterInstallFunctions();
        FinishRegistration();
    }
};

TEST_F(UpdaterTest, getprop) {
    expect(android::base::GetProperty("ro.product.device", "").c_str(),
           "getprop(\"ro.product.device\")",
           kNoError, kNoCause);

    expect(android::base::GetProperty("ro.build.fingerprint", "").c_str(),
           "getprop(\"ro.build.fingerprint\")",
           kNoError, kNoCause);

    // getprop() accepts only one parameter.
    expect(nullptr, "getprop()", kNoError, kArgsParsingFailure);
    expect(nullptr, "getprop(\"arg1\", \"arg2\")", kNoError, kArgsParsingFailure);
}
+67 −44
Original line number Diff line number Diff line
@@ -14,41 +14,6 @@

LOCAL_PATH := $(call my-dir)

# updater (static executable)
# ===============================
# Build a statically-linked binary to include in OTA packages.
include $(CLEAR_VARS)

updater_src_files := \
    install.cpp \
    blockimg.cpp \
    updater.cpp

LOCAL_CLANG := true
LOCAL_SRC_FILES := $(updater_src_files)

LOCAL_STATIC_LIBRARIES += \
    $(TARGET_RECOVERY_UPDATER_LIBS) \
    $(TARGET_RECOVERY_UPDATER_EXTRA_LIBS) \
    libfec \
    libfec_rs \
    libext4_utils_static \
    libsquashfs_utils \
    libcrypto_utils \
    libcrypto \
    libapplypatch \
    libotafault \
    libedify \
    libminzip \
    libmounts \
    libz \
    libbz \
    libcutils \
    liblog \
    libselinux \
    libbase \
    liblog

tune2fs_static_libraries := \
    libext2_com_err \
    libext2_blkid \
@@ -57,17 +22,77 @@ tune2fs_static_libraries := \
    libext2_e2p \
    libext2fs

LOCAL_STATIC_LIBRARIES += \
updater_common_static_libraries := \
    libapplypatch \
    libedify \
    libminzip \
    libmounts \
    libotafault \
    libext4_utils_static \
    libfec \
    libfec_rs \
    liblog \
    libselinux \
    libsparse_static \
    libsquashfs_utils \
    libbz \
    libz \
    libbase \
    libcrypto \
    libcrypto_utils \
    libcutils \
    libtune2fs \
    $(tune2fs_static_libraries)

LOCAL_CFLAGS += -Wno-unused-parameter -Werror
LOCAL_STATIC_LIBRARIES += \
    libsparse_static \
    libz
# libupdater (static library)
# ===============================
include $(CLEAR_VARS)

LOCAL_MODULE := libupdater

LOCAL_SRC_FILES := \
    install.cpp \
    blockimg.cpp

LOCAL_C_INCLUDES := \
    $(LOCAL_PATH)/.. \
    $(LOCAL_PATH)/include \
    external/e2fsprogs/misc

LOCAL_CFLAGS := \
    -Wno-unused-parameter \
    -Werror

LOCAL_C_INCLUDES += external/e2fsprogs/misc
LOCAL_C_INCLUDES += $(LOCAL_PATH)/..
LOCAL_EXPORT_C_INCLUDE_DIRS := \
    $(LOCAL_PATH)/include

LOCAL_STATIC_LIBRARIES := \
    $(updater_common_static_libraries)

include $(BUILD_STATIC_LIBRARY)

# updater (static executable)
# ===============================
include $(CLEAR_VARS)

LOCAL_MODULE := updater

LOCAL_SRC_FILES := \
    updater.cpp

LOCAL_C_INCLUDES := \
    $(LOCAL_PATH)/.. \
    $(LOCAL_PATH)/include

LOCAL_CFLAGS := \
    -Wno-unused-parameter \
    -Werror

LOCAL_STATIC_LIBRARIES := \
    libupdater \
    $(TARGET_RECOVERY_UPDATER_LIBS) \
    $(TARGET_RECOVERY_UPDATER_EXTRA_LIBS) \
    $(updater_common_static_libraries)

# Each library in TARGET_RECOVERY_UPDATER_LIBS should have a function
# named "Register_<libname>()".  Here we emit a little C function that
@@ -108,8 +133,6 @@ LOCAL_C_INCLUDES += $(dir $(inc))
inc :=
inc_dep_file :=

LOCAL_MODULE := updater

LOCAL_FORCE_STATIC_EXECUTABLE := true

include $(BUILD_EXECUTABLE)
+2 −2
Original line number Diff line number Diff line
@@ -45,12 +45,12 @@
#include "applypatch/applypatch.h"
#include "edify/expr.h"
#include "error_code.h"
#include "install.h"
#include "updater/install.h"
#include "openssl/sha.h"
#include "minzip/Hash.h"
#include "ota_io.h"
#include "print_sha1.h"
#include "updater.h"
#include "updater/updater.h"

#define BLOCKSIZE 4096

Loading