Use prebuilt_file for prebuilt_{etc,usr_share}

Bug: 215723302
Test: TestPrebuiltEtcNoSubdir
Test: bp2build.sh
Test: mixed_{libc,droid}.sh
Change-Id: I006bfe12beb770e11153c52eddf34a6ec7f9e363
This commit is contained in:
Alex Márquez Pérez Muñíz Díaz Púras Thaureaux
2022-02-28 18:22:59 -05:00
parent b81f77ed24
commit c78604e6a4
2 changed files with 77 additions and 27 deletions

View File

@@ -49,7 +49,7 @@ prebuilt_etc {
"filename": `"tz_version"`, "filename": `"tz_version"`,
"installable": `False`, "installable": `False`,
"src": `"version/tz_version"`, "src": `"version/tz_version"`,
"sub_dir": `"tz"`, "dir": `"etc/tz"`,
})}}) })}})
} }
@@ -83,7 +83,7 @@ prebuilt_etc {
"//build/bazel/platforms/arch:arm64": "arm64", "//build/bazel/platforms/arch:arm64": "arm64",
"//conditions:default": "version/tz_version", "//conditions:default": "version/tz_version",
})`, })`,
"sub_dir": `"tz"`, "dir": `"etc/tz"`,
})}}) })}})
} }
@@ -125,6 +125,59 @@ prebuilt_etc {
"//build/bazel/platforms/os_arch:linux_bionic_arm64": "darwin_or_arm64", "//build/bazel/platforms/os_arch:linux_bionic_arm64": "darwin_or_arm64",
"//conditions:default": "version/tz_version", "//conditions:default": "version/tz_version",
})`, })`,
"sub_dir": `"tz"`, "dir": `"etc/tz"`,
})}})
}
func runPrebuiltUsrShareTestCase(t *testing.T, tc bp2buildTestCase) {
t.Helper()
(&tc).moduleTypeUnderTest = "prebuilt_usr_share"
(&tc).moduleTypeUnderTestFactory = etc.PrebuiltUserShareFactory
runBp2BuildTestCase(t, registerPrebuiltEtcModuleTypes, tc)
}
func registerPrebuiltUsrShareModuleTypes(ctx android.RegistrationContext) {
}
func TestPrebuiltUsrShareSimple(t *testing.T) {
runPrebuiltUsrShareTestCase(t, bp2buildTestCase{
description: "prebuilt_usr_share - simple example",
filesystem: map[string]string{},
blueprint: `
prebuilt_usr_share {
name: "apex_tz_version",
src: "version/tz_version",
filename: "tz_version",
sub_dir: "tz",
installable: false,
}
`,
expectedBazelTargets: []string{
makeBazelTarget("prebuilt_file", "apex_tz_version", attrNameToString{
"filename": `"tz_version"`,
"installable": `False`,
"src": `"version/tz_version"`,
"dir": `"usr/share/tz"`,
})}})
}
func TestPrebuiltEtcNoSubdir(t *testing.T) {
runPrebuiltEtcTestCase(t, bp2buildTestCase{
description: "prebuilt_etc - no subdir",
filesystem: map[string]string{},
blueprint: `
prebuilt_etc {
name: "apex_tz_version",
src: "version/tz_version",
filename: "tz_version",
installable: false,
}
`,
expectedBazelTargets: []string{
makeBazelTarget("prebuilt_file", "apex_tz_version", attrNameToString{
"filename": `"tz_version"`,
"installable": `False`,
"src": `"version/tz_version"`,
"dir": `"etc"`,
})}}) })}})
} }

View File

@@ -474,6 +474,7 @@ func PrebuiltUserShareFactory() android.Module {
// This module is device-only // This module is device-only
android.InitAndroidArchModule(module, android.DeviceSupported, android.MultilibFirst) android.InitAndroidArchModule(module, android.DeviceSupported, android.MultilibFirst)
android.InitDefaultableModule(module) android.InitDefaultableModule(module)
android.InitBazelModule(module)
return module return module
} }
@@ -668,25 +669,17 @@ func generatePrebuiltSnapshot(s snapshot.SnapshotSingleton, ctx android.Singleto
// For Bazel / bp2build // For Bazel / bp2build
type bazelPrebuiltEtcAttributes struct { type bazelPrebuiltFileAttributes struct {
Src bazel.LabelAttribute Src bazel.LabelAttribute
Filename string Filename string
Sub_dir string Dir string
Installable bazel.BoolAttribute Installable bazel.BoolAttribute
} }
// ConvertWithBp2build performs bp2build conversion of PrebuiltEtc // ConvertWithBp2build performs bp2build conversion of PrebuiltEtc
func (p *PrebuiltEtc) ConvertWithBp2build(ctx android.TopDownMutatorContext) { // All prebuilt_* modules are PrebuiltEtc, which we treat uniformily as *PrebuiltFile*
// All prebuilt_* modules are PrebuiltEtc, but at this time, we only convert prebuilt_etc modules. func (module *PrebuiltEtc) ConvertWithBp2build(ctx android.TopDownMutatorContext) {
if p.installDirBase != "etc" { var src bazel.LabelAttribute
return
}
prebuiltEtcBp2BuildInternal(ctx, p)
}
func prebuiltEtcBp2BuildInternal(ctx android.TopDownMutatorContext, module *PrebuiltEtc) {
var srcLabelAttribute bazel.LabelAttribute
for axis, configToProps := range module.GetArchVariantProperties(ctx, &prebuiltEtcProperties{}) { for axis, configToProps := range module.GetArchVariantProperties(ctx, &prebuiltEtcProperties{}) {
for config, p := range configToProps { for config, p := range configToProps {
props, ok := p.(*prebuiltEtcProperties) props, ok := p.(*prebuiltEtcProperties)
@@ -695,7 +688,7 @@ func prebuiltEtcBp2BuildInternal(ctx android.TopDownMutatorContext, module *Preb
} }
if props.Src != nil { if props.Src != nil {
label := android.BazelLabelForModuleSrcSingle(ctx, *props.Src) label := android.BazelLabelForModuleSrcSingle(ctx, *props.Src)
srcLabelAttribute.SetSelectValue(axis, config, label) src.SetSelectValue(axis, config, label)
} }
} }
} }
@@ -705,21 +698,25 @@ func prebuiltEtcBp2BuildInternal(ctx android.TopDownMutatorContext, module *Preb
filename = *module.properties.Filename filename = *module.properties.Filename
} }
var subDir string var dir = module.installDirBase
if module.subdirProperties.Sub_dir != nil { // prebuilt_file supports only `etc` or `usr/share`
subDir = *module.subdirProperties.Sub_dir if !(dir == "etc" || dir == "usr/share") {
return
}
if subDir := module.subdirProperties.Sub_dir; subDir != nil {
dir = dir + "/" + *subDir
} }
var installableBoolAttribute bazel.BoolAttribute var installable bazel.BoolAttribute
if module.properties.Installable != nil { if install := module.properties.Installable; install != nil {
installableBoolAttribute.Value = module.properties.Installable installable.Value = install
} }
attrs := &bazelPrebuiltEtcAttributes{ attrs := &bazelPrebuiltFileAttributes{
Src: srcLabelAttribute, Src: src,
Filename: filename, Filename: filename,
Sub_dir: subDir, Dir: dir,
Installable: installableBoolAttribute, Installable: installable,
} }
props := bazel.BazelTargetModuleProperties{ props := bazel.BazelTargetModuleProperties{