Merge changes from topic "services_serve_interfaces_test"
* changes: Adds new property for service name -> PID. Adds a library to parse service info from init_rc files for use in tests. Adds a visibility rule for init defaults.
This commit is contained in:
commit
fb54b74fa0
5 changed files with 149 additions and 5 deletions
|
|
@ -93,12 +93,16 @@ cc_defaults {
|
|||
"libutils",
|
||||
],
|
||||
bootstrap: true,
|
||||
visibility: [":__subpackages__"],
|
||||
}
|
||||
|
||||
cc_library_static {
|
||||
name: "libinit",
|
||||
recovery_available: true,
|
||||
defaults: ["init_defaults", "selinux_policy_version"],
|
||||
defaults: [
|
||||
"init_defaults",
|
||||
"selinux_policy_version",
|
||||
],
|
||||
srcs: [
|
||||
"action.cpp",
|
||||
"action_manager.cpp",
|
||||
|
|
@ -143,7 +147,10 @@ cc_library_static {
|
|||
"ueventd_parser.cpp",
|
||||
"util.cpp",
|
||||
],
|
||||
whole_static_libs: ["libcap", "com.android.sysprop.apex"],
|
||||
whole_static_libs: [
|
||||
"libcap",
|
||||
"com.android.sysprop.apex",
|
||||
],
|
||||
header_libs: ["bootimg_headers"],
|
||||
proto: {
|
||||
type: "lite",
|
||||
|
|
@ -153,7 +160,10 @@ cc_library_static {
|
|||
target: {
|
||||
recovery: {
|
||||
cflags: ["-DRECOVERY"],
|
||||
exclude_shared_libs: ["libbinder", "libutils"],
|
||||
exclude_shared_libs: [
|
||||
"libbinder",
|
||||
"libutils",
|
||||
],
|
||||
},
|
||||
},
|
||||
}
|
||||
|
|
@ -182,7 +192,10 @@ cc_binary {
|
|||
target: {
|
||||
recovery: {
|
||||
cflags: ["-DRECOVERY"],
|
||||
exclude_shared_libs: ["libbinder", "libutils"],
|
||||
exclude_shared_libs: [
|
||||
"libbinder",
|
||||
"libutils",
|
||||
],
|
||||
},
|
||||
},
|
||||
}
|
||||
|
|
@ -283,7 +296,7 @@ cc_binary {
|
|||
},
|
||||
generated_headers: [
|
||||
"generated_stub_builtin_function_map",
|
||||
"generated_android_ids"
|
||||
"generated_android_ids",
|
||||
],
|
||||
target: {
|
||||
android: {
|
||||
|
|
|
|||
|
|
@ -167,6 +167,15 @@ void Service::NotifyStateChange(const std::string& new_state) const {
|
|||
property_set(boottime_property, std::to_string(start_ns));
|
||||
}
|
||||
}
|
||||
|
||||
// init.svc_debug_pid.* properties are only for tests, and should not be used
|
||||
// on device for security checks.
|
||||
std::string pid_property = "init.svc_debug_pid." + name_;
|
||||
if (new_state == "running") {
|
||||
property_set(pid_property, std::to_string(pid_));
|
||||
} else if (new_state == "stopped") {
|
||||
property_set(pid_property, "");
|
||||
}
|
||||
}
|
||||
|
||||
void Service::KillProcessGroup(int signal) {
|
||||
|
|
|
|||
27
init/test_utils/Android.bp
Normal file
27
init/test_utils/Android.bp
Normal file
|
|
@ -0,0 +1,27 @@
|
|||
cc_library_static {
|
||||
name: "libinit_test_utils",
|
||||
cflags: [
|
||||
"-Wall",
|
||||
"-Wextra",
|
||||
"-Wno-unused-parameter",
|
||||
"-Werror",
|
||||
],
|
||||
srcs: [
|
||||
"service_utils.cpp",
|
||||
],
|
||||
shared_libs: [
|
||||
"libcutils",
|
||||
"liblog",
|
||||
"libjsoncpp",
|
||||
"libprotobuf-cpp-lite",
|
||||
"libhidl-gen-utils",
|
||||
],
|
||||
whole_static_libs: [
|
||||
"libinit",
|
||||
"libpropertyinfoparser",
|
||||
],
|
||||
static_libs: [
|
||||
"libbase",
|
||||
],
|
||||
export_include_dirs: ["include"], // for tests
|
||||
}
|
||||
32
init/test_utils/include/init-test-utils/service_utils.h
Normal file
32
init/test_utils/include/init-test-utils/service_utils.h
Normal file
|
|
@ -0,0 +1,32 @@
|
|||
//
|
||||
// Copyright (C) 2019 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.
|
||||
//
|
||||
|
||||
#pragma once
|
||||
|
||||
#include <map>
|
||||
#include <set>
|
||||
|
||||
#include <android-base/result.h>
|
||||
#include <hidl-util/FqInstance.h>
|
||||
|
||||
namespace android {
|
||||
namespace init {
|
||||
|
||||
using ServiceInterfacesMap = std::map<std::string, std::set<android::FqInstance>>;
|
||||
android::base::Result<ServiceInterfacesMap> GetOnDeviceServiceInterfacesMap();
|
||||
|
||||
} // namespace init
|
||||
} // namespace android
|
||||
63
init/test_utils/service_utils.cpp
Normal file
63
init/test_utils/service_utils.cpp
Normal file
|
|
@ -0,0 +1,63 @@
|
|||
//
|
||||
// Copyright (C) 2019 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/logging.h>
|
||||
|
||||
#include "../parser.h"
|
||||
#include "../service.h"
|
||||
#include "../service_list.h"
|
||||
#include "../service_parser.h"
|
||||
#include "include/init-test-utils/service_utils.h"
|
||||
|
||||
namespace android {
|
||||
namespace init {
|
||||
|
||||
android::base::Result<ServiceInterfacesMap> GetOnDeviceServiceInterfacesMap() {
|
||||
ServiceList& service_list = ServiceList::GetInstance();
|
||||
Parser parser;
|
||||
parser.AddSectionParser("service",
|
||||
std::make_unique<ServiceParser>(&service_list, nullptr, std::nullopt));
|
||||
for (const auto& location : {
|
||||
"/init.rc",
|
||||
"/system/etc/init",
|
||||
"/system_ext/etc/init",
|
||||
"/product/etc/init",
|
||||
"/odm/etc/init",
|
||||
"/vendor/etc/init",
|
||||
}) {
|
||||
parser.ParseConfig(location);
|
||||
}
|
||||
|
||||
ServiceInterfacesMap result;
|
||||
for (const auto& service : service_list.services()) {
|
||||
// Create an entry for all services, including services that may not
|
||||
// have any declared interfaces.
|
||||
result[service->name()] = std::set<android::FqInstance>();
|
||||
for (const auto& intf : service->interfaces()) {
|
||||
android::FqInstance fqInstance;
|
||||
if (!fqInstance.setTo(intf)) {
|
||||
return android::base::Error() << "Unable to parse interface: '" << intf << "'";
|
||||
}
|
||||
result[service->name()].insert(fqInstance);
|
||||
}
|
||||
}
|
||||
return result;
|
||||
}
|
||||
|
||||
} // namespace init
|
||||
} // namespace android
|
||||
Loading…
Add table
Reference in a new issue