Add data_device_bins_both properties for python_test_host
Test: presubmits and manual verification Bug: 274930471 Change-Id: Iafc85526afdb8264526e8a5a33319fa33a23c66b
This commit is contained in:
@@ -66,6 +66,10 @@ type TestProperties struct {
|
|||||||
|
|
||||||
// Test options.
|
// Test options.
|
||||||
Test_options TestOptions
|
Test_options TestOptions
|
||||||
|
|
||||||
|
// list of device binary modules that should be installed alongside the test
|
||||||
|
// This property adds 64bit AND 32bit variants of the dependency
|
||||||
|
Data_device_bins_both []string `android:"arch_variant"`
|
||||||
}
|
}
|
||||||
|
|
||||||
type TestOptions struct {
|
type TestOptions struct {
|
||||||
@@ -98,12 +102,48 @@ func (p *PythonTestModule) init() android.Module {
|
|||||||
android.InitAndroidArchModule(p, p.hod, p.multilib)
|
android.InitAndroidArchModule(p, p.hod, p.multilib)
|
||||||
android.InitDefaultableModule(p)
|
android.InitDefaultableModule(p)
|
||||||
android.InitBazelModule(p)
|
android.InitBazelModule(p)
|
||||||
if p.hod == android.HostSupported && p.testProperties.Test_options.Unit_test == nil {
|
if p.isTestHost() && p.testProperties.Test_options.Unit_test == nil {
|
||||||
p.testProperties.Test_options.Unit_test = proptools.BoolPtr(true)
|
p.testProperties.Test_options.Unit_test = proptools.BoolPtr(true)
|
||||||
}
|
}
|
||||||
return p
|
return p
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (p *PythonTestModule) isTestHost() bool {
|
||||||
|
return p.hod == android.HostSupported
|
||||||
|
}
|
||||||
|
|
||||||
|
var dataDeviceBinsTag = dependencyTag{name: "dataDeviceBins"}
|
||||||
|
|
||||||
|
// python_test_host DepsMutator uses this method to add multilib dependencies of
|
||||||
|
// data_device_bin_both
|
||||||
|
func (p *PythonTestModule) addDataDeviceBinsDeps(ctx android.BottomUpMutatorContext, filter string) {
|
||||||
|
if len(p.testProperties.Data_device_bins_both) < 1 {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
var maybeAndroidTarget *android.Target
|
||||||
|
androidTargetList := android.FirstTarget(ctx.Config().Targets[android.Android], filter)
|
||||||
|
if len(androidTargetList) > 0 {
|
||||||
|
maybeAndroidTarget = &androidTargetList[0]
|
||||||
|
}
|
||||||
|
|
||||||
|
if maybeAndroidTarget != nil {
|
||||||
|
ctx.AddFarVariationDependencies(
|
||||||
|
maybeAndroidTarget.Variations(),
|
||||||
|
dataDeviceBinsTag,
|
||||||
|
p.testProperties.Data_device_bins_both...,
|
||||||
|
)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func (p *PythonTestModule) DepsMutator(ctx android.BottomUpMutatorContext) {
|
||||||
|
p.PythonBinaryModule.DepsMutator(ctx)
|
||||||
|
if p.isTestHost() {
|
||||||
|
p.addDataDeviceBinsDeps(ctx, "lib32")
|
||||||
|
p.addDataDeviceBinsDeps(ctx, "lib64")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
func (p *PythonTestModule) GenerateAndroidBuildActions(ctx android.ModuleContext) {
|
func (p *PythonTestModule) GenerateAndroidBuildActions(ctx android.ModuleContext) {
|
||||||
// We inherit from only the library's GenerateAndroidBuildActions, and then
|
// We inherit from only the library's GenerateAndroidBuildActions, and then
|
||||||
// just use buildBinary() so that the binary is not installed into the location
|
// just use buildBinary() so that the binary is not installed into the location
|
||||||
@@ -153,6 +193,12 @@ func (p *PythonTestModule) GenerateAndroidBuildActions(ctx android.ModuleContext
|
|||||||
p.data = append(p.data, android.DataPath{SrcPath: dataSrcPath})
|
p.data = append(p.data, android.DataPath{SrcPath: dataSrcPath})
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if p.isTestHost() && len(p.testProperties.Data_device_bins_both) > 0 {
|
||||||
|
ctx.VisitDirectDepsWithTag(dataDeviceBinsTag, func(dep android.Module) {
|
||||||
|
p.data = append(p.data, android.DataPath{SrcPath: android.OutputFileForModule(ctx, dep, "")})
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
// Emulate the data property for java_data dependencies.
|
// Emulate the data property for java_data dependencies.
|
||||||
for _, javaData := range ctx.GetDirectDepsWithTag(javaDataTag) {
|
for _, javaData := range ctx.GetDirectDepsWithTag(javaDataTag) {
|
||||||
for _, javaDataSrcPath := range android.OutputFilesForModule(ctx, javaData, "") {
|
for _, javaDataSrcPath := range android.OutputFilesForModule(ctx, javaData, "") {
|
||||||
|
Reference in New Issue
Block a user