aboutsummaryrefslogtreecommitdiff
path: root/build/mainline_modules_sdks_test.py
diff options
context:
space:
mode:
authorMartin Stjernholm <mast@google.com>2022-02-24 15:20:58 +0000
committerMartin Stjernholm <mast@google.com>2022-03-28 12:30:46 +0100
commit576e65c5129dfb4a67ea69511443c19958f6f3e8 (patch)
tree8ecc7280222154b096a968dc154bcf4730c22817 /build/mainline_modules_sdks_test.py
parentaad984bea1c4aea1f4391cf3395a91793669c83b (diff)
downloadcommon-576e65c5129dfb4a67ea69511443c19958f6f3e8.tar.gz
Add support for building SDKs for bundled modules and platform SDKs for
Mainline. These are used in the ART thin manifest. They are added here to allow using the common module build scripts for them as well. The Python script is extended to work for these modules, and their SDKs end up in DIST_DIR/bundled-mainline-sdks, so DIST_DIR/mainline-sdks only carries the SDKs for unbundled modules that are to be distributed to partners etc. This change has the effect to (re)enable building these SDKs in CI. Test: env TARGET_BUILD_APPS="com.android.i18n com.android.runtime com.android.tzdata" \ packages/modules/common/build/mainline_modules_sdks.sh \ --build-platform-sdks-for-mainline --build-release=latest Replace SDK snapshots under prebuilts/runtime/mainline with those produced in out/dist/bundled-mainline-sdks in a master-art tree, with https://r.android.com/2046463 applied, then `banchan com.android.art && m` Test: env -u TARGET_BUILD_APPS \ packages/modules/common/build/mainline_modules_sdks.sh \ --build-release=latest Check that all SDKs are built, and that the bundled SDKs get copied to out/dist/bundled-mainline-sdks so the contents of out/dist/mainline-sdks and out/dist/stubs remain unchanged. Test: env -u TARGET_BUILD_APPS \ packages/modules/common/build/mainline_modules_sdks.sh \ --build-release=S Check that out/dist/bundled-mainline-sdks isn't producted. Test: env -u TARGET_BUILD_APPS \ vendor/google/build/mainline_modules_sdks.sh Check that all SDKs are built, and that the bundled SDKs get copied to out/dist/bundled-mainline-sdks so the contents of out/dist/mainline-sdks and out/dist/stubs remain unchanged. Test: atest --host mainline_modules_sdks_test Bug: 216762037 Change-Id: Ie6182fa42dc9c2c7f35ed95a040c05be0f0e878a
Diffstat (limited to 'build/mainline_modules_sdks_test.py')
-rw-r--r--build/mainline_modules_sdks_test.py316
1 files changed, 201 insertions, 115 deletions
diff --git a/build/mainline_modules_sdks_test.py b/build/mainline_modules_sdks_test.py
index 8d452bdd..084230e8 100644
--- a/build/mainline_modules_sdks_test.py
+++ b/build/mainline_modules_sdks_test.py
@@ -17,6 +17,7 @@
import re
from pathlib import Path
import os
+import shutil
import tempfile
import unittest
import zipfile
@@ -24,7 +25,10 @@ from unittest import mock
import mainline_modules_sdks as mm
-MAINLINE_MODULES_BY_APEX = dict((m.apex, m) for m in mm.MAINLINE_MODULES)
+MAINLINE_MODULES_BY_APEX = dict((m.apex, m) for m in (
+ mm.MAINLINE_MODULES +
+ mm.BUNDLED_MAINLINE_MODULES +
+ mm.PLATFORM_SDKS_FOR_MAINLINE))
class FakeSnapshotBuilder(mm.SnapshotBuilder):
@@ -67,116 +71,29 @@ class FakeSnapshotBuilder(mm.SnapshotBuilder):
class TestProduceDist(unittest.TestCase):
- def test(self):
- """Verify the dist/mainline-sdks directory is populated correctly"""
- with tempfile.TemporaryDirectory() as tmp_dir:
- tmp_out_dir = os.path.join(tmp_dir, "out")
- os.mkdir(tmp_out_dir)
- tmp_dist_dir = os.path.join(tmp_dir, "dist")
- os.mkdir(tmp_dist_dir)
-
- modules = [
- MAINLINE_MODULES_BY_APEX["com.android.art"],
- MAINLINE_MODULES_BY_APEX["com.android.ipsec"],
- # Create a google specific module.
- mm.aosp_to_google(MAINLINE_MODULES_BY_APEX["com.android.wifi"]),
- ]
-
- subprocess_runner = mm.SubprocessRunner()
-
- snapshot_builder = FakeSnapshotBuilder(
- tool_path="path/to/mainline_modules_sdks.sh",
- subprocess_runner=subprocess_runner,
- out_dir=tmp_out_dir,
- )
-
- build_releases = [
- mm.Q,
- mm.R,
- mm.S,
- mm.LATEST,
- mm.LEGACY_BUILD_RELEASE,
- ]
-
- producer = mm.SdkDistProducer(
- subprocess_runner=subprocess_runner,
- snapshot_builder=snapshot_builder,
- dist_dir=tmp_dist_dir,
- )
-
- producer.produce_dist(modules, build_releases)
-
- # pylint: disable=line-too-long
- self.assertEqual(
- [
- # Legacy copy of the snapshots, for use by tools that don't support build specific snapshots.
- "mainline-sdks/current/com.android.art/host-exports/art-module-host-exports-current.zip",
- "mainline-sdks/current/com.android.art/sdk/art-module-sdk-current.zip",
- "mainline-sdks/current/com.android.art/test-exports/art-module-test-exports-current.zip",
- "mainline-sdks/current/com.android.ipsec/sdk/ipsec-module-sdk-current.zip",
- "mainline-sdks/current/com.google.android.wifi/sdk/wifi-module-sdk-current.zip",
- # Build specific snapshots.
- "mainline-sdks/for-R-build/current/com.android.ipsec/sdk/ipsec-module-sdk-current.zip",
- "mainline-sdks/for-R-build/current/com.google.android.wifi/sdk/wifi-module-sdk-current.zip",
- "mainline-sdks/for-S-build/current/com.android.art/host-exports/art-module-host-exports-current.zip",
- "mainline-sdks/for-S-build/current/com.android.art/sdk/art-module-sdk-current.zip",
- "mainline-sdks/for-S-build/current/com.android.art/test-exports/art-module-test-exports-current.zip",
- "mainline-sdks/for-S-build/current/com.android.ipsec/sdk/ipsec-module-sdk-current.zip",
- "mainline-sdks/for-S-build/current/com.google.android.wifi/sdk/wifi-module-sdk-current.zip",
- "mainline-sdks/for-latest-build/current/com.android.art/host-exports/art-module-host-exports-current.zip",
- "mainline-sdks/for-latest-build/current/com.android.art/sdk/art-module-sdk-current.zip",
- "mainline-sdks/for-latest-build/current/com.android.art/test-exports/art-module-test-exports-current.zip",
- "mainline-sdks/for-latest-build/current/com.android.ipsec/sdk/ipsec-module-sdk-current.zip",
- "mainline-sdks/for-latest-build/current/com.google.android.wifi/sdk/wifi-module-sdk-current.zip",
- # Legacy stubs directory containing unpacked java_sdk_library artifacts.
- "stubs/com.android.art/sdk_library/public/art-removed.txt",
- "stubs/com.android.art/sdk_library/public/art-stubs.jar",
- "stubs/com.android.art/sdk_library/public/art.srcjar",
- "stubs/com.android.art/sdk_library/public/art.txt",
- "stubs/com.android.ipsec/sdk_library/public/android.net.ipsec.ike-removed.txt",
- "stubs/com.android.ipsec/sdk_library/public/android.net.ipsec.ike-stubs.jar",
- "stubs/com.android.ipsec/sdk_library/public/android.net.ipsec.ike.srcjar",
- "stubs/com.android.ipsec/sdk_library/public/android.net.ipsec.ike.txt",
- "stubs/com.google.android.wifi/sdk_library/public/framework-wifi-removed.txt",
- "stubs/com.google.android.wifi/sdk_library/public/framework-wifi-stubs.jar",
- "stubs/com.google.android.wifi/sdk_library/public/framework-wifi.srcjar",
- "stubs/com.google.android.wifi/sdk_library/public/framework-wifi.txt",
- ],
- sorted(self.list_files_in_dir(tmp_dist_dir)))
-
- r_snaphot_dir = os.path.join(
- tmp_out_dir, "soong/mainline-sdks/test/for-R-build")
- aosp_ipsec_r_bp_file = "com.android.ipsec/Android.bp"
- google_wifi_android_bp = "com.google.android.wifi/Android.bp"
- self.assertEqual([
- aosp_ipsec_r_bp_file,
- "com.android.ipsec/sdk_library/public/android.net.ipsec.ike-removed.txt",
- "com.android.ipsec/sdk_library/public/android.net.ipsec.ike-stubs.jar",
- "com.android.ipsec/sdk_library/public/android.net.ipsec.ike.srcjar",
- "com.android.ipsec/sdk_library/public/android.net.ipsec.ike.txt",
- google_wifi_android_bp,
- "com.google.android.wifi/sdk_library/public/framework-wifi-removed.txt",
- "com.google.android.wifi/sdk_library/public/framework-wifi-stubs.jar",
- "com.google.android.wifi/sdk_library/public/framework-wifi.srcjar",
- "com.google.android.wifi/sdk_library/public/framework-wifi.txt",
- "ipsec-module-sdk-current.zip",
- "wifi-module-sdk-current.zip",
- ], sorted(self.list_files_in_dir(r_snaphot_dir)))
-
- def read_r_snapshot_contents(path):
- abs_path = os.path.join(r_snaphot_dir, path)
- with open(abs_path, "r", encoding="utf8") as file:
- return file.read()
-
- # Check the contents of the AOSP ipsec module
- ipsec_contents = read_r_snapshot_contents(aosp_ipsec_r_bp_file)
- expected = read_test_data("ipsec_for_r_Android.bp")
- self.assertEqual(expected, ipsec_contents)
-
- # Check the contents of the Google ipsec module
- wifi_contents = read_r_snapshot_contents(google_wifi_android_bp)
- expected = read_test_data("google_wifi_for_r_Android.bp")
- self.assertEqual(expected, wifi_contents)
+ def setUp(self):
+ self.tmp_dir = tempfile.mkdtemp()
+ self.tmp_out_dir = os.path.join(self.tmp_dir, "out")
+ os.mkdir(self.tmp_out_dir)
+ self.tmp_dist_dir = os.path.join(self.tmp_dir, "dist")
+ os.mkdir(self.tmp_dist_dir)
+
+ def tearDown(self):
+ shutil.rmtree(self.tmp_dir, ignore_errors=True)
+
+ def produce_dist(self, modules, build_releases):
+ subprocess_runner = mm.SubprocessRunner()
+ snapshot_builder = FakeSnapshotBuilder(
+ tool_path="path/to/mainline_modules_sdks.sh",
+ subprocess_runner=subprocess_runner,
+ out_dir=self.tmp_out_dir,
+ )
+ producer = mm.SdkDistProducer(
+ subprocess_runner=subprocess_runner,
+ snapshot_builder=snapshot_builder,
+ dist_dir=self.tmp_dist_dir,
+ )
+ producer.produce_dist(modules, build_releases)
def list_files_in_dir(self, tmp_dist_dir):
files = []
@@ -188,6 +105,160 @@ class TestProduceDist(unittest.TestCase):
files.append(os.path.join(rel_dir, f))
return files
+ def test_unbundled_modules(self):
+ modules = [
+ MAINLINE_MODULES_BY_APEX["com.android.art"],
+ MAINLINE_MODULES_BY_APEX["com.android.ipsec"],
+ # Create a google specific module.
+ mm.aosp_to_google(MAINLINE_MODULES_BY_APEX["com.android.wifi"]),
+ ]
+ build_releases = [
+ mm.Q,
+ mm.R,
+ mm.S,
+ mm.LATEST,
+ mm.LEGACY_BUILD_RELEASE,
+ ]
+ self.produce_dist(modules, build_releases)
+
+ # pylint: disable=line-too-long
+ self.assertEqual(
+ [
+ # Legacy copy of the snapshots, for use by tools that don't support build specific snapshots.
+ "mainline-sdks/current/com.android.art/host-exports/art-module-host-exports-current.zip",
+ "mainline-sdks/current/com.android.art/sdk/art-module-sdk-current.zip",
+ "mainline-sdks/current/com.android.art/test-exports/art-module-test-exports-current.zip",
+ "mainline-sdks/current/com.android.ipsec/sdk/ipsec-module-sdk-current.zip",
+ "mainline-sdks/current/com.google.android.wifi/sdk/wifi-module-sdk-current.zip",
+ # Build specific snapshots.
+ "mainline-sdks/for-R-build/current/com.android.ipsec/sdk/ipsec-module-sdk-current.zip",
+ "mainline-sdks/for-R-build/current/com.google.android.wifi/sdk/wifi-module-sdk-current.zip",
+ "mainline-sdks/for-S-build/current/com.android.art/host-exports/art-module-host-exports-current.zip",
+ "mainline-sdks/for-S-build/current/com.android.art/sdk/art-module-sdk-current.zip",
+ "mainline-sdks/for-S-build/current/com.android.art/test-exports/art-module-test-exports-current.zip",
+ "mainline-sdks/for-S-build/current/com.android.ipsec/sdk/ipsec-module-sdk-current.zip",
+ "mainline-sdks/for-S-build/current/com.google.android.wifi/sdk/wifi-module-sdk-current.zip",
+ "mainline-sdks/for-latest-build/current/com.android.art/host-exports/art-module-host-exports-current.zip",
+ "mainline-sdks/for-latest-build/current/com.android.art/sdk/art-module-sdk-current.zip",
+ "mainline-sdks/for-latest-build/current/com.android.art/test-exports/art-module-test-exports-current.zip",
+ "mainline-sdks/for-latest-build/current/com.android.ipsec/sdk/ipsec-module-sdk-current.zip",
+ "mainline-sdks/for-latest-build/current/com.google.android.wifi/sdk/wifi-module-sdk-current.zip",
+ # Legacy stubs directory containing unpacked java_sdk_library artifacts.
+ "stubs/com.android.art/sdk_library/public/art-removed.txt",
+ "stubs/com.android.art/sdk_library/public/art-stubs.jar",
+ "stubs/com.android.art/sdk_library/public/art.srcjar",
+ "stubs/com.android.art/sdk_library/public/art.txt",
+ "stubs/com.android.ipsec/sdk_library/public/android.net.ipsec.ike-removed.txt",
+ "stubs/com.android.ipsec/sdk_library/public/android.net.ipsec.ike-stubs.jar",
+ "stubs/com.android.ipsec/sdk_library/public/android.net.ipsec.ike.srcjar",
+ "stubs/com.android.ipsec/sdk_library/public/android.net.ipsec.ike.txt",
+ "stubs/com.google.android.wifi/sdk_library/public/framework-wifi-removed.txt",
+ "stubs/com.google.android.wifi/sdk_library/public/framework-wifi-stubs.jar",
+ "stubs/com.google.android.wifi/sdk_library/public/framework-wifi.srcjar",
+ "stubs/com.google.android.wifi/sdk_library/public/framework-wifi.txt",
+ ],
+ sorted(self.list_files_in_dir(self.tmp_dist_dir)))
+
+ r_snaphot_dir = os.path.join(
+ self.tmp_out_dir, "soong/mainline-sdks/test/for-R-build")
+ aosp_ipsec_r_bp_file = "com.android.ipsec/Android.bp"
+ google_wifi_android_bp = "com.google.android.wifi/Android.bp"
+ self.assertEqual([
+ aosp_ipsec_r_bp_file,
+ "com.android.ipsec/sdk_library/public/android.net.ipsec.ike-removed.txt",
+ "com.android.ipsec/sdk_library/public/android.net.ipsec.ike-stubs.jar",
+ "com.android.ipsec/sdk_library/public/android.net.ipsec.ike.srcjar",
+ "com.android.ipsec/sdk_library/public/android.net.ipsec.ike.txt",
+ google_wifi_android_bp,
+ "com.google.android.wifi/sdk_library/public/framework-wifi-removed.txt",
+ "com.google.android.wifi/sdk_library/public/framework-wifi-stubs.jar",
+ "com.google.android.wifi/sdk_library/public/framework-wifi.srcjar",
+ "com.google.android.wifi/sdk_library/public/framework-wifi.txt",
+ "ipsec-module-sdk-current.zip",
+ "wifi-module-sdk-current.zip",
+ ], sorted(self.list_files_in_dir(r_snaphot_dir)))
+
+ def read_r_snapshot_contents(path):
+ abs_path = os.path.join(r_snaphot_dir, path)
+ with open(abs_path, "r", encoding="utf8") as file:
+ return file.read()
+
+ # Check the contents of the AOSP ipsec module
+ ipsec_contents = read_r_snapshot_contents(aosp_ipsec_r_bp_file)
+ expected = read_test_data("ipsec_for_r_Android.bp")
+ self.assertEqual(expected, ipsec_contents)
+
+ # Check the contents of the Google ipsec module
+ wifi_contents = read_r_snapshot_contents(google_wifi_android_bp)
+ expected = read_test_data("google_wifi_for_r_Android.bp")
+ self.assertEqual(expected, wifi_contents)
+
+ def test_old_release(self):
+ modules = [
+ MAINLINE_MODULES_BY_APEX["com.android.art"], # An unnbundled module
+ MAINLINE_MODULES_BY_APEX["com.android.runtime"], # A bundled module
+ MAINLINE_MODULES_BY_APEX["platform-mainline"], # Platform SDK
+ ]
+ build_releases = [mm.S]
+ self.produce_dist(modules, build_releases)
+
+ # pylint: disable=line-too-long
+ self.assertEqual(
+ [
+ "mainline-sdks/for-S-build/current/com.android.art/host-exports/art-module-host-exports-current.zip",
+ "mainline-sdks/for-S-build/current/com.android.art/sdk/art-module-sdk-current.zip",
+ "mainline-sdks/for-S-build/current/com.android.art/test-exports/art-module-test-exports-current.zip",
+ ],
+ sorted(self.list_files_in_dir(self.tmp_dist_dir)))
+
+ def test_latest_release(self):
+ modules = [
+ MAINLINE_MODULES_BY_APEX["com.android.art"], # An unnbundled module
+ MAINLINE_MODULES_BY_APEX["com.android.runtime"], # A bundled module
+ MAINLINE_MODULES_BY_APEX["platform-mainline"], # Platform SDK
+ ]
+ build_releases = [mm.LATEST]
+ self.produce_dist(modules, build_releases)
+
+ # pylint: disable=line-too-long
+ self.assertEqual(
+ [
+ # Bundled modules and platform SDKs.
+ "bundled-mainline-sdks/com.android.runtime/host-exports/runtime-module-host-exports-current.zip",
+ "bundled-mainline-sdks/com.android.runtime/sdk/runtime-module-sdk-current.zip",
+ "bundled-mainline-sdks/platform-mainline/sdk/platform-mainline-sdk-current.zip",
+ "bundled-mainline-sdks/platform-mainline/test-exports/platform-mainline-test-exports-current.zip",
+ # Unbundled (normal) modules.
+ "mainline-sdks/for-latest-build/current/com.android.art/host-exports/art-module-host-exports-current.zip",
+ "mainline-sdks/for-latest-build/current/com.android.art/sdk/art-module-sdk-current.zip",
+ "mainline-sdks/for-latest-build/current/com.android.art/test-exports/art-module-test-exports-current.zip",
+ ],
+ sorted(self.list_files_in_dir(self.tmp_dist_dir)))
+
+ def test_legacy_release(self):
+ modules = [
+ MAINLINE_MODULES_BY_APEX["com.android.art"], # An unnbundled module
+ MAINLINE_MODULES_BY_APEX["com.android.runtime"], # A bundled module
+ MAINLINE_MODULES_BY_APEX["platform-mainline"], # Platform SDK
+ ]
+ build_releases = [mm.LEGACY_BUILD_RELEASE]
+ self.produce_dist(modules, build_releases)
+
+ # pylint: disable=line-too-long
+ self.assertEqual(
+ [
+ # Legacy copy of the snapshots.
+ "mainline-sdks/current/com.android.art/host-exports/art-module-host-exports-current.zip",
+ "mainline-sdks/current/com.android.art/sdk/art-module-sdk-current.zip",
+ "mainline-sdks/current/com.android.art/test-exports/art-module-test-exports-current.zip",
+ # Legacy stubs directory containing unpacked java_sdk_library artifacts.
+ "stubs/com.android.art/sdk_library/public/art-removed.txt",
+ "stubs/com.android.art/sdk_library/public/art-stubs.jar",
+ "stubs/com.android.art/sdk_library/public/art.srcjar",
+ "stubs/com.android.art/sdk_library/public/art.txt",
+ ],
+ sorted(self.list_files_in_dir(self.tmp_dist_dir)))
+
def path_to_test_data(relative_path):
"""Construct a path to a test data file.
@@ -290,15 +361,30 @@ class TestSoongConfigBoilerplateInserter(unittest.TestCase):
class TestFilterModules(unittest.TestCase):
def test_no_filter(self):
- modules = mm.filter_modules(mm.MAINLINE_MODULES)
- self.assertEqual(modules, mm.MAINLINE_MODULES)
+ all_modules = mm.MAINLINE_MODULES + mm.BUNDLED_MAINLINE_MODULES
+ modules = mm.filter_modules(all_modules, None)
+ self.assertEqual(modules, all_modules)
def test_with_filter(self):
- os.environ["TARGET_BUILD_APPS"] = "com.android.art"
- modules = mm.filter_modules(mm.MAINLINE_MODULES)
+ modules = mm.filter_modules(mm.MAINLINE_MODULES, "com.android.art")
expected = MAINLINE_MODULES_BY_APEX["com.android.art"]
self.assertEqual(modules, [expected])
+class TestModuleProperties(unittest.TestCase):
+
+ def test_unbundled(self):
+ for module in mm.MAINLINE_MODULES:
+ with self.subTest(module=module):
+ self.assertFalse(module.is_bundled())
+
+ def test_bundled(self):
+ for module in (mm.BUNDLED_MAINLINE_MODULES +
+ mm.PLATFORM_SDKS_FOR_MAINLINE):
+ with self.subTest(module=module):
+ self.assertTrue(module.is_bundled())
+ self.assertEqual(module.first_release, mm.LATEST)
+
+
if __name__ == "__main__":
unittest.main(verbosity=2)