// Copyright 2018 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 tradefed import ( "strings" "github.com/google/blueprint" "android/soong/android" ) func getTestConfig(ctx android.ModuleContext, prop *string) android.Path { if p := ctx.ExpandOptionalSource(prop, "test_config"); p.Valid() { return p.Path() } else if p := android.ExistentPathForSource(ctx, ctx.ModuleDir(), "AndroidTest.xml"); p.Valid() { return p.Path() } return nil } var autogenTestConfig = pctx.StaticRule("autogenTestConfig", blueprint.RuleParams{ Command: "sed 's&{MODULE}&${name}&g' $template > $out", CommandDeps: []string{"$template"}, }, "name", "template") func testConfigPath(ctx android.ModuleContext, prop *string) (path android.Path, autogenPath android.WritablePath) { if p := getTestConfig(ctx, prop); p != nil { return p, nil } else if !strings.HasPrefix(ctx.ModuleDir(), "cts/") { outputFile := android.PathForModuleOut(ctx, ctx.ModuleName()+".config") return outputFile, outputFile } else { // CTS modules can be used for test data, so test config files must be // explicitly created using AndroidTest.xml // TODO(b/112602712): remove the path check return nil, nil } } func autogenTemplate(ctx android.ModuleContext, output android.WritablePath, template string) { ctx.Build(pctx, android.BuildParams{ Rule: autogenTestConfig, Description: "test config", Output: output, Args: map[string]string{ "name": ctx.ModuleName(), "template": template, }, }) } func AutoGenNativeTestConfig(ctx android.ModuleContext, prop *string) android.Path { path, autogenPath := testConfigPath(ctx, prop) if autogenPath != nil { if ctx.Device() { autogenTemplate(ctx, autogenPath, "${NativeTestConfigTemplate}") } else { autogenTemplate(ctx, autogenPath, "${NativeHostTestConfigTemplate}") } } return path } func AutoGenNativeBenchmarkTestConfig(ctx android.ModuleContext, prop *string) android.Path { path, autogenPath := testConfigPath(ctx, prop) if autogenPath != nil { autogenTemplate(ctx, autogenPath, "${NativeBenchmarkTestConfigTemplate}") } return path } func AutoGenJavaTestConfig(ctx android.ModuleContext, prop *string) android.Path { path, autogenPath := testConfigPath(ctx, prop) if autogenPath != nil { if ctx.Device() { autogenTemplate(ctx, autogenPath, "${JavaTestConfigTemplate}") } else { autogenTemplate(ctx, autogenPath, "${JavaHostTestConfigTemplate}") } } return path } var autogenInstrumentationTest = pctx.StaticRule("autogenInstrumentationTest", blueprint.RuleParams{ Command: "${AutoGenTestConfigScript} $out $in ${EmptyTestConfig} ${InstrumentationTestConfigTemplate}", CommandDeps: []string{ "${AutoGenTestConfigScript}", "${EmptyTestConfig}", "${InstrumentationTestConfigTemplate}", }, }, "name") func AutoGenInstrumentationTestConfig(ctx android.ModuleContext, prop *string, manifest android.Path) android.Path { path, autogenPath := testConfigPath(ctx, prop) if autogenPath != nil { ctx.Build(pctx, android.BuildParams{ Rule: autogenInstrumentationTest, Description: "test config", Input: manifest, Output: autogenPath, Args: map[string]string{ "name": ctx.ModuleName(), }, }) } return path }