blob: 742f5a7a570a7e67acc1e834d8513b48ae20b58a [file] [log] [blame]
Adam Lesinski1ab598f2015-08-14 14:26:04 -07001/*
2 * Copyright (C) 2015 The Android Open Source Project
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16
Adam Lesinskicacb28f2016-10-19 12:18:14 -070017#include "link/TableMerger.h"
Adam Lesinskice5e56e2016-10-21 17:56:45 -070018
Adam Lesinski6a008172016-02-02 17:02:58 -080019#include "filter/ConfigFilter.h"
Adam Lesinskia6fe3452015-12-09 15:20:52 -080020#include "io/FileSystem.h"
Adam Lesinskice5e56e2016-10-21 17:56:45 -070021#include "test/Test.h"
Adam Lesinski1ab598f2015-08-14 14:26:04 -070022
23namespace aapt {
24
25struct TableMergerTest : public ::testing::Test {
Adam Lesinskice5e56e2016-10-21 17:56:45 -070026 std::unique_ptr<IAaptContext> context_;
Adam Lesinski1ab598f2015-08-14 14:26:04 -070027
Adam Lesinskicacb28f2016-10-19 12:18:14 -070028 void SetUp() override {
Adam Lesinskice5e56e2016-10-21 17:56:45 -070029 context_ =
Adam Lesinskicacb28f2016-10-19 12:18:14 -070030 test::ContextBuilder()
31 // We are compiling this package.
Adam Lesinskice5e56e2016-10-21 17:56:45 -070032 .SetCompilationPackage("com.app.a")
Adam Lesinski1ab598f2015-08-14 14:26:04 -070033
Adam Lesinskicacb28f2016-10-19 12:18:14 -070034 // Merge all packages that have this package ID.
Adam Lesinskice5e56e2016-10-21 17:56:45 -070035 .SetPackageId(0x7f)
Adam Lesinski1ab598f2015-08-14 14:26:04 -070036
Adam Lesinskicacb28f2016-10-19 12:18:14 -070037 // Mangle all packages that do not have this package name.
Adam Lesinskice5e56e2016-10-21 17:56:45 -070038 .SetNameManglerPolicy(NameManglerPolicy{"com.app.a", {"com.app.b"}})
Adam Lesinski1ab598f2015-08-14 14:26:04 -070039
Adam Lesinskice5e56e2016-10-21 17:56:45 -070040 .Build();
Adam Lesinskicacb28f2016-10-19 12:18:14 -070041 }
Adam Lesinski1ab598f2015-08-14 14:26:04 -070042};
43
44TEST_F(TableMergerTest, SimpleMerge) {
Adam Lesinskice5e56e2016-10-21 17:56:45 -070045 std::unique_ptr<ResourceTable> table_a =
Adam Lesinskicacb28f2016-10-19 12:18:14 -070046 test::ResourceTableBuilder()
Adam Lesinskice5e56e2016-10-21 17:56:45 -070047 .SetPackageId("com.app.a", 0x7f)
48 .AddReference("com.app.a:id/foo", "com.app.a:id/bar")
49 .AddReference("com.app.a:id/bar", "com.app.b:id/foo")
50 .AddValue(
Adam Lesinskicacb28f2016-10-19 12:18:14 -070051 "com.app.a:styleable/view",
Adam Lesinskice5e56e2016-10-21 17:56:45 -070052 test::StyleableBuilder().AddItem("com.app.b:id/foo").Build())
53 .Build();
Adam Lesinski1ab598f2015-08-14 14:26:04 -070054
Adam Lesinskice5e56e2016-10-21 17:56:45 -070055 std::unique_ptr<ResourceTable> table_b = test::ResourceTableBuilder()
56 .SetPackageId("com.app.b", 0x7f)
57 .AddSimple("com.app.b:id/foo")
58 .Build();
Adam Lesinski1ab598f2015-08-14 14:26:04 -070059
Adam Lesinskice5e56e2016-10-21 17:56:45 -070060 ResourceTable final_table;
61 TableMerger merger(context_.get(), &final_table, TableMergerOptions{});
Adam Lesinskicacb28f2016-10-19 12:18:14 -070062 io::FileCollection collection;
Adam Lesinski1ab598f2015-08-14 14:26:04 -070063
Adam Lesinskice5e56e2016-10-21 17:56:45 -070064 ASSERT_TRUE(merger.Merge({}, table_a.get()));
Adam Lesinskicacb28f2016-10-19 12:18:14 -070065 ASSERT_TRUE(
Adam Lesinskice5e56e2016-10-21 17:56:45 -070066 merger.MergeAndMangle({}, "com.app.b", table_b.get(), &collection));
Adam Lesinski1ab598f2015-08-14 14:26:04 -070067
Adam Lesinskice5e56e2016-10-21 17:56:45 -070068 EXPECT_TRUE(merger.merged_packages().count("com.app.b") != 0);
Adam Lesinski1ab598f2015-08-14 14:26:04 -070069
Adam Lesinskicacb28f2016-10-19 12:18:14 -070070 // Entries from com.app.a should not be mangled.
71 AAPT_EXPECT_TRUE(
Adam Lesinskice5e56e2016-10-21 17:56:45 -070072 final_table.FindResource(test::ParseNameOrDie("com.app.a:id/foo")));
Adam Lesinskicacb28f2016-10-19 12:18:14 -070073 AAPT_EXPECT_TRUE(
Adam Lesinskice5e56e2016-10-21 17:56:45 -070074 final_table.FindResource(test::ParseNameOrDie("com.app.a:id/bar")));
75 AAPT_EXPECT_TRUE(final_table.FindResource(
76 test::ParseNameOrDie("com.app.a:styleable/view")));
Adam Lesinski1ab598f2015-08-14 14:26:04 -070077
Adam Lesinskicacb28f2016-10-19 12:18:14 -070078 // The unmangled name should not be present.
79 AAPT_EXPECT_FALSE(
Adam Lesinskice5e56e2016-10-21 17:56:45 -070080 final_table.FindResource(test::ParseNameOrDie("com.app.b:id/foo")));
Adam Lesinski1ab598f2015-08-14 14:26:04 -070081
Adam Lesinskicacb28f2016-10-19 12:18:14 -070082 // Look for the mangled name.
Adam Lesinskice5e56e2016-10-21 17:56:45 -070083 AAPT_EXPECT_TRUE(final_table.FindResource(
84 test::ParseNameOrDie("com.app.a:id/com.app.b$foo")));
Adam Lesinski1ab598f2015-08-14 14:26:04 -070085}
86
Adam Lesinskia6fe3452015-12-09 15:20:52 -080087TEST_F(TableMergerTest, MergeFile) {
Adam Lesinskice5e56e2016-10-21 17:56:45 -070088 ResourceTable final_table;
Adam Lesinskicacb28f2016-10-19 12:18:14 -070089 TableMergerOptions options;
Adam Lesinskice5e56e2016-10-21 17:56:45 -070090 options.auto_add_overlay = false;
91 TableMerger merger(context_.get(), &final_table, options);
Adam Lesinskia6fe3452015-12-09 15:20:52 -080092
Adam Lesinskice5e56e2016-10-21 17:56:45 -070093 ResourceFile file_desc;
94 file_desc.config = test::ParseConfigOrDie("hdpi-v4");
95 file_desc.name = test::ParseNameOrDie("layout/main");
96 file_desc.source = Source("res/layout-hdpi/main.xml");
97 test::TestFile test_file("path/to/res/layout-hdpi/main.xml.flat");
Adam Lesinskia6fe3452015-12-09 15:20:52 -080098
Adam Lesinskice5e56e2016-10-21 17:56:45 -070099 ASSERT_TRUE(merger.MergeFile(file_desc, &test_file));
Adam Lesinskia6fe3452015-12-09 15:20:52 -0800100
Adam Lesinskice5e56e2016-10-21 17:56:45 -0700101 FileReference* file = test::GetValueForConfig<FileReference>(
102 &final_table, "com.app.a:layout/main", test::ParseConfigOrDie("hdpi-v4"));
Adam Lesinskicacb28f2016-10-19 12:18:14 -0700103 ASSERT_NE(nullptr, file);
104 EXPECT_EQ(std::string("res/layout-hdpi-v4/main.xml"), *file->path);
Adam Lesinskia6fe3452015-12-09 15:20:52 -0800105}
106
107TEST_F(TableMergerTest, MergeFileOverlay) {
Adam Lesinskice5e56e2016-10-21 17:56:45 -0700108 ResourceTable final_table;
109 TableMergerOptions options;
110 options.auto_add_overlay = false;
111 TableMerger merger(context_.get(), &final_table, options);
Adam Lesinskia6fe3452015-12-09 15:20:52 -0800112
Adam Lesinskice5e56e2016-10-21 17:56:45 -0700113 ResourceFile file_desc;
114 file_desc.name = test::ParseNameOrDie("xml/foo");
115 test::TestFile file_a("path/to/fileA.xml.flat");
116 test::TestFile file_b("path/to/fileB.xml.flat");
Adam Lesinskia6fe3452015-12-09 15:20:52 -0800117
Adam Lesinskice5e56e2016-10-21 17:56:45 -0700118 ASSERT_TRUE(merger.MergeFile(file_desc, &file_a));
119 ASSERT_TRUE(merger.MergeFileOverlay(file_desc, &file_b));
Adam Lesinskia6fe3452015-12-09 15:20:52 -0800120}
121
Adam Lesinski1ab598f2015-08-14 14:26:04 -0700122TEST_F(TableMergerTest, MergeFileReferences) {
Adam Lesinskice5e56e2016-10-21 17:56:45 -0700123 std::unique_ptr<ResourceTable> table_a =
Adam Lesinskicacb28f2016-10-19 12:18:14 -0700124 test::ResourceTableBuilder()
Adam Lesinskice5e56e2016-10-21 17:56:45 -0700125 .SetPackageId("com.app.a", 0x7f)
126 .AddFileReference("com.app.a:xml/file", "res/xml/file.xml")
127 .Build();
128 std::unique_ptr<ResourceTable> table_b =
Adam Lesinskicacb28f2016-10-19 12:18:14 -0700129 test::ResourceTableBuilder()
Adam Lesinskice5e56e2016-10-21 17:56:45 -0700130 .SetPackageId("com.app.b", 0x7f)
131 .AddFileReference("com.app.b:xml/file", "res/xml/file.xml")
132 .Build();
Adam Lesinski1ab598f2015-08-14 14:26:04 -0700133
Adam Lesinskice5e56e2016-10-21 17:56:45 -0700134 ResourceTable final_table;
135 TableMerger merger(context_.get(), &final_table, TableMergerOptions{});
Adam Lesinskicacb28f2016-10-19 12:18:14 -0700136 io::FileCollection collection;
Adam Lesinskice5e56e2016-10-21 17:56:45 -0700137 collection.InsertFile("res/xml/file.xml");
Adam Lesinski1ab598f2015-08-14 14:26:04 -0700138
Adam Lesinskice5e56e2016-10-21 17:56:45 -0700139 ASSERT_TRUE(merger.Merge({}, table_a.get()));
Adam Lesinskicacb28f2016-10-19 12:18:14 -0700140 ASSERT_TRUE(
Adam Lesinskice5e56e2016-10-21 17:56:45 -0700141 merger.MergeAndMangle({}, "com.app.b", table_b.get(), &collection));
Adam Lesinski1ab598f2015-08-14 14:26:04 -0700142
Adam Lesinskicacb28f2016-10-19 12:18:14 -0700143 FileReference* f =
Adam Lesinskice5e56e2016-10-21 17:56:45 -0700144 test::GetValue<FileReference>(&final_table, "com.app.a:xml/file");
Adam Lesinskicacb28f2016-10-19 12:18:14 -0700145 ASSERT_NE(f, nullptr);
146 EXPECT_EQ(std::string("res/xml/file.xml"), *f->path);
Adam Lesinski1ab598f2015-08-14 14:26:04 -0700147
Adam Lesinskice5e56e2016-10-21 17:56:45 -0700148 f = test::GetValue<FileReference>(&final_table,
Adam Lesinskicacb28f2016-10-19 12:18:14 -0700149 "com.app.a:xml/com.app.b$file");
150 ASSERT_NE(f, nullptr);
151 EXPECT_EQ(std::string("res/xml/com.app.b$file.xml"), *f->path);
Adam Lesinskia6fe3452015-12-09 15:20:52 -0800152}
153
154TEST_F(TableMergerTest, OverrideResourceWithOverlay) {
Adam Lesinskicacb28f2016-10-19 12:18:14 -0700155 std::unique_ptr<ResourceTable> base =
156 test::ResourceTableBuilder()
Adam Lesinskice5e56e2016-10-21 17:56:45 -0700157 .SetPackageId("", 0x00)
158 .AddValue("bool/foo", ResourceUtils::TryParseBool("true"))
159 .Build();
Adam Lesinskicacb28f2016-10-19 12:18:14 -0700160 std::unique_ptr<ResourceTable> overlay =
161 test::ResourceTableBuilder()
Adam Lesinskice5e56e2016-10-21 17:56:45 -0700162 .SetPackageId("", 0x00)
163 .AddValue("bool/foo", ResourceUtils::TryParseBool("false"))
164 .Build();
Adam Lesinskia6fe3452015-12-09 15:20:52 -0800165
Adam Lesinskice5e56e2016-10-21 17:56:45 -0700166 ResourceTable final_table;
167 TableMergerOptions options;
168 options.auto_add_overlay = false;
169 TableMerger merger(context_.get(), &final_table, options);
Adam Lesinskia6fe3452015-12-09 15:20:52 -0800170
Adam Lesinskice5e56e2016-10-21 17:56:45 -0700171 ASSERT_TRUE(merger.Merge({}, base.get()));
172 ASSERT_TRUE(merger.MergeOverlay({}, overlay.get()));
Adam Lesinskia6fe3452015-12-09 15:20:52 -0800173
Adam Lesinskicacb28f2016-10-19 12:18:14 -0700174 BinaryPrimitive* foo =
Adam Lesinskice5e56e2016-10-21 17:56:45 -0700175 test::GetValue<BinaryPrimitive>(&final_table, "com.app.a:bool/foo");
Adam Lesinskicacb28f2016-10-19 12:18:14 -0700176 ASSERT_NE(nullptr, foo);
177 EXPECT_EQ(0x0u, foo->value.data);
Adam Lesinskia6fe3452015-12-09 15:20:52 -0800178}
179
Alexandria Cornwall6a1f8db2016-08-11 13:49:44 -0700180TEST_F(TableMergerTest, OverrideSameResourceIdsWithOverlay) {
Adam Lesinskicacb28f2016-10-19 12:18:14 -0700181 std::unique_ptr<ResourceTable> base =
182 test::ResourceTableBuilder()
Adam Lesinskice5e56e2016-10-21 17:56:45 -0700183 .SetPackageId("", 0x7f)
184 .SetSymbolState("bool/foo", ResourceId(0x7f, 0x01, 0x0001),
Adam Lesinskicacb28f2016-10-19 12:18:14 -0700185 SymbolState::kPublic)
Adam Lesinskice5e56e2016-10-21 17:56:45 -0700186 .Build();
Adam Lesinskicacb28f2016-10-19 12:18:14 -0700187 std::unique_ptr<ResourceTable> overlay =
188 test::ResourceTableBuilder()
Adam Lesinskice5e56e2016-10-21 17:56:45 -0700189 .SetPackageId("", 0x7f)
190 .SetSymbolState("bool/foo", ResourceId(0x7f, 0x01, 0x0001),
Adam Lesinskicacb28f2016-10-19 12:18:14 -0700191 SymbolState::kPublic)
Adam Lesinskice5e56e2016-10-21 17:56:45 -0700192 .Build();
Alexandria Cornwall6a1f8db2016-08-11 13:49:44 -0700193
Adam Lesinskice5e56e2016-10-21 17:56:45 -0700194 ResourceTable final_table;
195 TableMergerOptions options;
196 options.auto_add_overlay = false;
197 TableMerger merger(context_.get(), &final_table, options);
Alexandria Cornwall6a1f8db2016-08-11 13:49:44 -0700198
Adam Lesinskice5e56e2016-10-21 17:56:45 -0700199 ASSERT_TRUE(merger.Merge({}, base.get()));
200 ASSERT_TRUE(merger.MergeOverlay({}, overlay.get()));
Alexandria Cornwall6a1f8db2016-08-11 13:49:44 -0700201}
202
203TEST_F(TableMergerTest, FailToOverrideConflictingTypeIdsWithOverlay) {
Adam Lesinskicacb28f2016-10-19 12:18:14 -0700204 std::unique_ptr<ResourceTable> base =
205 test::ResourceTableBuilder()
Adam Lesinskice5e56e2016-10-21 17:56:45 -0700206 .SetPackageId("", 0x7f)
207 .SetSymbolState("bool/foo", ResourceId(0x7f, 0x01, 0x0001),
Adam Lesinskicacb28f2016-10-19 12:18:14 -0700208 SymbolState::kPublic)
Adam Lesinskice5e56e2016-10-21 17:56:45 -0700209 .Build();
Adam Lesinskicacb28f2016-10-19 12:18:14 -0700210 std::unique_ptr<ResourceTable> overlay =
211 test::ResourceTableBuilder()
Adam Lesinskice5e56e2016-10-21 17:56:45 -0700212 .SetPackageId("", 0x7f)
213 .SetSymbolState("bool/foo", ResourceId(0x7f, 0x02, 0x0001),
Adam Lesinskicacb28f2016-10-19 12:18:14 -0700214 SymbolState::kPublic)
Adam Lesinskice5e56e2016-10-21 17:56:45 -0700215 .Build();
Alexandria Cornwall6a1f8db2016-08-11 13:49:44 -0700216
Adam Lesinskice5e56e2016-10-21 17:56:45 -0700217 ResourceTable final_table;
218 TableMergerOptions options;
219 options.auto_add_overlay = false;
220 TableMerger merger(context_.get(), &final_table, options);
Alexandria Cornwall6a1f8db2016-08-11 13:49:44 -0700221
Adam Lesinskice5e56e2016-10-21 17:56:45 -0700222 ASSERT_TRUE(merger.Merge({}, base.get()));
223 ASSERT_FALSE(merger.MergeOverlay({}, overlay.get()));
Alexandria Cornwall6a1f8db2016-08-11 13:49:44 -0700224}
225
226TEST_F(TableMergerTest, FailToOverrideConflictingEntryIdsWithOverlay) {
Adam Lesinskicacb28f2016-10-19 12:18:14 -0700227 std::unique_ptr<ResourceTable> base =
228 test::ResourceTableBuilder()
Adam Lesinskice5e56e2016-10-21 17:56:45 -0700229 .SetPackageId("", 0x7f)
230 .SetSymbolState("bool/foo", ResourceId(0x7f, 0x01, 0x0001),
Adam Lesinskicacb28f2016-10-19 12:18:14 -0700231 SymbolState::kPublic)
Adam Lesinskice5e56e2016-10-21 17:56:45 -0700232 .Build();
Adam Lesinskicacb28f2016-10-19 12:18:14 -0700233 std::unique_ptr<ResourceTable> overlay =
234 test::ResourceTableBuilder()
Adam Lesinskice5e56e2016-10-21 17:56:45 -0700235 .SetPackageId("", 0x7f)
236 .SetSymbolState("bool/foo", ResourceId(0x7f, 0x01, 0x0002),
Adam Lesinskicacb28f2016-10-19 12:18:14 -0700237 SymbolState::kPublic)
Adam Lesinskice5e56e2016-10-21 17:56:45 -0700238 .Build();
Alexandria Cornwall6a1f8db2016-08-11 13:49:44 -0700239
Adam Lesinskice5e56e2016-10-21 17:56:45 -0700240 ResourceTable final_table;
241 TableMergerOptions options;
242 options.auto_add_overlay = false;
243 TableMerger merger(context_.get(), &final_table, options);
Alexandria Cornwall6a1f8db2016-08-11 13:49:44 -0700244
Adam Lesinskice5e56e2016-10-21 17:56:45 -0700245 ASSERT_TRUE(merger.Merge({}, base.get()));
246 ASSERT_FALSE(merger.MergeOverlay({}, overlay.get()));
Alexandria Cornwall6a1f8db2016-08-11 13:49:44 -0700247}
248
Adam Lesinskia6fe3452015-12-09 15:20:52 -0800249TEST_F(TableMergerTest, MergeAddResourceFromOverlay) {
Adam Lesinskice5e56e2016-10-21 17:56:45 -0700250 std::unique_ptr<ResourceTable> table_a =
Adam Lesinskicacb28f2016-10-19 12:18:14 -0700251 test::ResourceTableBuilder()
Adam Lesinskice5e56e2016-10-21 17:56:45 -0700252 .SetPackageId("", 0x7f)
253 .SetSymbolState("bool/foo", {}, SymbolState::kUndefined)
254 .Build();
255 std::unique_ptr<ResourceTable> table_b =
Adam Lesinskicacb28f2016-10-19 12:18:14 -0700256 test::ResourceTableBuilder()
Adam Lesinskice5e56e2016-10-21 17:56:45 -0700257 .SetPackageId("", 0x7f)
258 .AddValue("bool/foo", ResourceUtils::TryParseBool("true"))
259 .Build();
Adam Lesinskia6fe3452015-12-09 15:20:52 -0800260
Adam Lesinskice5e56e2016-10-21 17:56:45 -0700261 ResourceTable final_table;
262 TableMerger merger(context_.get(), &final_table, TableMergerOptions{});
Adam Lesinskia6fe3452015-12-09 15:20:52 -0800263
Adam Lesinskice5e56e2016-10-21 17:56:45 -0700264 ASSERT_TRUE(merger.Merge({}, table_a.get()));
265 ASSERT_TRUE(merger.MergeOverlay({}, table_b.get()));
Adam Lesinskia6fe3452015-12-09 15:20:52 -0800266}
267
268TEST_F(TableMergerTest, MergeAddResourceFromOverlayWithAutoAddOverlay) {
Adam Lesinskice5e56e2016-10-21 17:56:45 -0700269 std::unique_ptr<ResourceTable> table_a =
270 test::ResourceTableBuilder().SetPackageId("", 0x7f).Build();
271 std::unique_ptr<ResourceTable> table_b =
Adam Lesinskicacb28f2016-10-19 12:18:14 -0700272 test::ResourceTableBuilder()
Adam Lesinskice5e56e2016-10-21 17:56:45 -0700273 .SetPackageId("", 0x7f)
274 .AddValue("bool/foo", ResourceUtils::TryParseBool("true"))
275 .Build();
Adam Lesinskia6fe3452015-12-09 15:20:52 -0800276
Adam Lesinskice5e56e2016-10-21 17:56:45 -0700277 ResourceTable final_table;
Adam Lesinskicacb28f2016-10-19 12:18:14 -0700278 TableMergerOptions options;
Adam Lesinskice5e56e2016-10-21 17:56:45 -0700279 options.auto_add_overlay = true;
280 TableMerger merger(context_.get(), &final_table, options);
Adam Lesinskia6fe3452015-12-09 15:20:52 -0800281
Adam Lesinskice5e56e2016-10-21 17:56:45 -0700282 ASSERT_TRUE(merger.Merge({}, table_a.get()));
283 ASSERT_TRUE(merger.MergeOverlay({}, table_b.get()));
Adam Lesinskia6fe3452015-12-09 15:20:52 -0800284}
285
286TEST_F(TableMergerTest, FailToMergeNewResourceWithoutAutoAddOverlay) {
Adam Lesinskice5e56e2016-10-21 17:56:45 -0700287 std::unique_ptr<ResourceTable> table_a =
288 test::ResourceTableBuilder().SetPackageId("", 0x7f).Build();
289 std::unique_ptr<ResourceTable> table_b =
Adam Lesinskicacb28f2016-10-19 12:18:14 -0700290 test::ResourceTableBuilder()
Adam Lesinskice5e56e2016-10-21 17:56:45 -0700291 .SetPackageId("", 0x7f)
292 .AddValue("bool/foo", ResourceUtils::TryParseBool("true"))
293 .Build();
Adam Lesinskia6fe3452015-12-09 15:20:52 -0800294
Adam Lesinskice5e56e2016-10-21 17:56:45 -0700295 ResourceTable final_table;
Adam Lesinskicacb28f2016-10-19 12:18:14 -0700296 TableMergerOptions options;
Adam Lesinskice5e56e2016-10-21 17:56:45 -0700297 options.auto_add_overlay = false;
298 TableMerger merger(context_.get(), &final_table, options);
Adam Lesinskia6fe3452015-12-09 15:20:52 -0800299
Adam Lesinskice5e56e2016-10-21 17:56:45 -0700300 ASSERT_TRUE(merger.Merge({}, table_a.get()));
301 ASSERT_FALSE(merger.MergeOverlay({}, table_b.get()));
Adam Lesinski1ab598f2015-08-14 14:26:04 -0700302}
303
Adam Lesinski5c3464c2016-08-24 16:03:48 -0700304TEST_F(TableMergerTest, OverlaidStyleablesShouldBeMerged) {
Adam Lesinskice5e56e2016-10-21 17:56:45 -0700305 std::unique_ptr<ResourceTable> table_a =
Adam Lesinskicacb28f2016-10-19 12:18:14 -0700306 test::ResourceTableBuilder()
Adam Lesinskice5e56e2016-10-21 17:56:45 -0700307 .SetPackageId("com.app.a", 0x7f)
308 .AddValue("com.app.a:styleable/Foo",
Adam Lesinskicacb28f2016-10-19 12:18:14 -0700309 test::StyleableBuilder()
Adam Lesinskice5e56e2016-10-21 17:56:45 -0700310 .AddItem("com.app.a:attr/bar")
311 .AddItem("com.app.a:attr/foo", ResourceId(0x01010000))
312 .Build())
313 .Build();
Adam Lesinski5c3464c2016-08-24 16:03:48 -0700314
Adam Lesinskice5e56e2016-10-21 17:56:45 -0700315 std::unique_ptr<ResourceTable> table_b =
Adam Lesinskicacb28f2016-10-19 12:18:14 -0700316 test::ResourceTableBuilder()
Adam Lesinskice5e56e2016-10-21 17:56:45 -0700317 .SetPackageId("com.app.a", 0x7f)
318 .AddValue("com.app.a:styleable/Foo",
Adam Lesinskicacb28f2016-10-19 12:18:14 -0700319 test::StyleableBuilder()
Adam Lesinskice5e56e2016-10-21 17:56:45 -0700320 .AddItem("com.app.a:attr/bat")
321 .AddItem("com.app.a:attr/foo")
322 .Build())
323 .Build();
Adam Lesinski5c3464c2016-08-24 16:03:48 -0700324
Adam Lesinskice5e56e2016-10-21 17:56:45 -0700325 ResourceTable final_table;
Adam Lesinskicacb28f2016-10-19 12:18:14 -0700326 TableMergerOptions options;
Adam Lesinskice5e56e2016-10-21 17:56:45 -0700327 options.auto_add_overlay = true;
328 TableMerger merger(context_.get(), &final_table, options);
Adam Lesinski5c3464c2016-08-24 16:03:48 -0700329
Adam Lesinskice5e56e2016-10-21 17:56:45 -0700330 ASSERT_TRUE(merger.Merge({}, table_a.get()));
331 ASSERT_TRUE(merger.MergeOverlay({}, table_b.get()));
Adam Lesinski5c3464c2016-08-24 16:03:48 -0700332
Adam Lesinskicacb28f2016-10-19 12:18:14 -0700333 Styleable* styleable =
Adam Lesinskice5e56e2016-10-21 17:56:45 -0700334 test::GetValue<Styleable>(&final_table, "com.app.a:styleable/Foo");
Adam Lesinskicacb28f2016-10-19 12:18:14 -0700335 ASSERT_NE(nullptr, styleable);
Adam Lesinski5c3464c2016-08-24 16:03:48 -0700336
Adam Lesinskice5e56e2016-10-21 17:56:45 -0700337 std::vector<Reference> expected_refs = {
338 Reference(test::ParseNameOrDie("com.app.a:attr/bar")),
339 Reference(test::ParseNameOrDie("com.app.a:attr/bat")),
340 Reference(test::ParseNameOrDie("com.app.a:attr/foo"),
Adam Lesinskicacb28f2016-10-19 12:18:14 -0700341 ResourceId(0x01010000)),
342 };
Adam Lesinski5c3464c2016-08-24 16:03:48 -0700343
Adam Lesinskice5e56e2016-10-21 17:56:45 -0700344 EXPECT_EQ(expected_refs, styleable->entries);
Adam Lesinski5c3464c2016-08-24 16:03:48 -0700345}
346
Adam Lesinskicacb28f2016-10-19 12:18:14 -0700347} // namespace aapt