diff options
author | 2023-03-06 09:02:38 -0500 | |
---|---|---|
committer | 2023-03-06 09:15:36 -0500 | |
commit | 8103dc428e0969cb2882182d296aa4049cd76a90 (patch) | |
tree | e8aaa54a61457f32309f77ee6509adcad4e4975d /android/soongconfig/modules_test.go | |
parent | b547b65ed320b4fdf7fb2ea9b07f3d8bab67f47a (diff) |
Migrate overlapping config var defs in all bp file
Unlike most module types, config variable handling is always namespaced
to the Android.bp file, which limits reuse of the variable definitions.
Additionally multiple of these module types can define a string variable
in the same config namespace, but specify different valid values for the
string.
Previously, we cached the first instance we see of variable + namespace;
however, this caused non-determinism in which defintion would be used
and not migrating all values. Instead, we now only cache within a single
Android.bp file where the variable definitions are re-used.
Test: go tests
Bug: 271481817
Change-Id: Ic327657c508e47a705bacd24712a1916e105c7cd
Diffstat (limited to 'android/soongconfig/modules_test.go')
-rw-r--r-- | android/soongconfig/modules_test.go | 132 |
1 files changed, 118 insertions, 14 deletions
diff --git a/android/soongconfig/modules_test.go b/android/soongconfig/modules_test.go index d5d87efc0..a5fa34938 100644 --- a/android/soongconfig/modules_test.go +++ b/android/soongconfig/modules_test.go @@ -414,6 +414,110 @@ func Test_PropertiesToApply_String_Error(t *testing.T) { } } +func Test_Bp2BuildSoongConfigDefinitionsAddVars(t *testing.T) { + testCases := []struct { + desc string + defs []*SoongConfigDefinition + expected Bp2BuildSoongConfigDefinitions + }{ + { + desc: "non-overlapping", + defs: []*SoongConfigDefinition{ + &SoongConfigDefinition{ + ModuleTypes: map[string]*ModuleType{ + "a": &ModuleType{ + ConfigNamespace: "foo", + Variables: []soongConfigVariable{ + &stringVariable{ + baseVariable: baseVariable{"string_var"}, + values: []string{"a", "b", "c"}, + }, + }, + }, + }, + }, + &SoongConfigDefinition{ + ModuleTypes: map[string]*ModuleType{ + "b": &ModuleType{ + ConfigNamespace: "foo", + Variables: []soongConfigVariable{ + &stringVariable{ + baseVariable: baseVariable{"string_var"}, + values: []string{"a", "b", "c"}, + }, + &boolVariable{baseVariable: baseVariable{"bool_var"}}, + &valueVariable{baseVariable: baseVariable{"variable_var"}}, + }, + }, + }, + }, + }, + expected: Bp2BuildSoongConfigDefinitions{ + StringVars: map[string]map[string]bool{ + "foo__string_var": map[string]bool{"a": true, "b": true, "c": true}, + }, + BoolVars: map[string]bool{"foo__bool_var": true}, + ValueVars: map[string]bool{"foo__variable_var": true}, + }, + }, + { + desc: "overlapping", + defs: []*SoongConfigDefinition{ + &SoongConfigDefinition{ + ModuleTypes: map[string]*ModuleType{ + "a": &ModuleType{ + ConfigNamespace: "foo", + Variables: []soongConfigVariable{ + &stringVariable{ + baseVariable: baseVariable{"string_var"}, + values: []string{"a", "b", "c"}, + }, + }, + }, + }, + }, + &SoongConfigDefinition{ + ModuleTypes: map[string]*ModuleType{ + "b": &ModuleType{ + ConfigNamespace: "foo", + Variables: []soongConfigVariable{ + &stringVariable{ + baseVariable: baseVariable{"string_var"}, + values: []string{"b", "c", "d"}, + }, + &boolVariable{baseVariable: baseVariable{"bool_var"}}, + &valueVariable{baseVariable: baseVariable{"variable_var"}}, + }, + }, + }, + }, + }, + expected: Bp2BuildSoongConfigDefinitions{ + StringVars: map[string]map[string]bool{ + "foo__string_var": map[string]bool{"a": true, "b": true, "c": true, "d": true}, + }, + BoolVars: map[string]bool{"foo__bool_var": true}, + ValueVars: map[string]bool{"foo__variable_var": true}, + }, + }, + } + + for _, tc := range testCases { + t.Run(tc.desc, func(t *testing.T) { + actual := &Bp2BuildSoongConfigDefinitions{} + for _, d := range tc.defs { + func(def *SoongConfigDefinition) { + actual.AddVars(def) + }(d) + } + if !reflect.DeepEqual(*actual, tc.expected) { + t.Errorf("Expected %#v, got %#v", tc.expected, *actual) + } + }) + } + +} + func Test_Bp2BuildSoongConfigDefinitions(t *testing.T) { testCases := []struct { desc string @@ -456,11 +560,11 @@ soong_config_value_variables = { soong_config_string_variables = {}`}, { desc: "only string vars", defs: Bp2BuildSoongConfigDefinitions{ - StringVars: map[string][]string{ - "string_var": []string{ - "choice1", - "choice2", - "choice3", + StringVars: map[string]map[string]bool{ + "string_var": map[string]bool{ + "choice1": true, + "choice2": true, + "choice3": true, }, }, }, @@ -484,15 +588,15 @@ soong_config_string_variables = { "value_var_one": true, "value_var_two": true, }, - StringVars: map[string][]string{ - "string_var_one": []string{ - "choice1", - "choice2", - "choice3", + StringVars: map[string]map[string]bool{ + "string_var_one": map[string]bool{ + "choice1": true, + "choice2": true, + "choice3": true, }, - "string_var_two": []string{ - "foo", - "bar", + "string_var_two": map[string]bool{ + "foo": true, + "bar": true, }, }, }, @@ -512,8 +616,8 @@ soong_config_string_variables = { "choice3", ], "string_var_two": [ - "foo", "bar", + "foo", ], }`}, } |