diff options
Diffstat (limited to 'systemfeatures/system_features_test.go')
| -rw-r--r-- | systemfeatures/system_features_test.go | 80 |
1 files changed, 80 insertions, 0 deletions
diff --git a/systemfeatures/system_features_test.go b/systemfeatures/system_features_test.go index 58e6a0660..3f6060b0a 100644 --- a/systemfeatures/system_features_test.go +++ b/systemfeatures/system_features_test.go @@ -44,8 +44,88 @@ java_system_features_srcs { android.AssertStringDoesContain(t, "Expected TELEVISION feature flag", cmd, "--feature=TELEVISION:UNAVAILABLE ") android.AssertStringDoesContain(t, "Expected WATCH feature flag", cmd, "--feature=WATCH: ") android.AssertStringDoesNotContain(t, "Unexpected FOO arg from non-system feature flag", cmd, "FOO") + android.AssertStringDoesNotContain(t, "Unexpected feature xml files flag", cmd, "--feature-xml-files") systemFeaturesModule := module.Module().(*javaSystemFeaturesSrcs) expectedOutputPath := "out/soong/.intermediates/system-features-srcs/gen/RoSystemFeatures.java" android.AssertPathsRelativeToTopEquals(t, "Expected output file", []string{expectedOutputPath}, systemFeaturesModule.Srcs()) } + +func TestJavaSystemFeaturesSrcsFromXml(t *testing.T) { + bp := ` +java_system_features_srcs { + name: "system-features-srcs", + full_class_name: "com.android.test.RoSystemFeatures", +} +` + + res := android.GroupFixturePreparers( + android.FixtureRegisterWithContext(registerSystemFeaturesComponents), + android.PrepareForTestWithBuildFlag("RELEASE_USE_SYSTEM_FEATURE_BUILD_FLAGS", "true"), + android.PrepareForTestWithBuildFlag("RELEASE_USE_SYSTEM_FEATURE_XML_FOR_UNAVAILABLE_FEATURES", "true"), + android.PrepareForTestWithBuildFlag("RELEASE_SYSTEM_FEATURE_AUTOMOTIVE", "0"), + android.FixtureModifyConfig(func(config android.Config) { + config.TestProductVariables.PartitionVarsForSoongMigrationOnlyDoNotUse.ProductCopyFiles = []string{ + "frameworks/features.xml:system/etc/permissions/features.xml", + "frameworks/features.xml:system/etc/permissions/featurescopy.xml", + "frameworks/features2.xml:system/etc/sysconfig/features2.xml", + "frameworks/featureswithowner.xml:vendor/etc/permissions/featureswithowner.xml:customowner", + "frameworks/dstalreadyexists.xml:system/etc/permissions/features.xml", + "frameworks/wrongsuffix.notxml:system/etc/permissions/wrongsuffix.notxml", + "frameworks/wrongsubdir.xml:system/notsysconfig/wrongsubdir.xml", + "frameworks/wrongsubdir.xml:system/notpermissions/wrongsubdir.xml", + "frameworks/wrongsubdir.xml:system/etc/permissions/nested/wrongsubdir.xml", + "frameworks/wrongsubdir.xml:system/notetc/permissions/wrongsubdir.xml", + "frameworks/nonexistent.xml:system/etc/permissions/nonexistent.xml", + } + }), + android.FixtureMergeMockFs(android.MockFS{ + "frameworks/features.xml": nil, + "frameworks/features2.xml": nil, + "frameworks/featureswithowner.xml": nil, + "frameworks/wrongsuffix.notxml": nil, + "frameworks/wrongsubdir.xml": nil, + "frameworks/dstalreadyexists.xml": nil, + // Note that we explicitly omit frameworks/nonexistent.xml. + }), + ).RunTestWithBp(t, bp) + + module := res.ModuleForTests(t, "system-features-srcs", "") + cmd := module.Rule("system-features-srcs").RuleParams.Command + android.AssertStringDoesContain(t, "Expected fully class name", cmd, " com.android.test.RoSystemFeatures ") + android.AssertStringDoesContain(t, "Expected readonly flag", cmd, "--readonly=true") + android.AssertStringDoesContain(t, "Expected AUTOMOTIVE feature flag", cmd, "--feature=AUTOMOTIVE:0 ") + android.AssertStringDoesContain(t, "Expected feature xml files flag", cmd, "--unavailable-feature-xml-files=frameworks/features.xml,frameworks/features2.xml,frameworks/featureswithowner.xml") + android.AssertStringDoesNotContain(t, "Unexpected feature xml file", cmd, "dstalreadyexists.xml") + android.AssertStringDoesNotContain(t, "Unexpected feature xml file", cmd, "nonexistent.xml") + android.AssertStringDoesNotContain(t, "Unexpected feature xml file", cmd, "wrongsubdir.xml") + android.AssertStringDoesNotContain(t, "Unexpected feature xml file", cmd, "wrongsuffix.notxml") + + systemFeaturesModule := module.Module().(*javaSystemFeaturesSrcs) + expectedOutputPath := "out/soong/.intermediates/system-features-srcs/gen/RoSystemFeatures.java" + android.AssertPathsRelativeToTopEquals(t, "Expected output file", []string{expectedOutputPath}, systemFeaturesModule.Srcs()) +} + +func TestJavaSystemFeaturesSrcsFromInvalidProductFiles(t *testing.T) { + bp := ` +java_system_features_srcs { + name: "system-features-srcs", + full_class_name: "com.android.test.RoSystemFeatures", +} +` + + android.GroupFixturePreparers( + android.FixtureRegisterWithContext(registerSystemFeaturesComponents), + android.PrepareForTestWithBuildFlag("RELEASE_USE_SYSTEM_FEATURE_XML_FOR_UNAVAILABLE_FEATURES", "true"), + android.FixtureModifyConfig(func(config android.Config) { + config.TestProductVariables.PartitionVarsForSoongMigrationOnlyDoNotUse.ProductCopyFiles = []string{ + "frameworks/dstmissing.xml", + } + }), + android.FixtureMergeMockFs(android.MockFS{ + "frameworks/dstmissing.xml": nil, + }), + ).ExtendWithErrorHandler( + android.FixtureExpectsAtLeastOneErrorMatchingPattern("PRODUCT_COPY_FILES must follow the format \"src:dest\", got: frameworks/dstmissing.xml"), + ).RunTestWithBp(t, bp) +} |
