Add connectivity coverage tests

The coverage tests will allow measuring code coverage for all
Connectivity+Tethering code.

This is a combination of the current TetheringCoverageTests, and
FrameworksNetTests.

Adding min_sdk_version to the test prevents it from using deprecated
IoUtils utilities. Replace it with the non-deprecated alternative.

Bug: 187935317
Test: atest ConnectivityCoverageTests
Original-Change: https://android-review.googlesource.com/1731232
Merged-In: I5366e1cc9cd6ddb41f24718246381cc2b1cc1383
Change-Id: I5366e1cc9cd6ddb41f24718246381cc2b1cc1383
This commit is contained in:
Remi NGUYEN VAN
2021-06-21 13:36:05 +00:00
parent ad8f23fef4
commit 168b3d19f1
7 changed files with 127 additions and 9 deletions

View File

@@ -22,6 +22,7 @@ java_sdk_library {
defaults: ["framework-module-defaults"], defaults: ["framework-module-defaults"],
impl_library_visibility: [ impl_library_visibility: [
"//packages/modules/Connectivity/Tethering:__subpackages__", "//packages/modules/Connectivity/Tethering:__subpackages__",
"//packages/modules/Connectivity/tests:__subpackages__",
], ],
srcs: [":framework-tethering-srcs"], srcs: [":framework-tethering-srcs"],

View File

@@ -51,7 +51,8 @@ android_library {
defaults: ["TetheringIntegrationTestsDefaults"], defaults: ["TetheringIntegrationTestsDefaults"],
visibility: [ visibility: [
"//packages/modules/Connectivity/tests/cts/tethering", "//packages/modules/Connectivity/tests/cts/tethering",
"//packages/modules/Connectivity/Tethering/tests/mts", "//packages/modules/Connectivity/tests:__subpackages__",
"//packages/modules/Connectivity/Tethering/tests:__subpackages__",
] ]
} }
@@ -104,7 +105,6 @@ android_test {
"libnetworkstackutilsjni", "libnetworkstackutilsjni",
"libtetherutilsjni", "libtetherutilsjni",
], ],
jarjar_rules: ":TetheringTestsJarJarRules",
compile_multilib: "both", compile_multilib: "both",
manifest: "AndroidManifest_coverage.xml", manifest: "AndroidManifest_coverage.xml",
} }

View File

@@ -77,6 +77,7 @@ java_defaults {
"libstaticjvmtiagent", "libstaticjvmtiagent",
"libtetherutilsjni", "libtetherutilsjni",
], ],
jarjar_rules: ":TetheringTestsJarJarRules",
} }
// Library containing the unit tests. This is used by the coverage test target to pull in the // Library containing the unit tests. This is used by the coverage test target to pull in the
@@ -87,7 +88,8 @@ android_library {
defaults: ["TetheringTestsDefaults"], defaults: ["TetheringTestsDefaults"],
target_sdk_version: "30", target_sdk_version: "30",
visibility: [ visibility: [
"//packages/modules/Connectivity/Tethering/tests/integration", "//packages/modules/Connectivity/tests:__subpackages__",
"//packages/modules/Connectivity/Tethering/tests:__subpackages__",
] ]
} }
@@ -98,7 +100,6 @@ android_test {
"device-tests", "device-tests",
"mts", "mts",
], ],
jarjar_rules: ":TetheringTestsJarJarRules",
defaults: ["TetheringTestsDefaults"], defaults: ["TetheringTestsDefaults"],
compile_multilib: "both", compile_multilib: "both",
} }

View File

