Merge "modify cc_binary type to cc_test for test modules" am: ec04417506

Original change: https://android-review.googlesource.com/c/platform/build/soong/+/1758945

Change-Id: I005a4d947eeb7123ab26ff1e0acc69db083e60c4
This commit is contained in:
Yuntao Xu
2021-07-09 16:55:53 +00:00
committed by Automerger Merge Worker
2 changed files with 57 additions and 1 deletions

View File

@@ -392,7 +392,7 @@ func rewriteTestModuleTypes(f *Fixer) error {
continue
}
if !strings.HasPrefix(mod.Type, "java_") && !strings.HasPrefix(mod.Type, "android_") {
if !strings.HasPrefix(mod.Type, "java_") && !strings.HasPrefix(mod.Type, "android_") && mod.Type != "cc_binary" {
continue
}
@@ -420,6 +420,14 @@ func rewriteTestModuleTypes(f *Fixer) error {
mod.Type = "java_test_host"
}
}
// when a cc_binary module has a nonempty test_suites field, modify the type to cc_test
if mod.Type == "cc_binary" {
hasTestSuites := hasNonEmptyLiteralListProperty(mod, "test_suites")
if hasTestSuites {
mod.Type = "cc_test"
}
}
}
return nil

View File

@@ -1124,3 +1124,51 @@ func TestRewriteRuntimeResourceOverlay(t *testing.T) {
})
}
}
func TestRewriteTestModuleTypes(t *testing.T) {
tests := []struct {
name string
in string
out string
}{
{
name: "cc_binary with test_suites",
in: `
cc_binary {
name: "foo",
srcs: ["srcs"],
test_suites: ["test_suite1"],
}
`,
out: `
cc_test {
name: "foo",
srcs: ["srcs"],
test_suites: ["test_suite1"],
}
`,
},
{
name: "cc_binary without test_suites",
in: `
cc_binary {
name: "foo",
srcs: ["srcs"],
}
`,
out: `
cc_binary {
name: "foo",
srcs: ["srcs"],
}
`,
},
}
for _, test := range tests {
t.Run(test.name, func(t *testing.T) {
runPass(t, test.in, test.out, func(fixer *Fixer) error {
return rewriteTestModuleTypes(fixer)
})
})
}
}