add unit test for bp2build allowlist
Test: go test ./android Change-Id: I0ea1d97444cbedfd285f1fc4bd7ff246ce699dc9
This commit is contained in:
@@ -15,7 +15,12 @@ package android
|
||||
|
||||
import (
|
||||
"android/soong/android/allowlists"
|
||||
"android/soong/bazel"
|
||||
"fmt"
|
||||
"testing"
|
||||
|
||||
"github.com/google/blueprint"
|
||||
"github.com/google/blueprint/proptools"
|
||||
)
|
||||
|
||||
func TestConvertAllModulesInPackage(t *testing.T) {
|
||||
@@ -135,3 +140,249 @@ func TestModuleOptIn(t *testing.T) {
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
type TestBazelModule struct {
|
||||
bazel.TestModuleInfo
|
||||
BazelModuleBase
|
||||
}
|
||||
|
||||
var _ blueprint.Module = TestBazelModule{}
|
||||
|
||||
func (m TestBazelModule) Name() string {
|
||||
return m.TestModuleInfo.ModuleName
|
||||
}
|
||||
|
||||
func (m TestBazelModule) GenerateBuildActions(blueprint.ModuleContext) {
|
||||
}
|
||||
|
||||
type TestBazelConversionContext struct {
|
||||
omc bazel.OtherModuleTestContext
|
||||
allowlist bp2BuildConversionAllowlist
|
||||
errors []string
|
||||
}
|
||||
|
||||
var _ bazelOtherModuleContext = &TestBazelConversionContext{}
|
||||
|
||||
func (bcc *TestBazelConversionContext) OtherModuleType(m blueprint.Module) string {
|
||||
return bcc.omc.OtherModuleType(m)
|
||||
}
|
||||
|
||||
func (bcc *TestBazelConversionContext) OtherModuleName(m blueprint.Module) string {
|
||||
return bcc.omc.OtherModuleName(m)
|
||||
}
|
||||
|
||||
func (bcc *TestBazelConversionContext) OtherModuleDir(m blueprint.Module) string {
|
||||
return bcc.omc.OtherModuleDir(m)
|
||||
}
|
||||
|
||||
func (bcc *TestBazelConversionContext) ModuleErrorf(format string, args ...interface{}) {
|
||||
bcc.errors = append(bcc.errors, fmt.Sprintf(format, args...))
|
||||
}
|
||||
|
||||
func (bcc *TestBazelConversionContext) Config() Config {
|
||||
return Config{
|
||||
&config{
|
||||
bp2buildPackageConfig: bcc.allowlist,
|
||||
},
|
||||
}
|
||||
}
|
||||
|
||||
var bazelableBazelModuleBase = BazelModuleBase{
|
||||
bazelProperties: properties{
|
||||
Bazel_module: bazelModuleProperties{
|
||||
CanConvertToBazel: true,
|
||||
},
|
||||
},
|
||||
}
|
||||
|
||||
func TestBp2BuildAllowlist(t *testing.T) {
|
||||
testCases := []struct {
|
||||
description string
|
||||
shouldConvert bool
|
||||
expectedErrors []string
|
||||
module TestBazelModule
|
||||
allowlist bp2BuildConversionAllowlist
|
||||
}{
|
||||
{
|
||||
description: "allowlist enables module",
|
||||
shouldConvert: true,
|
||||
module: TestBazelModule{
|
||||
TestModuleInfo: bazel.TestModuleInfo{
|
||||
ModuleName: "foo",
|
||||
Typ: "rule1",
|
||||
Dir: "dir1",
|
||||
},
|
||||
BazelModuleBase: bazelableBazelModuleBase,
|
||||
},
|
||||
allowlist: bp2BuildConversionAllowlist{
|
||||
moduleAlwaysConvert: map[string]bool{
|
||||
"foo": true,
|
||||
},
|
||||
},
|
||||
},
|
||||
{
|
||||
description: "module in name allowlist and type allowlist fails",
|
||||
shouldConvert: false,
|
||||
expectedErrors: []string{"A module cannot be in moduleAlwaysConvert and also be in moduleTypeAlwaysConvert"},
|
||||
module: TestBazelModule{
|
||||
TestModuleInfo: bazel.TestModuleInfo{
|
||||
ModuleName: "foo",
|
||||
Typ: "rule1",
|
||||
Dir: "dir1",
|
||||
},
|
||||
BazelModuleBase: bazelableBazelModuleBase,
|
||||
},
|
||||
allowlist: bp2BuildConversionAllowlist{
|
||||
moduleAlwaysConvert: map[string]bool{
|
||||
"foo": true,
|
||||
},
|
||||
moduleTypeAlwaysConvert: map[string]bool{
|
||||
"rule1": true,
|
||||
},
|
||||
},
|
||||
},
|
||||
{
|
||||
description: "module in allowlist and denylist fails",
|
||||
shouldConvert: false,
|
||||
expectedErrors: []string{"a module cannot be in moduleDoNotConvert and also be in moduleAlwaysConvert"},
|
||||
module: TestBazelModule{
|
||||
TestModuleInfo: bazel.TestModuleInfo{
|
||||
ModuleName: "foo",
|
||||
Typ: "rule1",
|
||||
Dir: "dir1",
|
||||
},
|
||||
BazelModuleBase: bazelableBazelModuleBase,
|
||||
},
|
||||
allowlist: bp2BuildConversionAllowlist{
|
||||
moduleAlwaysConvert: map[string]bool{
|
||||
"foo": true,
|
||||
},
|
||||
moduleDoNotConvert: map[string]bool{
|
||||
"foo": true,
|
||||
},
|
||||
},
|
||||
},
|
||||
{
|
||||
description: "module in allowlist and existing BUILD file",
|
||||
shouldConvert: false,
|
||||
expectedErrors: []string{"A module cannot be in a directory listed in keepExistingBuildFile and also be in moduleAlwaysConvert. Directory: 'existing/build/dir'"},
|
||||
module: TestBazelModule{
|
||||
TestModuleInfo: bazel.TestModuleInfo{
|
||||
ModuleName: "foo",
|
||||
Typ: "rule1",
|
||||
Dir: "existing/build/dir",
|
||||
},
|
||||
BazelModuleBase: bazelableBazelModuleBase,
|
||||
},
|
||||
allowlist: bp2BuildConversionAllowlist{
|
||||
moduleAlwaysConvert: map[string]bool{
|
||||
"foo": true,
|
||||
},
|
||||
keepExistingBuildFile: map[string]bool{
|
||||
"existing/build/dir": true,
|
||||
},
|
||||
},
|
||||
},
|
||||
{
|
||||
description: "module allowlist and enabled directory",
|
||||
shouldConvert: false,
|
||||
expectedErrors: []string{"A module cannot be in a directory marked Bp2BuildDefaultTrue or Bp2BuildDefaultTrueRecursively and also be in moduleAlwaysConvert. Directory: 'existing/build/dir'"},
|
||||
module: TestBazelModule{
|
||||
TestModuleInfo: bazel.TestModuleInfo{
|
||||
ModuleName: "foo",
|
||||
Typ: "rule1",
|
||||
Dir: "existing/build/dir",
|
||||
},
|
||||
BazelModuleBase: bazelableBazelModuleBase,
|
||||
},
|
||||
allowlist: bp2BuildConversionAllowlist{
|
||||
moduleAlwaysConvert: map[string]bool{
|
||||
"foo": true,
|
||||
},
|
||||
defaultConfig: allowlists.Bp2BuildConfig{
|
||||
"existing/build/dir": allowlists.Bp2BuildDefaultTrue,
|
||||
},
|
||||
},
|
||||
},
|
||||
{
|
||||
description: "module allowlist and enabled subdirectory",
|
||||
shouldConvert: false,
|
||||
expectedErrors: []string{"A module cannot be in a directory marked Bp2BuildDefaultTrue or Bp2BuildDefaultTrueRecursively and also be in moduleAlwaysConvert. Directory: 'existing/build/dir'"},
|
||||
module: TestBazelModule{
|
||||
TestModuleInfo: bazel.TestModuleInfo{
|
||||
ModuleName: "foo",
|
||||
Typ: "rule1",
|
||||
Dir: "existing/build/dir/subdir",
|
||||
},
|
||||
BazelModuleBase: bazelableBazelModuleBase,
|
||||
},
|
||||
allowlist: bp2BuildConversionAllowlist{
|
||||
moduleAlwaysConvert: map[string]bool{
|
||||
"foo": true,
|
||||
},
|
||||
defaultConfig: allowlists.Bp2BuildConfig{
|
||||
"existing/build/dir": allowlists.Bp2BuildDefaultTrueRecursively,
|
||||
},
|
||||
},
|
||||
},
|
||||
{
|
||||
description: "module enabled in unit test short-circuits other allowlists",
|
||||
shouldConvert: true,
|
||||
module: TestBazelModule{
|
||||
TestModuleInfo: bazel.TestModuleInfo{
|
||||
ModuleName: "foo",
|
||||
Typ: "rule1",
|
||||
Dir: ".",
|
||||
},
|
||||
BazelModuleBase: BazelModuleBase{
|
||||
bazelProperties: properties{
|
||||
Bazel_module: bazelModuleProperties{
|
||||
CanConvertToBazel: true,
|
||||
Bp2build_available: proptools.BoolPtr(true),
|
||||
},
|
||||
},
|
||||
},
|
||||
},
|
||||
allowlist: bp2BuildConversionAllowlist{
|
||||
moduleAlwaysConvert: map[string]bool{
|
||||
"foo": true,
|
||||
},
|
||||
moduleDoNotConvert: map[string]bool{
|
||||
"foo": true,
|
||||
},
|
||||
},
|
||||
},
|
||||
}
|
||||
|
||||
for _, test := range testCases {
|
||||
t.Run(test.description, func(t *testing.T) {
|
||||
bcc := &TestBazelConversionContext{
|
||||
omc: bazel.OtherModuleTestContext{
|
||||
Modules: []bazel.TestModuleInfo{
|
||||
test.module.TestModuleInfo,
|
||||
},
|
||||
},
|
||||
allowlist: test.allowlist,
|
||||
}
|
||||
|
||||
shouldConvert := test.module.shouldConvertWithBp2build(bcc, test.module.TestModuleInfo)
|
||||
if test.shouldConvert != shouldConvert {
|
||||
t.Errorf("Module shouldConvert expected to be: %v, but was: %v", test.shouldConvert, shouldConvert)
|
||||
}
|
||||
|
||||
errorsMatch := true
|
||||
if len(test.expectedErrors) != len(bcc.errors) {
|
||||
errorsMatch = false
|
||||
} else {
|
||||
for i, err := range test.expectedErrors {
|
||||
if err != bcc.errors[i] {
|
||||
errorsMatch = false
|
||||
}
|
||||
}
|
||||
}
|
||||
if !errorsMatch {
|
||||
t.Errorf("Expected errors to be: %v, but were: %v", test.expectedErrors, bcc.errors)
|
||||
}
|
||||
})
|
||||
}
|
||||
}
|
||||
|
Reference in New Issue
Block a user