diff options
Diffstat (limited to 'libnativeloader/library_namespaces_test.cpp')
-rw-r--r-- | libnativeloader/library_namespaces_test.cpp | 56 |
1 files changed, 37 insertions, 19 deletions
diff --git a/libnativeloader/library_namespaces_test.cpp b/libnativeloader/library_namespaces_test.cpp index 7780418846..4582223f4a 100644 --- a/libnativeloader/library_namespaces_test.cpp +++ b/libnativeloader/library_namespaces_test.cpp @@ -31,40 +31,45 @@ using ::android::base::testing::HasValue; using ::android::base::testing::WithMessage; using ::testing::StartsWith; -TEST(LibraryNamespacesTest, TestGetApiDomainFromPath) { +static ApiDomain GetProductApiDomain(ApiDomain fallback_domain) { // GetApiDomainFromPath returns API_DOMAIN_PRODUCT only if the device is // trebleized and has an unbundled product partition. - ApiDomain api_domain_product = is_product_treblelized() ? API_DOMAIN_PRODUCT : API_DOMAIN_DEFAULT; + return is_product_treblelized() ? API_DOMAIN_PRODUCT : fallback_domain; +} +TEST(LibraryNamespacesTest, TestGetApiDomainFromPath) { EXPECT_EQ(GetApiDomainFromPath("/data/somewhere"), API_DOMAIN_DEFAULT); - EXPECT_EQ(GetApiDomainFromPath("/system/somewhere"), API_DOMAIN_DEFAULT); - EXPECT_EQ(GetApiDomainFromPath("/product/somewhere"), api_domain_product); + EXPECT_EQ(GetApiDomainFromPath("/system/somewhere"), API_DOMAIN_SYSTEM); + EXPECT_EQ(GetApiDomainFromPath("/system_ext/somewhere"), API_DOMAIN_SYSTEM); + EXPECT_EQ(GetApiDomainFromPath("/systemext/somewhere"), API_DOMAIN_DEFAULT); + EXPECT_EQ(GetApiDomainFromPath("/product/somewhere"), GetProductApiDomain(API_DOMAIN_DEFAULT)); EXPECT_EQ(GetApiDomainFromPath("/vendor/somewhere"), API_DOMAIN_VENDOR); - EXPECT_EQ(GetApiDomainFromPath("/system/product/somewhere"), api_domain_product); + EXPECT_EQ(GetApiDomainFromPath("/system/product/somewhere"), + GetProductApiDomain(API_DOMAIN_SYSTEM)); EXPECT_EQ(GetApiDomainFromPath("/system/vendor/somewhere"), API_DOMAIN_VENDOR); EXPECT_EQ(GetApiDomainFromPath(""), API_DOMAIN_DEFAULT); EXPECT_EQ(GetApiDomainFromPath("/"), API_DOMAIN_DEFAULT); EXPECT_EQ(GetApiDomainFromPath("product/somewhere"), API_DOMAIN_DEFAULT); EXPECT_EQ(GetApiDomainFromPath("/product"), API_DOMAIN_DEFAULT); - EXPECT_EQ(GetApiDomainFromPath("/product/"), api_domain_product); + EXPECT_EQ(GetApiDomainFromPath("/product/"), GetProductApiDomain(API_DOMAIN_DEFAULT)); EXPECT_EQ(GetApiDomainFromPath(":/product/"), API_DOMAIN_DEFAULT); EXPECT_EQ(GetApiDomainFromPath("/data/somewhere:/product/somewhere"), API_DOMAIN_DEFAULT); EXPECT_EQ(GetApiDomainFromPath("/vendor/somewhere:/product/somewhere"), API_DOMAIN_VENDOR); - EXPECT_EQ(GetApiDomainFromPath("/product/somewhere:/vendor/somewhere"), api_domain_product); + EXPECT_EQ(GetApiDomainFromPath("/product/somewhere:/vendor/somewhere"), + GetProductApiDomain(API_DOMAIN_DEFAULT)); } TEST(LibraryNamespacesTest, TestGetApiDomainFromPathList) { - // GetApiDomainFromPath returns API_DOMAIN_PRODUCT only if the device is - // trebleized and has an unbundled product partition. - ApiDomain api_domain_product = is_product_treblelized() ? API_DOMAIN_PRODUCT : API_DOMAIN_DEFAULT; - EXPECT_THAT(GetApiDomainFromPathList("/data/somewhere"), HasValue(API_DOMAIN_DEFAULT)); EXPECT_THAT(GetApiDomainFromPathList("/system/somewhere"), HasValue(API_DOMAIN_DEFAULT)); - EXPECT_THAT(GetApiDomainFromPathList("/product/somewhere"), HasValue(api_domain_product)); + EXPECT_THAT(GetApiDomainFromPathList("/system_ext/somewhere"), HasValue(API_DOMAIN_DEFAULT)); + EXPECT_THAT(GetApiDomainFromPathList("/product/somewhere"), + HasValue(GetProductApiDomain(API_DOMAIN_DEFAULT))); EXPECT_THAT(GetApiDomainFromPathList("/vendor/somewhere"), HasValue(API_DOMAIN_VENDOR)); - EXPECT_THAT(GetApiDomainFromPathList("/system/product/somewhere"), HasValue(api_domain_product)); + EXPECT_THAT(GetApiDomainFromPathList("/system/product/somewhere"), + HasValue(GetProductApiDomain(API_DOMAIN_DEFAULT))); EXPECT_THAT(GetApiDomainFromPathList("/system/vendor/somewhere"), HasValue(API_DOMAIN_VENDOR)); EXPECT_THAT(GetApiDomainFromPathList(""), HasValue(API_DOMAIN_DEFAULT)); @@ -73,12 +78,25 @@ TEST(LibraryNamespacesTest, TestGetApiDomainFromPathList) { EXPECT_THAT(GetApiDomainFromPathList("/vendor/somewhere:"), HasValue(API_DOMAIN_VENDOR)); EXPECT_THAT(GetApiDomainFromPathList("/data/somewhere:/product/somewhere"), - HasValue(api_domain_product)); - if (api_domain_product == API_DOMAIN_PRODUCT) { - EXPECT_THAT(GetApiDomainFromPathList("/vendor/somewhere:/product/somewhere"), - HasError(WithMessage(StartsWith("Path list crosses partition boundaries")))); - EXPECT_THAT(GetApiDomainFromPathList("/product/somewhere:/vendor/somewhere"), - HasError(WithMessage(StartsWith("Path list crosses partition boundaries")))); + HasValue(GetProductApiDomain(API_DOMAIN_DEFAULT))); + EXPECT_THAT(GetApiDomainFromPathList("/system/somewhere:/product/somewhere"), + HasValue(GetProductApiDomain(API_DOMAIN_DEFAULT))); + EXPECT_THAT(GetApiDomainFromPathList("/product/somewhere:/system/somewhere"), + HasValue(GetProductApiDomain(API_DOMAIN_DEFAULT))); + EXPECT_THAT(GetApiDomainFromPathList("/data/somewhere:/vendor/somewhere"), + HasValue(API_DOMAIN_VENDOR)); + EXPECT_THAT(GetApiDomainFromPathList("/system/somewhere:/vendor/somewhere"), + HasValue(API_DOMAIN_VENDOR)); + EXPECT_THAT(GetApiDomainFromPathList("/vendor/somewhere:/system/somewhere"), + HasValue(API_DOMAIN_VENDOR)); + + if (GetProductApiDomain(API_DOMAIN_DEFAULT) == API_DOMAIN_PRODUCT) { + EXPECT_THAT( + GetApiDomainFromPathList("/vendor/somewhere:/product/somewhere"), + HasError(WithMessage(StartsWith("Path list crosses vendor/product partition boundaries")))); + EXPECT_THAT( + GetApiDomainFromPathList("/system/somewhere:/product/somewhere:/vendor/somewhere"), + HasError(WithMessage(StartsWith("Path list crosses vendor/product partition boundaries")))); } } |