diff options
author | 2023-02-02 13:22:26 -0800 | |
---|---|---|
committer | 2023-02-08 12:38:50 -0800 | |
commit | c6f4b532f3bd2a4d204fa059631907560e76ab5b (patch) | |
tree | 44cffe17f0846ca579a0071cdad1f345eb945d2f | |
parent | 800f64078ccc52ab1ced951376e44fb24e61fcaa (diff) |
Allow android tests to specify a mainline package name
Tests that run against mainline modules generally need to be built
twice: once for aosp (unsigned) and once for internal (signed).
The override_android_test rule is really useful for generating a
signed version of the unsigned test.
However, mainline tests need to use a MainlineTestModuleController
to only run tests on targets with the expected module. Since unsigned
and signed mainline modules have different package names, this means
the test config needs to be updated when overriding a test.
Add a new "mainline_package_name" argument so that android test rules
can update the targeted mainline package. Without this, the only way
to create a mainline package test is to instead use android_test, which
results in a lot of copy-pasta.
Test: added tests to soong
Test: manual, using a locally-modified RkpdAppUnitTest
Test: test_config_fixer_test.py
Change-Id: Idaffd63f225719a2bfda41018fda630b17db0080
-rwxr-xr-x | java/app.go | 10 | ||||
-rw-r--r-- | java/app_test.go | 5 | ||||
-rw-r--r-- | scripts/test_config_fixer.py | 17 | ||||
-rw-r--r-- | scripts/test_config_fixer_test.py | 36 |
4 files changed, 67 insertions, 1 deletions
diff --git a/java/app.go b/java/app.go index e7e52d471..dc28ef84c 100755 --- a/java/app.go +++ b/java/app.go @@ -984,8 +984,11 @@ type appTestProperties struct { // The name of the android_app module that the tests will run against. Instrumentation_for *string - // if specified, the instrumentation target package name in the manifest is overwritten by it. + // If specified, the instrumentation target package name in the manifest is overwritten by it. Instrumentation_target_package *string + + // If specified, the mainline module package name in the test config is overwritten by it. + Mainline_package_name *string } type AndroidTest struct { @@ -1063,6 +1066,11 @@ func (a *AndroidTest) FixTestConfig(ctx android.ModuleContext, testConfig androi FlagWithArg("--package-name ", *a.overridableAppProperties.Package_name) } + if a.appTestProperties.Mainline_package_name != nil { + fixNeeded = true + command.FlagWithArg("--mainline-package-name ", *a.appTestProperties.Mainline_package_name) + } + if fixNeeded { rule.Build("fix_test_config", "fix test config") return fixedConfig diff --git a/java/app_test.go b/java/app_test.go index 3fb67c188..c77f29d23 100644 --- a/java/app_test.go +++ b/java/app_test.go @@ -2330,12 +2330,14 @@ func TestAndroidTest_FixTestConfig(t *testing.T) { srcs: ["b.java"], package_name: "com.android.bar.test", instrumentation_for: "foo", + mainline_package_name: "com.android.bar", } override_android_test { name: "baz_test", base: "foo_test", package_name: "com.android.baz.test", + mainline_package_name: "com.android.baz", } `) @@ -2354,6 +2356,7 @@ func TestAndroidTest_FixTestConfig(t *testing.T) { expectedFlags: []string{ "--manifest out/soong/.intermediates/bar_test/android_common/manifest_fixer/AndroidManifest.xml", "--package-name com.android.bar.test", + "--mainline-package-name com.android.bar", }, }, { @@ -2363,6 +2366,8 @@ func TestAndroidTest_FixTestConfig(t *testing.T) { "--manifest out/soong/.intermediates/foo_test/android_common_baz_test/manifest_fixer/AndroidManifest.xml", "--package-name com.android.baz.test", "--test-file-name baz_test.apk", + "out/soong/.intermediates/foo_test/android_common_baz_test/test_config_fixer/AndroidTest.xml", + "--mainline-package-name com.android.baz", }, }, } diff --git a/scripts/test_config_fixer.py b/scripts/test_config_fixer.py index 3dbc22ec2..07e01a14a 100644 --- a/scripts/test_config_fixer.py +++ b/scripts/test_config_fixer.py @@ -31,6 +31,8 @@ from manifest import write_xml KNOWN_PREPARERS = ['com.android.tradefed.targetprep.TestAppInstallSetup', 'com.android.tradefed.targetprep.suite.SuiteApkInstaller'] +MAINLINE_CONTROLLER = 'com.android.tradefed.testtype.suite.module.MainlineTestModuleController' + def parse_args(): """Parse commandline arguments.""" @@ -41,6 +43,8 @@ def parse_args(): help=('overwrite package fields in the test config')) parser.add_argument('--test-file-name', default='', dest='test_file_name', help=('overwrite test file name in the test config')) + parser.add_argument('--mainline-package-name', default='', dest='mainline_package_name', + help=('overwrite mainline module package name in the test config')) parser.add_argument('input', help='input test config file') parser.add_argument('output', help='output test config file') return parser.parse_args() @@ -72,6 +76,16 @@ def overwrite_test_file_name(test_config_doc, test_file_name): if option.getAttribute('name') == "test-file-name": option.setAttribute('value', test_file_name) +def overwrite_mainline_module_package_name(test_config_doc, mainline_package_name): + + test_config = parse_test_config(test_config_doc) + + for obj in get_children_with_tag(test_config, 'object'): + if obj.getAttribute('class') == MAINLINE_CONTROLLER: + for option in get_children_with_tag(obj, 'option'): + if option.getAttribute('name') == "mainline-module-package-name": + option.setAttribute('value', mainline_package_name) + def main(): """Program entry point.""" try: @@ -88,6 +102,9 @@ def main(): if args.test_file_name: overwrite_test_file_name(doc, args.test_file_name) + if args.mainline_package_name: + overwrite_mainline_module_package_name(doc, args.mainline_package_name) + with open(args.output, 'w') as f: write_xml(f, doc) diff --git a/scripts/test_config_fixer_test.py b/scripts/test_config_fixer_test.py index 39ce5b3c3..699f91eeb 100644 --- a/scripts/test_config_fixer_test.py +++ b/scripts/test_config_fixer_test.py @@ -23,6 +23,8 @@ from xml.dom import minidom import test_config_fixer +from manifest import write_xml + sys.dont_write_bytecode = True @@ -117,5 +119,39 @@ class OverwriteTestFileNameTest(unittest.TestCase): self.assertEqual(expected, output.getvalue()) +class OverwriteMainlineModulePackageNameTest(unittest.TestCase): + """ Unit tests for overwrite_mainline_module_package_name function """ + + test_config = ( + '<?xml version="1.0" encoding="utf-8"?>\n' + '<configuration description="Runs some tests.">\n' + ' <target_preparer class="com.android.tradefed.targetprep.TestAppInstallSetup">\n' + ' <option name="test-file-name" value="foo.apk"/>\n' + ' </target_preparer>\n' + ' <test class="com.android.tradefed.testtype.AndroidJUnitTest">\n' + ' <option name="package" value="com.android.foo"/>\n' + ' <option name="runtime-hint" value="20s"/>\n' + ' </test>\n' + ' <object type="module_controller" class="com.android.tradefed.testtype.suite.module.MainlineTestModuleController">\n' + ' <option name="enable" value="true"/>\n' + ' <option name="mainline-module-package-name" value="%s"/>\n' + ' </object>\n' + '</configuration>\n') + + def test_testappinstallsetup(self): + doc = minidom.parseString(self.test_config % ("com.android.old.package.name")) + + test_config_fixer.overwrite_mainline_module_package_name(doc, "com.android.new.package.name") + output = io.StringIO() + test_config_fixer.write_xml(output, doc) + + # Only the mainline module package name should be updated. Format the xml + # with minidom first to avoid mismatches due to trivial reformatting. + expected = io.StringIO() + write_xml(expected, minidom.parseString(self.test_config % ("com.android.new.package.name"))) + self.maxDiff = None + self.assertEqual(expected.getvalue(), output.getvalue()) + + if __name__ == '__main__': unittest.main(verbosity=2) |