summaryrefslogtreecommitdiffstats
path: root/tests
diff options
context:
space:
mode:
authorPaul Duffin <paulduffin@google.com>2017-12-05 18:36:57 +0000
committerPaul Duffin <paulduffin@google.com>2017-12-05 18:36:57 +0000
commit2e86be170a8d554e06c94856953f1856796b9c47 (patch)
treee93958168493db7fac421fca01664082dad76a3e /tests
parent9812a75c014a24f87fe9f65b8997dcb362f4c2e2 (diff)
downloadpackages_apps_Messaging-2e86be170a8d554e06c94856953f1856796b9c47.tar.gz
packages_apps_Messaging-2e86be170a8d554e06c94856953f1856796b9c47.tar.bz2
packages_apps_Messaging-2e86be170a8d554e06c94856953f1856796b9c47.zip
Flatten dependency hierarchy of legacy-android-test
Previous changes statically included legacy-android-test in preparation for removing android.test.* and junit.* classes from the android.jar. Unfortunately, that lead to duplicate classes between APKs and the bootclasspath which caused build problems (Proguard) and also runtime problems (when targeting and running on older releases). Switching from statically including the classes to using the runtime libraries cannot be done in one step because legacy-android-test is statically included in libraries which are used in many APKs and so removing it from those libraries requires that all APKs be updated at once. Doing that atomically across dozens of projects is not practical. This change modifies APKS that statically include the legacy-android-test library indirectly. * If the APK manifest uses the android.test.runner library then the APK is modified to stop statically including legacy-android-test and instead build against android.test.base/mock/runner libraries instead. * Otherwise, the APK statically includes legacy-android-test. Also, any libraries that statically include are modified to stop statically including it and if it has source dependencies on the classes is changed to build against the android.test.base/mock/runner libraries. The following change descriptions were generated automatically and so may be a little repetitive. They are provided to give the reviewer enough information to check the comments match what has actually been changed and check the reasoning behind the changes. * tests/Android.mk Replaced 'legacy-android-test' with 'android.test.runner.stubs' in LOCAL_JAVA_LIBRARIES because messagingtests's source depends on its classes. The classes do not need to be statically included because the classes will be provided by the runtime, either from the default bootclasspath or from the android.test.runner library that messagingtests specifies in its manifest. Bug: 30188076 Test: make checkbuild Change-Id: I7fa5bcf37c3b003c84ba5e493c6d675a619b6bcd
Diffstat (limited to 'tests')
-rw-r--r--tests/Android.mk2
1 files changed, 1 insertions, 1 deletions
diff --git a/tests/Android.mk b/tests/Android.mk
index b906684..ecdb8ab 100644
--- a/tests/Android.mk
+++ b/tests/Android.mk
@@ -32,7 +32,7 @@ LOCAL_CERTIFICATE := platform
LOCAL_STATIC_JAVA_LIBRARIES := \
mockito-target
-LOCAL_JAVA_LIBRARIES := android.test.mock.stubs legacy-android-test
+LOCAL_JAVA_LIBRARIES := android.test.mock.stubs android.test.runner.stubs
include $(BUILD_PACKAGE)