Fix package boundary in glob expansion with checked in BUILD files.
For directories without an Android.bp file, if they contain a merged checked in BUILD file, it becomes a package boundary in the symlink forest. However, the current glob expansion is only aware of Android.bp files, but not merged BUILD files, so it generates glob expansions incorrectly for files that cross the package boundary. This CL fixes that by making the package boundary function aware of the keepExistingBuildFile allowlist. See the new test cases for example. Also stop using the same global bp2buildConfig for every test case to allow each test to define their own bp2build allowlists. Bug: 185358476 Test: new unit tests Change-Id: Ifcd1283480a09a642ef4343e5bbc599583524577
This commit is contained in:
@@ -986,57 +986,6 @@ func TestModuleTypeBp2Build(t *testing.T) {
|
||||
}),
|
||||
},
|
||||
},
|
||||
{
|
||||
Description: "filegroup with glob",
|
||||
ModuleTypeUnderTest: "filegroup",
|
||||
ModuleTypeUnderTestFactory: android.FileGroupFactory,
|
||||
Blueprint: `filegroup {
|
||||
name: "fg_foo",
|
||||
srcs: ["**/*.txt"],
|
||||
bazel_module: { bp2build_available: true },
|
||||
}`,
|
||||
ExpectedBazelTargets: []string{
|
||||
MakeBazelTargetNoRestrictions("filegroup", "fg_foo", map[string]string{
|
||||
"srcs": `[
|
||||
"other/a.txt",
|
||||
"other/b.txt",
|
||||
"other/subdir/a.txt",
|
||||
]`,
|
||||
}),
|
||||
},
|
||||
Filesystem: map[string]string{
|
||||
"other/a.txt": "",
|
||||
"other/b.txt": "",
|
||||
"other/subdir/a.txt": "",
|
||||
"other/file": "",
|
||||
},
|
||||
},
|
||||
{
|
||||
Description: "filegroup with glob in subdir",
|
||||
ModuleTypeUnderTest: "filegroup",
|
||||
ModuleTypeUnderTestFactory: android.FileGroupFactory,
|
||||
Dir: "other",
|
||||
Filesystem: map[string]string{
|
||||
"other/Android.bp": `filegroup {
|
||||
name: "fg_foo",
|
||||
srcs: ["**/*.txt"],
|
||||
bazel_module: { bp2build_available: true },
|
||||
}`,
|
||||
"other/a.txt": "",
|
||||
"other/b.txt": "",
|
||||
"other/subdir/a.txt": "",
|
||||
"other/file": "",
|
||||
},
|
||||
ExpectedBazelTargets: []string{
|
||||
MakeBazelTargetNoRestrictions("filegroup", "fg_foo", map[string]string{
|
||||
"srcs": `[
|
||||
"a.txt",
|
||||
"b.txt",
|
||||
"subdir/a.txt",
|
||||
]`,
|
||||
}),
|
||||
},
|
||||
},
|
||||
{
|
||||
Description: "depends_on_other_dir_module",
|
||||
ModuleTypeUnderTest: "filegroup",
|
||||
@@ -1429,6 +1378,226 @@ func TestCombineBuildFilesBp2buildTargets(t *testing.T) {
|
||||
}
|
||||
}
|
||||
|
||||
func TestGlob(t *testing.T) {
|
||||
testCases := []Bp2buildTestCase{
|
||||
{
|
||||
Description: "filegroup with glob",
|
||||
ModuleTypeUnderTest: "filegroup",
|
||||
ModuleTypeUnderTestFactory: android.FileGroupFactory,
|
||||
Blueprint: `filegroup {
|
||||
name: "fg_foo",
|
||||
srcs: ["**/*.txt"],
|
||||
bazel_module: { bp2build_available: true },
|
||||
}`,
|
||||
ExpectedBazelTargets: []string{
|
||||
MakeBazelTargetNoRestrictions("filegroup", "fg_foo", map[string]string{
|
||||
"srcs": `[
|
||||
"other/a.txt",
|
||||
"other/b.txt",
|
||||
"other/subdir/a.txt",
|
||||
]`,
|
||||
}),
|
||||
},
|
||||
Filesystem: map[string]string{
|
||||
"other/a.txt": "",
|
||||
"other/b.txt": "",
|
||||
"other/subdir/a.txt": "",
|
||||
"other/file": "",
|
||||
},
|
||||
},
|
||||
{
|
||||
Description: "filegroup with glob in subdir",
|
||||
ModuleTypeUnderTest: "filegroup",
|
||||
ModuleTypeUnderTestFactory: android.FileGroupFactory,
|
||||
Dir: "other",
|
||||
Filesystem: map[string]string{
|
||||
"other/Android.bp": `filegroup {
|
||||
name: "fg_foo",
|
||||
srcs: ["**/*.txt"],
|
||||
bazel_module: { bp2build_available: true },
|
||||
}`,
|
||||
"other/a.txt": "",
|
||||
"other/b.txt": "",
|
||||
"other/subdir/a.txt": "",
|
||||
"other/file": "",
|
||||
},
|
||||
ExpectedBazelTargets: []string{
|
||||
MakeBazelTargetNoRestrictions("filegroup", "fg_foo", map[string]string{
|
||||
"srcs": `[
|
||||
"a.txt",
|
||||
"b.txt",
|
||||
"subdir/a.txt",
|
||||
]`,
|
||||
}),
|
||||
},
|
||||
},
|
||||
{
|
||||
Description: "filegroup with glob with no kept BUILD files",
|
||||
ModuleTypeUnderTest: "filegroup",
|
||||
ModuleTypeUnderTestFactory: android.FileGroupFactory,
|
||||
KeepBuildFileForDirs: []string{
|
||||
// empty
|
||||
},
|
||||
Blueprint: `filegroup {
|
||||
name: "fg_foo",
|
||||
srcs: ["**/*.txt"],
|
||||
bazel_module: { bp2build_available: true },
|
||||
}`,
|
||||
Filesystem: map[string]string{
|
||||
"a.txt": "",
|
||||
"b.txt": "",
|
||||
"foo/BUILD": "",
|
||||
"foo/a.txt": "",
|
||||
"foo/bar/BUILD": "",
|
||||
"foo/bar/b.txt": "",
|
||||
},
|
||||
ExpectedBazelTargets: []string{
|
||||
MakeBazelTargetNoRestrictions("filegroup", "fg_foo", map[string]string{
|
||||
"srcs": `[
|
||||
"a.txt",
|
||||
"b.txt",
|
||||
"foo/a.txt",
|
||||
"foo/bar/b.txt",
|
||||
]`,
|
||||
}),
|
||||
},
|
||||
},
|
||||
{
|
||||
Description: "filegroup with glob with kept BUILD file",
|
||||
ModuleTypeUnderTest: "filegroup",
|
||||
ModuleTypeUnderTestFactory: android.FileGroupFactory,
|
||||
KeepBuildFileForDirs: []string{
|
||||
"foo",
|
||||
},
|
||||
Blueprint: `filegroup {
|
||||
name: "fg_foo",
|
||||
srcs: ["**/*.txt"],
|
||||
bazel_module: { bp2build_available: true },
|
||||
}`,
|
||||
Filesystem: map[string]string{
|
||||
"a.txt": "",
|
||||
"b.txt": "",
|
||||
"foo/BUILD": "",
|
||||
"foo/a.txt": "",
|
||||
"foo/bar/BUILD": "",
|
||||
"foo/bar/b.txt": "",
|
||||
},
|
||||
ExpectedBazelTargets: []string{
|
||||
MakeBazelTargetNoRestrictions("filegroup", "fg_foo", map[string]string{
|
||||
"srcs": `[
|
||||
"a.txt",
|
||||
"b.txt",
|
||||
"//foo:a.txt",
|
||||
"//foo:bar/b.txt",
|
||||
]`,
|
||||
}),
|
||||
},
|
||||
},
|
||||
{
|
||||
Description: "filegroup with glob with kept BUILD.bazel file",
|
||||
ModuleTypeUnderTest: "filegroup",
|
||||
ModuleTypeUnderTestFactory: android.FileGroupFactory,
|
||||
KeepBuildFileForDirs: []string{
|
||||
"foo",
|
||||
},
|
||||
Blueprint: `filegroup {
|
||||
name: "fg_foo",
|
||||
srcs: ["**/*.txt"],
|
||||
bazel_module: { bp2build_available: true },
|
||||
}`,
|
||||
Filesystem: map[string]string{
|
||||
"a.txt": "",
|
||||
"b.txt": "",
|
||||
"foo/BUILD.bazel": "",
|
||||
"foo/a.txt": "",
|
||||
"foo/bar/BUILD.bazel": "",
|
||||
"foo/bar/b.txt": "",
|
||||
},
|
||||
ExpectedBazelTargets: []string{
|
||||
MakeBazelTargetNoRestrictions("filegroup", "fg_foo", map[string]string{
|
||||
"srcs": `[
|
||||
"a.txt",
|
||||
"b.txt",
|
||||
"//foo:a.txt",
|
||||
"//foo:bar/b.txt",
|
||||
]`,
|
||||
}),
|
||||
},
|
||||
},
|
||||
{
|
||||
Description: "filegroup with glob with Android.bp file as boundary",
|
||||
ModuleTypeUnderTest: "filegroup",
|
||||
ModuleTypeUnderTestFactory: android.FileGroupFactory,
|
||||
Blueprint: `filegroup {
|
||||
name: "fg_foo",
|
||||
srcs: ["**/*.txt"],
|
||||
bazel_module: { bp2build_available: true },
|
||||
}`,
|
||||
Filesystem: map[string]string{
|
||||
"a.txt": "",
|
||||
"b.txt": "",
|
||||
"foo/Android.bp": "",
|
||||
"foo/a.txt": "",
|
||||
"foo/bar/Android.bp": "",
|
||||
"foo/bar/b.txt": "",
|
||||
},
|
||||
ExpectedBazelTargets: []string{
|
||||
MakeBazelTargetNoRestrictions("filegroup", "fg_foo", map[string]string{
|
||||
"srcs": `[
|
||||
"a.txt",
|
||||
"b.txt",
|
||||
"//foo:a.txt",
|
||||
"//foo/bar:b.txt",
|
||||
]`,
|
||||
}),
|
||||
},
|
||||
},
|
||||
{
|
||||
Description: "filegroup with glob in subdir with kept BUILD and BUILD.bazel file",
|
||||
ModuleTypeUnderTest: "filegroup",
|
||||
ModuleTypeUnderTestFactory: android.FileGroupFactory,
|
||||
Dir: "other",
|
||||
KeepBuildFileForDirs: []string{
|
||||
"other/foo",
|
||||
"other/foo/bar",
|
||||
// deliberately not other/foo/baz/BUILD.
|
||||
},
|
||||
Filesystem: map[string]string{
|
||||
"other/Android.bp": `filegroup {
|
||||
name: "fg_foo",
|
||||
srcs: ["**/*.txt"],
|
||||
bazel_module: { bp2build_available: true },
|
||||
}`,
|
||||
"other/a.txt": "",
|
||||
"other/b.txt": "",
|
||||
"other/foo/BUILD": "",
|
||||
"other/foo/a.txt": "",
|
||||
"other/foo/bar/BUILD.bazel": "",
|
||||
"other/foo/bar/b.txt": "",
|
||||
"other/foo/baz/BUILD": "",
|
||||
"other/foo/baz/c.txt": "",
|
||||
},
|
||||
ExpectedBazelTargets: []string{
|
||||
MakeBazelTargetNoRestrictions("filegroup", "fg_foo", map[string]string{
|
||||
"srcs": `[
|
||||
"a.txt",
|
||||
"b.txt",
|
||||
"//other/foo:a.txt",
|
||||
"//other/foo/bar:b.txt",
|
||||
"//other/foo:baz/c.txt",
|
||||
]`,
|
||||
}),
|
||||
},
|
||||
},
|
||||
}
|
||||
|
||||
for _, testCase := range testCases {
|
||||
t.Run(testCase.Description, func(t *testing.T) {
|
||||
RunBp2BuildTestCaseSimple(t, testCase)
|
||||
})
|
||||
}
|
||||
}
|
||||
|
||||
func TestGlobExcludeSrcs(t *testing.T) {
|
||||
testCases := []Bp2buildTestCase{
|
||||
{
|
||||
|
Reference in New Issue
Block a user