add unit test for bp2build allowlist
Test: go test ./android Change-Id: I0ea1d97444cbedfd285f1fc4bd7ff246ce699dc9
This commit is contained in:
@@ -329,7 +329,7 @@ func labelAddSuffixForTypeMapper(suffix, typ string) LabelMapper {
|
||||
func TestPartitionLabelListAttribute(t *testing.T) {
|
||||
testCases := []struct {
|
||||
name string
|
||||
ctx *otherModuleTestContext
|
||||
ctx *OtherModuleTestContext
|
||||
labelList LabelListAttribute
|
||||
filters LabelPartitions
|
||||
expected PartitionToLabelListAttribute
|
||||
@@ -337,7 +337,7 @@ func TestPartitionLabelListAttribute(t *testing.T) {
|
||||
}{
|
||||
{
|
||||
name: "no configurable values",
|
||||
ctx: &otherModuleTestContext{},
|
||||
ctx: &OtherModuleTestContext{},
|
||||
labelList: LabelListAttribute{
|
||||
Value: makeLabelList([]string{"a.a", "b.b", "c.c", "d.d", "e.e"}, []string{}),
|
||||
},
|
||||
@@ -354,7 +354,7 @@ func TestPartitionLabelListAttribute(t *testing.T) {
|
||||
},
|
||||
{
|
||||
name: "no configurable values, remainder partition",
|
||||
ctx: &otherModuleTestContext{},
|
||||
ctx: &OtherModuleTestContext{},
|
||||
labelList: LabelListAttribute{
|
||||
Value: makeLabelList([]string{"a.a", "b.b", "c.c", "d.d", "e.e"}, []string{}),
|
||||
},
|
||||
@@ -371,7 +371,7 @@ func TestPartitionLabelListAttribute(t *testing.T) {
|
||||
},
|
||||
{
|
||||
name: "no configurable values, empty partition",
|
||||
ctx: &otherModuleTestContext{},
|
||||
ctx: &OtherModuleTestContext{},
|
||||
labelList: LabelListAttribute{
|
||||
Value: makeLabelList([]string{"a.a", "c.c"}, []string{}),
|
||||
},
|
||||
@@ -387,8 +387,8 @@ func TestPartitionLabelListAttribute(t *testing.T) {
|
||||
},
|
||||
{
|
||||
name: "no configurable values, has map",
|
||||
ctx: &otherModuleTestContext{
|
||||
modules: []testModuleInfo{testModuleInfo{name: "srcs", typ: "fg", dir: "dir"}},
|
||||
ctx: &OtherModuleTestContext{
|
||||
Modules: []TestModuleInfo{{ModuleName: "srcs", Typ: "fg", Dir: "dir"}},
|
||||
},
|
||||
labelList: LabelListAttribute{
|
||||
Value: makeLabelList([]string{"a.a", "srcs", "b.b", "c.c"}, []string{}),
|
||||
@@ -406,7 +406,7 @@ func TestPartitionLabelListAttribute(t *testing.T) {
|
||||
},
|
||||
{
|
||||
name: "configurable values, keeps empty if excludes",
|
||||
ctx: &otherModuleTestContext{},
|
||||
ctx: &OtherModuleTestContext{},
|
||||
labelList: LabelListAttribute{
|
||||
ConfigurableValues: configurableLabelLists{
|
||||
ArchConfigurationAxis: labelListSelectValues{
|
||||
@@ -450,7 +450,7 @@ func TestPartitionLabelListAttribute(t *testing.T) {
|
||||
},
|
||||
{
|
||||
name: "error for multiple partitions same value",
|
||||
ctx: &otherModuleTestContext{},
|
||||
ctx: &OtherModuleTestContext{},
|
||||
labelList: LabelListAttribute{
|
||||
Value: makeLabelList([]string{"a.a", "b.b", "c.c", "d.d", "e.e"}, []string{}),
|
||||
},
|
||||
|
@@ -20,86 +20,86 @@ import (
|
||||
"github.com/google/blueprint"
|
||||
)
|
||||
|
||||
// testModuleInfo implements blueprint.Module interface with sufficient information to mock a subset of
|
||||
// TestModuleInfo implements blueprint.Module interface with sufficient information to mock a subset of
|
||||
// a blueprint ModuleContext
|
||||
type testModuleInfo struct {
|
||||
name string
|
||||
typ string
|
||||
dir string
|
||||
type TestModuleInfo struct {
|
||||
ModuleName string
|
||||
Typ string
|
||||
Dir string
|
||||
}
|
||||
|
||||
// Name returns name for testModuleInfo -- required to implement blueprint.Module
|
||||
func (mi testModuleInfo) Name() string {
|
||||
return mi.name
|
||||
func (mi TestModuleInfo) Name() string {
|
||||
return mi.ModuleName
|
||||
}
|
||||
|
||||
// GenerateBuildActions unused, but required to implmeent blueprint.Module
|
||||
func (mi testModuleInfo) GenerateBuildActions(blueprint.ModuleContext) {}
|
||||
func (mi TestModuleInfo) GenerateBuildActions(blueprint.ModuleContext) {}
|
||||
|
||||
func (mi testModuleInfo) equals(other testModuleInfo) bool {
|
||||
return mi.name == other.name && mi.typ == other.typ && mi.dir == other.dir
|
||||
func (mi TestModuleInfo) equals(other TestModuleInfo) bool {
|
||||
return mi.ModuleName == other.ModuleName && mi.Typ == other.Typ && mi.Dir == other.Dir
|
||||
}
|
||||
|
||||
// ensure testModuleInfo implements blueprint.Module
|
||||
var _ blueprint.Module = testModuleInfo{}
|
||||
var _ blueprint.Module = TestModuleInfo{}
|
||||
|
||||
// otherModuleTestContext is a mock context that implements OtherModuleContext
|
||||
type otherModuleTestContext struct {
|
||||
modules []testModuleInfo
|
||||
// OtherModuleTestContext is a mock context that implements OtherModuleContext
|
||||
type OtherModuleTestContext struct {
|
||||
Modules []TestModuleInfo
|
||||
errors []string
|
||||
}
|
||||
|
||||
// ModuleFromName retrieves the testModuleInfo corresponding to name, if it exists
|
||||
func (omc *otherModuleTestContext) ModuleFromName(name string) (blueprint.Module, bool) {
|
||||
for _, m := range omc.modules {
|
||||
if m.name == name {
|
||||
func (omc *OtherModuleTestContext) ModuleFromName(name string) (blueprint.Module, bool) {
|
||||
for _, m := range omc.Modules {
|
||||
if m.ModuleName == name {
|
||||
return m, true
|
||||
}
|
||||
}
|
||||
return testModuleInfo{}, false
|
||||
return TestModuleInfo{}, false
|
||||
}
|
||||
|
||||
// testModuleInfo returns the testModuleInfo corresponding to a blueprint.Module if it exists in omc
|
||||
func (omc *otherModuleTestContext) testModuleInfo(m blueprint.Module) (testModuleInfo, bool) {
|
||||
mi, ok := m.(testModuleInfo)
|
||||
func (omc *OtherModuleTestContext) testModuleInfo(m blueprint.Module) (TestModuleInfo, bool) {
|
||||
mi, ok := m.(TestModuleInfo)
|
||||
if !ok {
|
||||
return testModuleInfo{}, false
|
||||
return TestModuleInfo{}, false
|
||||
}
|
||||
for _, other := range omc.modules {
|
||||
for _, other := range omc.Modules {
|
||||
if other.equals(mi) {
|
||||
return mi, true
|
||||
}
|
||||
}
|
||||
return testModuleInfo{}, false
|
||||
return TestModuleInfo{}, false
|
||||
}
|
||||
|
||||
// OtherModuleType returns type of m if it exists in omc
|
||||
func (omc *otherModuleTestContext) OtherModuleType(m blueprint.Module) string {
|
||||
func (omc *OtherModuleTestContext) OtherModuleType(m blueprint.Module) string {
|
||||
if mi, ok := omc.testModuleInfo(m); ok {
|
||||
return mi.typ
|
||||
return mi.Typ
|
||||
}
|
||||
return ""
|
||||
}
|
||||
|
||||
// OtherModuleName returns name of m if it exists in omc
|
||||
func (omc *otherModuleTestContext) OtherModuleName(m blueprint.Module) string {
|
||||
func (omc *OtherModuleTestContext) OtherModuleName(m blueprint.Module) string {
|
||||
if mi, ok := omc.testModuleInfo(m); ok {
|
||||
return mi.name
|
||||
return mi.ModuleName
|
||||
}
|
||||
return ""
|
||||
}
|
||||
|
||||
// OtherModuleDir returns dir of m if it exists in omc
|
||||
func (omc *otherModuleTestContext) OtherModuleDir(m blueprint.Module) string {
|
||||
func (omc *OtherModuleTestContext) OtherModuleDir(m blueprint.Module) string {
|
||||
if mi, ok := omc.testModuleInfo(m); ok {
|
||||
return mi.dir
|
||||
return mi.Dir
|
||||
}
|
||||
return ""
|
||||
}
|
||||
|
||||
func (omc *otherModuleTestContext) ModuleErrorf(format string, args ...interface{}) {
|
||||
func (omc *OtherModuleTestContext) ModuleErrorf(format string, args ...interface{}) {
|
||||
omc.errors = append(omc.errors, fmt.Sprintf(format, args...))
|
||||
}
|
||||
|
||||
// Ensure otherModuleTestContext implements OtherModuleContext
|
||||
var _ OtherModuleContext = &otherModuleTestContext{}
|
||||
var _ OtherModuleContext = &OtherModuleTestContext{}
|
||||
|
Reference in New Issue
Block a user