Merge "Generate test lists for Ravenwood and Robolectric tests" into main
This commit is contained in:
commit
3835928537
3 changed files with 192 additions and 15 deletions
|
@ -138,6 +138,7 @@ bootstrap_go_package {
|
||||||
"selects_test.go",
|
"selects_test.go",
|
||||||
"singleton_module_test.go",
|
"singleton_module_test.go",
|
||||||
"soong_config_modules_test.go",
|
"soong_config_modules_test.go",
|
||||||
|
"test_suites_test.go",
|
||||||
"util_test.go",
|
"util_test.go",
|
||||||
"variable_test.go",
|
"variable_test.go",
|
||||||
"visibility_test.go",
|
"visibility_test.go",
|
||||||
|
|
|
@ -14,6 +14,11 @@
|
||||||
|
|
||||||
package android
|
package android
|
||||||
|
|
||||||
|
import (
|
||||||
|
"path/filepath"
|
||||||
|
"strings"
|
||||||
|
)
|
||||||
|
|
||||||
func init() {
|
func init() {
|
||||||
RegisterParallelSingletonType("testsuites", testSuiteFilesFactory)
|
RegisterParallelSingletonType("testsuites", testSuiteFilesFactory)
|
||||||
}
|
}
|
||||||
|
@ -23,8 +28,8 @@ func testSuiteFilesFactory() Singleton {
|
||||||
}
|
}
|
||||||
|
|
||||||
type testSuiteFiles struct {
|
type testSuiteFiles struct {
|
||||||
robolectric WritablePath
|
robolectric []Path
|
||||||
ravenwood WritablePath
|
ravenwood []Path
|
||||||
}
|
}
|
||||||
|
|
||||||
type TestSuiteModule interface {
|
type TestSuiteModule interface {
|
||||||
|
@ -48,53 +53,107 @@ func (t *testSuiteFiles) GenerateBuildActions(ctx SingletonContext) {
|
||||||
})
|
})
|
||||||
|
|
||||||
t.robolectric = robolectricTestSuite(ctx, files["robolectric-tests"])
|
t.robolectric = robolectricTestSuite(ctx, files["robolectric-tests"])
|
||||||
ctx.Phony("robolectric-tests", t.robolectric)
|
ctx.Phony("robolectric-tests", t.robolectric...)
|
||||||
|
|
||||||
t.ravenwood = ravenwoodTestSuite(ctx, files["ravenwood-tests"])
|
t.ravenwood = ravenwoodTestSuite(ctx, files["ravenwood-tests"])
|
||||||
ctx.Phony("ravenwood-tests", t.ravenwood)
|
ctx.Phony("ravenwood-tests", t.ravenwood...)
|
||||||
}
|
}
|
||||||
|
|
||||||
func (t *testSuiteFiles) MakeVars(ctx MakeVarsContext) {
|
func (t *testSuiteFiles) MakeVars(ctx MakeVarsContext) {
|
||||||
ctx.DistForGoal("robolectric-tests", t.robolectric)
|
ctx.DistForGoal("robolectric-tests", t.robolectric...)
|
||||||
ctx.DistForGoal("ravenwood-tests", t.ravenwood)
|
ctx.DistForGoal("ravenwood-tests", t.ravenwood...)
|
||||||
}
|
}
|
||||||
|
|
||||||
func robolectricTestSuite(ctx SingletonContext, files map[string]InstallPaths) WritablePath {
|
func robolectricTestSuite(ctx SingletonContext, files map[string]InstallPaths) []Path {
|
||||||
var installedPaths InstallPaths
|
var installedPaths InstallPaths
|
||||||
for _, module := range SortedKeys(files) {
|
for _, module := range SortedKeys(files) {
|
||||||
installedPaths = append(installedPaths, files[module]...)
|
installedPaths = append(installedPaths, files[module]...)
|
||||||
}
|
}
|
||||||
testCasesDir := pathForInstall(ctx, ctx.Config().BuildOS, X86, "testcases")
|
|
||||||
|
|
||||||
outputFile := PathForOutput(ctx, "packaging", "robolectric-tests.zip")
|
outputFile := pathForPackaging(ctx, "robolectric-tests.zip")
|
||||||
rule := NewRuleBuilder(pctx, ctx)
|
rule := NewRuleBuilder(pctx, ctx)
|
||||||
rule.Command().BuiltTool("soong_zip").
|
rule.Command().BuiltTool("soong_zip").
|
||||||
FlagWithOutput("-o ", outputFile).
|
FlagWithOutput("-o ", outputFile).
|
||||||
FlagWithArg("-P ", "host/testcases").
|
FlagWithArg("-P ", "host/testcases").
|
||||||
FlagWithArg("-C ", testCasesDir.String()).
|
FlagWithArg("-C ", pathForTestCases(ctx).String()).
|
||||||
FlagWithRspFileInputList("-r ", outputFile.ReplaceExtension(ctx, "rsp"), installedPaths.Paths()).
|
FlagWithRspFileInputList("-r ", outputFile.ReplaceExtension(ctx, "rsp"), installedPaths.Paths()).
|
||||||
|
Flag("-sha256") // necessary to save cas_uploader's time
|
||||||
|
|
||||||
|
testList := buildTestList(ctx, "robolectric-tests_list", installedPaths)
|
||||||
|
testListZipOutputFile := pathForPackaging(ctx, "robolectric-tests_list.zip")
|
||||||
|
|
||||||
|
rule.Command().BuiltTool("soong_zip").
|
||||||
|
FlagWithOutput("-o ", testListZipOutputFile).
|
||||||
|
FlagWithArg("-C ", pathForPackaging(ctx).String()).
|
||||||
|
FlagWithInput("-f ", testList).
|
||||||
Flag("-sha256")
|
Flag("-sha256")
|
||||||
|
|
||||||
rule.Build("robolectric_tests_zip", "robolectric-tests.zip")
|
rule.Build("robolectric_tests_zip", "robolectric-tests.zip")
|
||||||
|
|
||||||
return outputFile
|
return []Path{outputFile, testListZipOutputFile}
|
||||||
}
|
}
|
||||||
|
|
||||||
func ravenwoodTestSuite(ctx SingletonContext, files map[string]InstallPaths) WritablePath {
|
func ravenwoodTestSuite(ctx SingletonContext, files map[string]InstallPaths) []Path {
|
||||||
var installedPaths InstallPaths
|
var installedPaths InstallPaths
|
||||||
for _, module := range SortedKeys(files) {
|
for _, module := range SortedKeys(files) {
|
||||||
installedPaths = append(installedPaths, files[module]...)
|
installedPaths = append(installedPaths, files[module]...)
|
||||||
}
|
}
|
||||||
testCasesDir := pathForInstall(ctx, ctx.Config().BuildOS, X86, "testcases")
|
|
||||||
|
|
||||||
outputFile := PathForOutput(ctx, "packaging", "ravenwood-tests.zip")
|
outputFile := pathForPackaging(ctx, "ravenwood-tests.zip")
|
||||||
rule := NewRuleBuilder(pctx, ctx)
|
rule := NewRuleBuilder(pctx, ctx)
|
||||||
rule.Command().BuiltTool("soong_zip").
|
rule.Command().BuiltTool("soong_zip").
|
||||||
FlagWithOutput("-o ", outputFile).
|
FlagWithOutput("-o ", outputFile).
|
||||||
FlagWithArg("-P ", "host/testcases").
|
FlagWithArg("-P ", "host/testcases").
|
||||||
FlagWithArg("-C ", testCasesDir.String()).
|
FlagWithArg("-C ", pathForTestCases(ctx).String()).
|
||||||
FlagWithRspFileInputList("-r ", outputFile.ReplaceExtension(ctx, "rsp"), installedPaths.Paths()).
|
FlagWithRspFileInputList("-r ", outputFile.ReplaceExtension(ctx, "rsp"), installedPaths.Paths()).
|
||||||
|
Flag("-sha256") // necessary to save cas_uploader's time
|
||||||
|
|
||||||
|
testList := buildTestList(ctx, "ravenwood-tests_list", installedPaths)
|
||||||
|
testListZipOutputFile := pathForPackaging(ctx, "ravenwood-tests_list.zip")
|
||||||
|
|
||||||
|
rule.Command().BuiltTool("soong_zip").
|
||||||
|
FlagWithOutput("-o ", testListZipOutputFile).
|
||||||
|
FlagWithArg("-C ", pathForPackaging(ctx).String()).
|
||||||
|
FlagWithInput("-f ", testList).
|
||||||
Flag("-sha256")
|
Flag("-sha256")
|
||||||
|
|
||||||
rule.Build("ravenwood_tests_zip", "ravenwood-tests.zip")
|
rule.Build("ravenwood_tests_zip", "ravenwood-tests.zip")
|
||||||
|
|
||||||
|
return []Path{outputFile, testListZipOutputFile}
|
||||||
|
}
|
||||||
|
|
||||||
|
func buildTestList(ctx SingletonContext, listFile string, installedPaths InstallPaths) Path {
|
||||||
|
buf := &strings.Builder{}
|
||||||
|
for _, p := range installedPaths {
|
||||||
|
if p.Ext() != ".config" {
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
pc, err := toTestListPath(p.String(), pathForTestCases(ctx).String(), "host/testcases")
|
||||||
|
if err != nil {
|
||||||
|
ctx.Errorf("Failed to convert path: %s, %v", p.String(), err)
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
buf.WriteString(pc)
|
||||||
|
buf.WriteString("\n")
|
||||||
|
}
|
||||||
|
outputFile := pathForPackaging(ctx, listFile)
|
||||||
|
WriteFileRuleVerbatim(ctx, outputFile, buf.String())
|
||||||
return outputFile
|
return outputFile
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func toTestListPath(path, relativeRoot, prefix string) (string, error) {
|
||||||
|
dest, err := filepath.Rel(relativeRoot, path)
|
||||||
|
if err != nil {
|
||||||
|
return "", err
|
||||||
|
}
|
||||||
|
return filepath.Join(prefix, dest), nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func pathForPackaging(ctx PathContext, pathComponents ...string) OutputPath {
|
||||||
|
pathComponents = append([]string{"packaging"}, pathComponents...)
|
||||||
|
return PathForOutput(ctx, pathComponents...)
|
||||||
|
}
|
||||||
|
|
||||||
|
func pathForTestCases(ctx PathContext) InstallPath {
|
||||||
|
return pathForInstall(ctx, ctx.Config().BuildOS, X86, "testcases")
|
||||||
|
}
|
||||||
|
|
117
android/test_suites_test.go
Normal file
117
android/test_suites_test.go
Normal file
|
@ -0,0 +1,117 @@
|
||||||
|
// Copyright 2024 Google Inc. All rights reserved.
|
||||||
|
//
|
||||||
|
// 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.
|
||||||
|
|
||||||
|
package android
|
||||||
|
|
||||||
|
import (
|
||||||
|
"path/filepath"
|
||||||
|
"testing"
|
||||||
|
)
|
||||||
|
|
||||||
|
func TestBuildTestList(t *testing.T) {
|
||||||
|
t.Parallel()
|
||||||
|
ctx := GroupFixturePreparers(
|
||||||
|
prepareForFakeTestSuite,
|
||||||
|
FixtureRegisterWithContext(func(ctx RegistrationContext) {
|
||||||
|
ctx.RegisterParallelSingletonType("testsuites", testSuiteFilesFactory)
|
||||||
|
}),
|
||||||
|
).RunTestWithBp(t, `
|
||||||
|
fake_module {
|
||||||
|
name: "module1",
|
||||||
|
outputs: [
|
||||||
|
"Test1/Test1.config",
|
||||||
|
"Test1/Test1.apk",
|
||||||
|
],
|
||||||
|
test_suites: ["ravenwood-tests"],
|
||||||
|
}
|
||||||
|
fake_module {
|
||||||
|
name: "module2",
|
||||||
|
outputs: [
|
||||||
|
"Test2/Test21/Test21.config",
|
||||||
|
"Test2/Test21/Test21.apk",
|
||||||
|
],
|
||||||
|
test_suites: ["ravenwood-tests", "robolectric-tests"],
|
||||||
|
}
|
||||||
|
fake_module {
|
||||||
|
name: "module_without_config",
|
||||||
|
outputs: [
|
||||||
|
"BadTest/BadTest.jar",
|
||||||
|
],
|
||||||
|
test_suites: ["robolectric-tests"],
|
||||||
|
}
|
||||||
|
`)
|
||||||
|
|
||||||
|
config := ctx.SingletonForTests("testsuites")
|
||||||
|
allOutputs := config.AllOutputs()
|
||||||
|
|
||||||
|
wantContents := map[string]string{
|
||||||
|
"robolectric-tests.zip": "",
|
||||||
|
"robolectric-tests_list.zip": "",
|
||||||
|
"robolectric-tests_list": `host/testcases/Test2/Test21/Test21.config
|
||||||
|
`,
|
||||||
|
"ravenwood-tests.zip": "",
|
||||||
|
"ravenwood-tests_list.zip": "",
|
||||||
|
"ravenwood-tests_list": `host/testcases/Test1/Test1.config
|
||||||
|
host/testcases/Test2/Test21/Test21.config
|
||||||
|
`,
|
||||||
|
}
|
||||||
|
for _, output := range allOutputs {
|
||||||
|
want, ok := wantContents[filepath.Base(output)]
|
||||||
|
if !ok {
|
||||||
|
t.Errorf("unexpected output: %q", output)
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
|
||||||
|
got := ""
|
||||||
|
if want != "" {
|
||||||
|
got = ContentFromFileRuleForTests(t, ctx.TestContext, config.MaybeOutput(output))
|
||||||
|
}
|
||||||
|
|
||||||
|
if want != got {
|
||||||
|
t.Errorf("want %q, got %q", want, got)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
type fake_module struct {
|
||||||
|
ModuleBase
|
||||||
|
props struct {
|
||||||
|
Outputs []string
|
||||||
|
Test_suites []string
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func fakeTestSuiteFactory() Module {
|
||||||
|
module := &fake_module{}
|
||||||
|
base := module.base()
|
||||||
|
module.AddProperties(&base.nameProperties, &module.props)
|
||||||
|
InitAndroidModule(module)
|
||||||
|
return module
|
||||||
|
}
|
||||||
|
|
||||||
|
var prepareForFakeTestSuite = GroupFixturePreparers(
|
||||||
|
FixtureRegisterWithContext(func(ctx RegistrationContext) {
|
||||||
|
ctx.RegisterModuleType("fake_module", fakeTestSuiteFactory)
|
||||||
|
}),
|
||||||
|
)
|
||||||
|
|
||||||
|
func (f *fake_module) GenerateAndroidBuildActions(ctx ModuleContext) {
|
||||||
|
for _, output := range f.props.Outputs {
|
||||||
|
ctx.InstallFile(pathForTestCases(ctx), output, nil)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func (f *fake_module) TestSuites() []string {
|
||||||
|
return f.props.Test_suites
|
||||||
|
}
|
Loading…
Reference in a new issue