@@ -43,6 +43,53 @@ java_library {
], ],
} }
android_test {
name: "ConnectivityCoverageTests",
// Tethering started on SDK 30
min_sdk_version: "30",
// TODO: change to 31 as soon as it is available
target_sdk_version: "30",
test_suites: ["device-tests", "mts"],
defaults: [
"framework-connectivity-test-defaults",
"FrameworksNetTests-jni-defaults",
"libnetworkstackutilsjni_deps",
],
manifest: "AndroidManifest_coverage.xml",
test_config: "AndroidTest_Coverage.xml",
static_libs: [
// Added first so all tests use extended mockito, instead of all tests using regular mockito
// (some tests would fail).
// TODO: consider removing extended mockito usage in tests that use it, for performance
"mockito-target-extended-minus-junit4",
"FrameworksNetTestsLib",
"modules-utils-native-coverage-listener",
"NetdStaticLibTestsLib",
"NetworkStaticLibTestsLib",
"NetworkStackTestsLib",
"TetheringTestsLatestSdkLib",
"TetheringIntegrationTestsLatestSdkLib",
],
jni_libs: [
// For mockito extended
"libdexmakerjvmtiagent",
"libstaticjvmtiagent",
// For NetworkStackUtils included in NetworkStackBase
"libnetworkstackutilsjni",
"libtetherutilsjni",
// For framework tests
"libservice-connectivity",
],
libs: [
// Although not required to compile the static libs together, the "libs" used to build each
// of the common static test libs are necessary for R8 to avoid "Missing class" warnings and
// incorrect optimizations
"framework-tethering.impl",
"framework-wifi.stubs.module_lib",
],
compile_multilib: "both",
}
// defaults for tests that need to build against framework-connectivity's @hide APIs // defaults for tests that need to build against framework-connectivity's @hide APIs
// Only usable from targets that have visibility on framework-connectivity.impl. // Only usable from targets that have visibility on framework-connectivity.impl.
// Instead of using this, consider avoiding to depend on hidden connectivity APIs in // Instead of using this, consider avoiding to depend on hidden connectivity APIs in

View File

@@ -0,0 +1,29 @@
<?xml version="1.0" encoding="utf-8"?>
<!-- Copyright (C) 2021 The Android Open Source Project
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
-->
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
package="com.android.connectivity.tests.coverage">
<application tools:replace="android:label"
android:debuggable="true"
android:label="Connectivity coverage tests">
<uses-library android:name="android.test.runner" />
</application>
<instrumentation android:name="androidx.test.runner.AndroidJUnitRunner"
android:targetPackage="com.android.connectivity.tests.coverage"
android:label="Connectivity coverage tests">
</instrumentation>
</manifest>

View File

@@ -0,0 +1,27 @@
<!-- Copyright (C) 2021 The Android Open Source Project
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
-->
<configuration description="Runs coverage tests for Connectivity">
<target_preparer class="com.android.tradefed.targetprep.TestAppInstallSetup">
<option name="test-file-name" value="ConnectivityCoverageTests.apk" />
</target_preparer>
<option name="test-tag" value="ConnectivityCoverageTests" />
<test class="com.android.tradefed.testtype.AndroidJUnitTest" >
<option name="package" value="com.android.connectivity.tests.coverage" />
<option name="runner" value="androidx.test.runner.AndroidJUnitRunner" />
<option name="hidden-api-checks" value="false"/>
<option name="device-listeners" value="com.android.modules.utils.testing.NativeCoverageHackInstrumentationListener" />
</test>
</configuration>

View File

@@ -49,17 +49,16 @@ java_defaults {
], ],
} }
android_test { android_library {
name: "FrameworksNetTests", name: "FrameworksNetTestsLib",
min_sdk_version: "30",
defaults: [ defaults: [
"framework-connectivity-test-defaults", "framework-connectivity-test-defaults",
"FrameworksNetTests-jni-defaults",
], ],
srcs: [ srcs: [
"java/**/*.java", "java/**/*.java",
"java/**/*.kt", "java/**/*.kt",
], ],
test_suites: ["device-tests"],
jarjar_rules: "jarjar-rules.txt", jarjar_rules: "jarjar-rules.txt",
static_libs: [ static_libs: [
"androidx.test.rules", "androidx.test.rules",
@@ -83,7 +82,21 @@ android_test {
"android.test.mock", "android.test.mock",
"ServiceConnectivityResources", "ServiceConnectivityResources",
], ],
visibility: ["//packages/modules/Connectivity/tests:__subpackages__"],
}
android_test {
name: "FrameworksNetTests",
min_sdk_version: "30",
defaults: [
"framework-connectivity-test-defaults",
"FrameworksNetTests-jni-defaults",
],
test_suites: ["device-tests"],
static_libs: [
"FrameworksNetTestsLib",
],
jni_libs: [ jni_libs: [
"libservice-connectivity", "libservice-connectivity",
], ]
} }