diff options
| author | 2017-01-16 19:11:19 -0800 | |
|---|---|---|
| committer | 2017-02-08 06:04:52 -0800 | |
| commit | 929d6517dfd338f0d481dbe6587643d5aef27ec6 (patch) | |
| tree | b80a93b93946bd4e982b9f4abd97a4c3aa43feb3 /libs/androidfw/tests | |
| parent | c270de85cc0c398d9ce165592908d2740219a708 (diff) | |
AssetManager2: Add GetResourceId
Add ability to lookup a resource by name.
Test: make libandroidfw_tests
Change-Id: I262ba5ce4c9892458226fbdb44cf21f9877fb92d
Diffstat (limited to 'libs/androidfw/tests')
| -rw-r--r-- | libs/androidfw/tests/Android.mk | 1 | ||||
| -rw-r--r-- | libs/androidfw/tests/AssetManager2_test.cpp | 9 | ||||
| -rw-r--r-- | libs/androidfw/tests/ResourceUtils_test.cpp | 49 | ||||
| -rw-r--r-- | libs/androidfw/tests/Theme_test.cpp | 7 |
4 files changed, 59 insertions, 7 deletions
diff --git a/libs/androidfw/tests/Android.mk b/libs/androidfw/tests/Android.mk index 650f8138366b..19527c51e816 100644 --- a/libs/androidfw/tests/Android.mk +++ b/libs/androidfw/tests/Android.mk @@ -32,6 +32,7 @@ testFiles := \ ConfigLocale_test.cpp \ Idmap_test.cpp \ LoadedArsc_test.cpp \ + ResourceUtils_test.cpp \ ResTable_test.cpp \ Split_test.cpp \ StringPiece_test.cpp \ diff --git a/libs/androidfw/tests/AssetManager2_test.cpp b/libs/androidfw/tests/AssetManager2_test.cpp index 557d8d40dfc2..78fbb0f85f68 100644 --- a/libs/androidfw/tests/AssetManager2_test.cpp +++ b/libs/androidfw/tests/AssetManager2_test.cpp @@ -20,6 +20,7 @@ #include "android-base/logging.h" #include "TestHelpers.h" +#include "androidfw/ResourceUtils.h" #include "data/appaslib/R.h" #include "data/basic/R.h" #include "data/lib_one/R.h" @@ -194,11 +195,11 @@ TEST_F(AssetManager2Test, FindsResourceFromAppLoadedAsSharedLibrary) { ResTable_config selected_config; uint32_t flags; ApkAssetsCookie cookie = assetmanager.GetResource( - util::fix_package_id(appaslib::R::integer::number1, 0x02), false /*may_be_bag*/, + fix_package_id(appaslib::R::integer::number1, 0x02), false /*may_be_bag*/, 0u /*density_override*/, &value, &selected_config, &flags); ASSERT_NE(kInvalidCookie, cookie); EXPECT_EQ(Res_value::TYPE_REFERENCE, value.dataType); - EXPECT_EQ(util::fix_package_id(appaslib::R::array::integerArray1, 0x02), value.data); + EXPECT_EQ(fix_package_id(appaslib::R::array::integerArray1, 0x02), value.data); } TEST_F(AssetManager2Test, FindsBagResourceFromSingleApkAssets) { @@ -238,9 +239,9 @@ TEST_F(AssetManager2Test, FindsBagResourceFromSharedLibrary) { // First two attributes come from lib_one. EXPECT_EQ(1, bag->entries[0].cookie); - EXPECT_EQ(0x03, util::get_package_id(bag->entries[0].key)); + EXPECT_EQ(0x03, get_package_id(bag->entries[0].key)); EXPECT_EQ(1, bag->entries[1].cookie); - EXPECT_EQ(0x03, util::get_package_id(bag->entries[1].key)); + EXPECT_EQ(0x03, get_package_id(bag->entries[1].key)); } TEST_F(AssetManager2Test, MergesStylesWithParentFromSingleApkAssets) { diff --git a/libs/androidfw/tests/ResourceUtils_test.cpp b/libs/androidfw/tests/ResourceUtils_test.cpp new file mode 100644 index 000000000000..b64a884fb8fb --- /dev/null +++ b/libs/androidfw/tests/ResourceUtils_test.cpp @@ -0,0 +1,49 @@ +/* + * Copyright (C) 2017 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 "androidfw/ResourceUtils.h" + +#include "TestHelpers.h" + +namespace android { + +TEST(ResourceUtilsTest, ExtractResourceName) { + StringPiece package, type, entry; + ASSERT_TRUE(ExtractResourceName("android:string/foo", &package, &type, &entry)); + EXPECT_EQ("android", package); + EXPECT_EQ("string", type); + EXPECT_EQ("foo", entry); + + ASSERT_TRUE(ExtractResourceName("string/foo", &package, &type, &entry)); + EXPECT_EQ("", package); + EXPECT_EQ("string", type); + EXPECT_EQ("foo", entry); + + ASSERT_TRUE(ExtractResourceName("foo", &package, &type, &entry)); + EXPECT_EQ("", package); + EXPECT_EQ("", type); + EXPECT_EQ("foo", entry); + + ASSERT_TRUE(ExtractResourceName("android:foo", &package, &type, &entry)); + EXPECT_EQ("android", package); + EXPECT_EQ("", type); + EXPECT_EQ("foo", entry); + + EXPECT_FALSE(ExtractResourceName(":string/foo", &package, &type, &entry)); + EXPECT_FALSE(ExtractResourceName("/foo", &package, &type, &entry)); +} + +} // namespace android diff --git a/libs/androidfw/tests/Theme_test.cpp b/libs/androidfw/tests/Theme_test.cpp index daed28b01a4f..dfff9c00922c 100644 --- a/libs/androidfw/tests/Theme_test.cpp +++ b/libs/androidfw/tests/Theme_test.cpp @@ -19,6 +19,7 @@ #include "android-base/logging.h" #include "TestHelpers.h" +#include "androidfw/ResourceUtils.h" #include "data/lib_one/R.h" #include "data/libclient/R.h" #include "data/styles/R.h" @@ -215,9 +216,9 @@ TEST_F(ThemeTest, ResolveDynamicAttributesAndReferencesToSharedLibrary) { EXPECT_EQ(Res_value::TYPE_REFERENCE, value.dataType); // lib_one is assigned package ID 0x03. - EXPECT_EQ(3u, util::get_package_id(value.data)); - EXPECT_EQ(util::get_type_id(lib_one::R::string::foo), util::get_type_id(value.data)); - EXPECT_EQ(util::get_entry_id(lib_one::R::string::foo), util::get_entry_id(value.data)); + EXPECT_EQ(3u, get_package_id(value.data)); + EXPECT_EQ(get_type_id(lib_one::R::string::foo), get_type_id(value.data)); + EXPECT_EQ(get_entry_id(lib_one::R::string::foo), get_entry_id(value.data)); } TEST_F(ThemeTest, CopyThemeSameAssetManager) { |