Merge "Simplify per-target-SDK LinkProperties tests."
This commit is contained in:
@@ -36,10 +36,10 @@ import android.os.Build;
|
|||||||
import android.system.OsConstants;
|
import android.system.OsConstants;
|
||||||
import android.util.ArraySet;
|
import android.util.ArraySet;
|
||||||
|
|
||||||
import androidx.core.os.BuildCompat;
|
|
||||||
import androidx.test.filters.SmallTest;
|
import androidx.test.filters.SmallTest;
|
||||||
import androidx.test.runner.AndroidJUnit4;
|
import androidx.test.runner.AndroidJUnit4;
|
||||||
|
|
||||||
|
import com.android.modules.utils.build.SdkLevel;
|
||||||
import com.android.net.module.util.LinkPropertiesUtils.CompareResult;
|
import com.android.net.module.util.LinkPropertiesUtils.CompareResult;
|
||||||
import com.android.testutils.ConnectivityModuleTest;
|
import com.android.testutils.ConnectivityModuleTest;
|
||||||
import com.android.testutils.DevSdkIgnoreRule;
|
import com.android.testutils.DevSdkIgnoreRule;
|
||||||
@@ -114,11 +114,6 @@ public class LinkPropertiesTest {
|
|||||||
return InetAddresses.parseNumericAddress(addrString);
|
return InetAddresses.parseNumericAddress(addrString);
|
||||||
}
|
}
|
||||||
|
|
||||||
private static boolean isAtLeastR() {
|
|
||||||
// BuildCompat.isAtLeastR is documented to return false on release SDKs (including R)
|
|
||||||
return Build.VERSION.SDK_INT > Build.VERSION_CODES.Q || BuildCompat.isAtLeastR();
|
|
||||||
}
|
|
||||||
|
|
||||||
private void checkEmpty(final LinkProperties lp) {
|
private void checkEmpty(final LinkProperties lp) {
|
||||||
assertEquals(0, lp.getAllInterfaceNames().size());
|
assertEquals(0, lp.getAllInterfaceNames().size());
|
||||||
assertEquals(0, lp.getAllAddresses().size());
|
assertEquals(0, lp.getAllAddresses().size());
|
||||||
@@ -139,7 +134,7 @@ public class LinkPropertiesTest {
|
|||||||
assertFalse(lp.isIpv6Provisioned());
|
assertFalse(lp.isIpv6Provisioned());
|
||||||
assertFalse(lp.isPrivateDnsActive());
|
assertFalse(lp.isPrivateDnsActive());
|
||||||
|
|
||||||
if (isAtLeastR()) {
|
if (SdkLevel.isAtLeastR()) {
|
||||||
assertNull(lp.getDhcpServerAddress());
|
assertNull(lp.getDhcpServerAddress());
|
||||||
assertFalse(lp.isWakeOnLanSupported());
|
assertFalse(lp.isWakeOnLanSupported());
|
||||||
assertNull(lp.getCaptivePortalApiUrl());
|
assertNull(lp.getCaptivePortalApiUrl());
|
||||||
@@ -166,7 +161,7 @@ public class LinkPropertiesTest {
|
|||||||
lp.setMtu(MTU);
|
lp.setMtu(MTU);
|
||||||
lp.setTcpBufferSizes(TCP_BUFFER_SIZES);
|
lp.setTcpBufferSizes(TCP_BUFFER_SIZES);
|
||||||
lp.setNat64Prefix(new IpPrefix("2001:db8:0:64::/96"));
|
lp.setNat64Prefix(new IpPrefix("2001:db8:0:64::/96"));
|
||||||
if (isAtLeastR()) {
|
if (SdkLevel.isAtLeastR()) {
|
||||||
lp.setDhcpServerAddress(DHCPSERVER);
|
lp.setDhcpServerAddress(DHCPSERVER);
|
||||||
lp.setWakeOnLanSupported(true);
|
lp.setWakeOnLanSupported(true);
|
||||||
lp.setCaptivePortalApiUrl(CAPPORT_API_URL);
|
lp.setCaptivePortalApiUrl(CAPPORT_API_URL);
|
||||||
@@ -210,7 +205,7 @@ public class LinkPropertiesTest {
|
|||||||
assertTrue(source.isIdenticalTcpBufferSizes(target));
|
assertTrue(source.isIdenticalTcpBufferSizes(target));
|
||||||
assertTrue(target.isIdenticalTcpBufferSizes(source));
|
assertTrue(target.isIdenticalTcpBufferSizes(source));
|
||||||
|
|
||||||
if (isAtLeastR()) {
|
if (SdkLevel.isAtLeastR()) {
|
||||||
assertTrue(source.isIdenticalDhcpServerAddress(target));
|
assertTrue(source.isIdenticalDhcpServerAddress(target));
|
||||||
assertTrue(source.isIdenticalDhcpServerAddress(source));
|
assertTrue(source.isIdenticalDhcpServerAddress(source));
|
||||||
|
|
||||||
@@ -1295,56 +1290,73 @@ public class LinkPropertiesTest {
|
|||||||
assertEquals(2, lp.getRoutes().size());
|
assertEquals(2, lp.getRoutes().size());
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test @IgnoreUpTo(Build.VERSION_CODES.R)
|
private void assertExcludeRoutesVisible() {
|
||||||
@CtsNetTestCasesMaxTargetSdk31(reason = "Compat change cannot be overridden when targeting T+")
|
|
||||||
@EnableCompatChanges({LinkProperties.EXCLUDED_ROUTES})
|
|
||||||
public void testExcludedRoutesEnabled() {
|
|
||||||
final LinkProperties lp = new LinkProperties();
|
final LinkProperties lp = new LinkProperties();
|
||||||
assertEquals(0, lp.getRoutes().size());
|
assertEquals(0, lp.getRoutes().size());
|
||||||
|
|
||||||
lp.addRoute(new RouteInfo(new IpPrefix(ADDRV4, 0), RTN_UNREACHABLE));
|
lp.addRoute(new RouteInfo(new IpPrefix(ADDRV4, 31), RTN_UNREACHABLE));
|
||||||
assertEquals(1, lp.getRoutes().size());
|
assertEquals(1, lp.getRoutes().size());
|
||||||
|
|
||||||
lp.addRoute(new RouteInfo(new IpPrefix(ADDRV6, 0), RTN_THROW));
|
lp.addRoute(new RouteInfo(new IpPrefix(ADDRV6, 127), RTN_THROW));
|
||||||
assertEquals(2, lp.getRoutes().size());
|
assertEquals(2, lp.getRoutes().size());
|
||||||
|
|
||||||
lp.addRoute(new RouteInfo(GATEWAY1));
|
lp.addRoute(new RouteInfo(GATEWAY1));
|
||||||
assertEquals(3, lp.getRoutes().size());
|
assertEquals(3, lp.getRoutes().size());
|
||||||
|
|
||||||
|
lp.addRoute(new RouteInfo(new IpPrefix(DNS6, 127), RTN_UNICAST));
|
||||||
|
assertEquals(4, lp.getRoutes().size());
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test @IgnoreUpTo(Build.VERSION_CODES.R) @IgnoreAfter(Build.VERSION_CODES.S_V2)
|
private void assertExcludeRoutesNotVisible() {
|
||||||
@CtsNetTestCasesMaxTargetSdk31(reason = "Compat change cannot be overridden when targeting T+")
|
|
||||||
@DisableCompatChanges({LinkProperties.EXCLUDED_ROUTES})
|
|
||||||
public void testExcludedRoutesDisabled_S() {
|
|
||||||
final LinkProperties lp = new LinkProperties();
|
final LinkProperties lp = new LinkProperties();
|
||||||
assertEquals(0, lp.getRoutes().size());
|
assertEquals(0, lp.getRoutes().size());
|
||||||
|
|
||||||
lp.addRoute(new RouteInfo(new IpPrefix(ADDRV4, 0), RTN_UNREACHABLE));
|
lp.addRoute(new RouteInfo(new IpPrefix(ADDRV4, 31), RTN_UNREACHABLE));
|
||||||
|
assertEquals(0, lp.getRoutes().size());
|
||||||
|
|
||||||
|
lp.addRoute(new RouteInfo(new IpPrefix(ADDRV6, 127), RTN_THROW));
|
||||||
|
assertEquals(0, lp.getRoutes().size());
|
||||||
|
|
||||||
|
lp.addRoute(new RouteInfo(GATEWAY1));
|
||||||
assertEquals(1, lp.getRoutes().size());
|
assertEquals(1, lp.getRoutes().size());
|
||||||
|
|
||||||
lp.addRoute(new RouteInfo(new IpPrefix(ADDRV6, 5), RTN_THROW));
|
lp.addRoute(new RouteInfo(new IpPrefix(DNS6, 127), RTN_UNICAST));
|
||||||
// RTN_THROW routes are visible on S when added by the caller (but they are not added by
|
|
||||||
// the system). This is uncommon usage but was tested by CTSv12.
|
|
||||||
assertEquals(2, lp.getRoutes().size());
|
assertEquals(2, lp.getRoutes().size());
|
||||||
|
|
||||||
lp.addRoute(new RouteInfo(new IpPrefix(ADDRV6, 2), RTN_UNICAST));
|
|
||||||
assertEquals(3, lp.getRoutes().size());
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test @IgnoreUpTo(Build.VERSION_CODES.S_V2)
|
private void checkExcludeRoutesNotVisibleAfterS() {
|
||||||
|
if (!SdkLevel.isAtLeastT()) {
|
||||||
|
// RTN_THROW routes are visible on R and S when added by the caller (but they are not
|
||||||
|
// added by the system except for legacy VPN).
|
||||||
|
// This is uncommon usage but was tested by CTSr12.
|
||||||
|
assertExcludeRoutesVisible();
|
||||||
|
} else {
|
||||||
|
assertExcludeRoutesNotVisible();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test @IgnoreUpTo(Build.VERSION_CODES.R)
|
||||||
|
@CtsNetTestCasesMaxTargetSdk31(reason = "Testing behaviour for target SDK 31")
|
||||||
|
public void testExcludedRoutesNotVisibleOnTargetSdk31() {
|
||||||
|
checkExcludeRoutesNotVisibleAfterS();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testExcludedRoutesVisibleOnTargetSdk33AndAbove() {
|
||||||
|
assertExcludeRoutesVisible();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test @IgnoreUpTo(Build.VERSION_CODES.R)
|
||||||
|
@CtsNetTestCasesMaxTargetSdk31(reason = "Compat change cannot be overridden when targeting T+")
|
||||||
|
@EnableCompatChanges({LinkProperties.EXCLUDED_ROUTES})
|
||||||
|
public void testExcludedRoutesEnabledByCompatChange() {
|
||||||
|
assertExcludeRoutesVisible();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test @IgnoreUpTo(Build.VERSION_CODES.R)
|
||||||
@CtsNetTestCasesMaxTargetSdk31(reason = "Compat change cannot be overridden when targeting T+")
|
@CtsNetTestCasesMaxTargetSdk31(reason = "Compat change cannot be overridden when targeting T+")
|
||||||
@DisableCompatChanges({LinkProperties.EXCLUDED_ROUTES})
|
@DisableCompatChanges({LinkProperties.EXCLUDED_ROUTES})
|
||||||
public void testExcludedRoutesDisabled() {
|
public void testExcludedRoutesDisabledByCompatChange() {
|
||||||
final LinkProperties lp = new LinkProperties();
|
checkExcludeRoutesNotVisibleAfterS();
|
||||||
assertEquals(0, lp.getRoutes().size());
|
|
||||||
|
|
||||||
lp.addRoute(new RouteInfo(new IpPrefix(ADDRV4, 0), RTN_UNREACHABLE));
|
|
||||||
assertEquals(0, lp.getRoutes().size());
|
|
||||||
|
|
||||||
lp.addRoute(new RouteInfo(new IpPrefix(ADDRV6, 5), RTN_THROW));
|
|
||||||
assertEquals(0, lp.getRoutes().size());
|
|
||||||
|
|
||||||
lp.addRoute(new RouteInfo(new IpPrefix(ADDRV6, 2), RTN_UNICAST));
|
|
||||||
assertEquals(1, lp.getRoutes().size());
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -26,7 +26,6 @@ java_test_host {
|
|||||||
"tradefed",
|
"tradefed",
|
||||||
],
|
],
|
||||||
static_libs: [
|
static_libs: [
|
||||||
"CompatChangeGatingTestBase",
|
|
||||||
"modules-utils-build-testing",
|
"modules-utils-build-testing",
|
||||||
],
|
],
|
||||||
// Tag this module as a cts test artifact
|
// Tag this module as a cts test artifact
|
||||||
@@ -38,8 +37,6 @@ java_test_host {
|
|||||||
data: [
|
data: [
|
||||||
":CtsHostsideNetworkTestsApp",
|
":CtsHostsideNetworkTestsApp",
|
||||||
":CtsHostsideNetworkTestsApp2",
|
":CtsHostsideNetworkTestsApp2",
|
||||||
":CtsHostsideNetworkTestsApp3",
|
|
||||||
":CtsHostsideNetworkTestsApp3PreT",
|
|
||||||
":CtsHostsideNetworkTestsAppNext",
|
":CtsHostsideNetworkTestsAppNext",
|
||||||
],
|
],
|
||||||
per_testcase_directory: true,
|
per_testcase_directory: true,
|
||||||
|
|||||||
@@ -1,54 +0,0 @@
|
|||||||
//
|
|
||||||
// Copyright (C) 2022 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.
|
|
||||||
//
|
|
||||||
|
|
||||||
package {
|
|
||||||
default_applicable_licenses: ["Android-Apache-2.0"],
|
|
||||||
}
|
|
||||||
|
|
||||||
java_defaults {
|
|
||||||
name: "CtsHostsideNetworkTestsApp3Defaults",
|
|
||||||
srcs: ["src/**/*.java"],
|
|
||||||
libs: [
|
|
||||||
"junit",
|
|
||||||
],
|
|
||||||
static_libs: [
|
|
||||||
"ctstestrunner-axt",
|
|
||||||
"truth-prebuilt",
|
|
||||||
],
|
|
||||||
|
|
||||||
// Tag this module as a cts test artifact
|
|
||||||
test_suites: [
|
|
||||||
"cts",
|
|
||||||
"general-tests",
|
|
||||||
],
|
|
||||||
}
|
|
||||||
|
|
||||||
android_test_helper_app {
|
|
||||||
name: "CtsHostsideNetworkTestsApp3",
|
|
||||||
defaults: [
|
|
||||||
"cts_support_defaults",
|
|
||||||
"CtsHostsideNetworkTestsApp3Defaults",
|
|
||||||
],
|
|
||||||
}
|
|
||||||
|
|
||||||
android_test_helper_app {
|
|
||||||
name: "CtsHostsideNetworkTestsApp3PreT",
|
|
||||||
target_sdk_version: "31",
|
|
||||||
defaults: [
|
|
||||||
"cts_support_defaults",
|
|
||||||
"CtsHostsideNetworkTestsApp3Defaults",
|
|
||||||
],
|
|
||||||
}
|
|
||||||
@@ -1,27 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="utf-8"?>
|
|
||||||
<!-- Copyright (C) 2022 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"
|
|
||||||
package="com.android.cts.net.hostside.app3">
|
|
||||||
|
|
||||||
<application android:debuggable="true">
|
|
||||||
<uses-library android:name="android.test.runner" />
|
|
||||||
</application>
|
|
||||||
|
|
||||||
<instrumentation
|
|
||||||
android:name="androidx.test.runner.AndroidJUnitRunner"
|
|
||||||
android:targetPackage="com.android.cts.net.hostside.app3" />
|
|
||||||
|
|
||||||
</manifest>
|
|
||||||
@@ -1,80 +0,0 @@
|
|||||||
/*
|
|
||||||
* Copyright (C) 2022 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.
|
|
||||||
*/
|
|
||||||
|
|
||||||
package com.android.cts.net.hostside.app3;
|
|
||||||
|
|
||||||
import static org.junit.Assert.assertEquals;
|
|
||||||
|
|
||||||
import android.Manifest;
|
|
||||||
import android.net.IpPrefix;
|
|
||||||
import android.net.LinkProperties;
|
|
||||||
import android.net.RouteInfo;
|
|
||||||
|
|
||||||
import androidx.test.InstrumentationRegistry;
|
|
||||||
import androidx.test.runner.AndroidJUnit4;
|
|
||||||
|
|
||||||
import org.junit.After;
|
|
||||||
import org.junit.Before;
|
|
||||||
import org.junit.Test;
|
|
||||||
import org.junit.runner.RunWith;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Tests to verify {@link LinkProperties#getRoutes} behavior, depending on
|
|
||||||
* {@LinkProperties#EXCLUDED_ROUTES} change state.
|
|
||||||
*/
|
|
||||||
@RunWith(AndroidJUnit4.class)
|
|
||||||
public class ExcludedRoutesGatingTest {
|
|
||||||
@Before
|
|
||||||
public void setUp() {
|
|
||||||
InstrumentationRegistry.getInstrumentation().getUiAutomation()
|
|
||||||
.adoptShellPermissionIdentity(Manifest.permission.LOG_COMPAT_CHANGE,
|
|
||||||
Manifest.permission.READ_COMPAT_CHANGE_CONFIG);
|
|
||||||
}
|
|
||||||
|
|
||||||
@After
|
|
||||||
public void tearDown() {
|
|
||||||
InstrumentationRegistry.getInstrumentation().getUiAutomation()
|
|
||||||
.dropShellPermissionIdentity();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void testExcludedRoutesChangeEnabled() {
|
|
||||||
final LinkProperties lp = makeLinkPropertiesWithExcludedRoutes();
|
|
||||||
|
|
||||||
// Excluded routes change is enabled: non-RTN_UNICAST routes are visible.
|
|
||||||
assertEquals(2, lp.getRoutes().size());
|
|
||||||
assertEquals(2, lp.getAllRoutes().size());
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void testExcludedRoutesChangeDisabled() {
|
|
||||||
final LinkProperties lp = makeLinkPropertiesWithExcludedRoutes();
|
|
||||||
|
|
||||||
// Excluded routes change is disabled: non-RTN_UNICAST routes are filtered out.
|
|
||||||
assertEquals(0, lp.getRoutes().size());
|
|
||||||
assertEquals(0, lp.getAllRoutes().size());
|
|
||||||
}
|
|
||||||
|
|
||||||
private LinkProperties makeLinkPropertiesWithExcludedRoutes() {
|
|
||||||
final LinkProperties lp = new LinkProperties();
|
|
||||||
|
|
||||||
lp.addRoute(new RouteInfo(new IpPrefix("10.0.0.0/8"), null, null, RouteInfo.RTN_THROW));
|
|
||||||
lp.addRoute(new RouteInfo(new IpPrefix("2001:db8::/64"), null, null,
|
|
||||||
RouteInfo.RTN_UNREACHABLE));
|
|
||||||
|
|
||||||
return lp;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,85 +0,0 @@
|
|||||||
/*
|
|
||||||
* Copyright (C) 2022 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.
|
|
||||||
*/
|
|
||||||
|
|
||||||
package com.android.cts.net;
|
|
||||||
|
|
||||||
import android.compat.cts.CompatChangeGatingTestCase;
|
|
||||||
|
|
||||||
import java.util.Set;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Tests for the {@link android.net.LinkProperties#EXCLUDED_ROUTES} compatibility change.
|
|
||||||
*
|
|
||||||
* TODO: see if we can delete this cumbersome host test by moving the coverage to CtsNetTestCases
|
|
||||||
* and CtsNetTestCasesMaxTargetSdk31.
|
|
||||||
*/
|
|
||||||
public class HostsideLinkPropertiesGatingTests extends CompatChangeGatingTestCase {
|
|
||||||
private static final String TEST_APK = "CtsHostsideNetworkTestsApp3.apk";
|
|
||||||
private static final String TEST_APK_PRE_T = "CtsHostsideNetworkTestsApp3PreT.apk";
|
|
||||||
private static final String TEST_PKG = "com.android.cts.net.hostside.app3";
|
|
||||||
private static final String TEST_CLASS = ".ExcludedRoutesGatingTest";
|
|
||||||
|
|
||||||
private static final long EXCLUDED_ROUTES_CHANGE_ID = 186082280;
|
|
||||||
|
|
||||||
protected void tearDown() throws Exception {
|
|
||||||
uninstallPackage(TEST_PKG, true);
|
|
||||||
}
|
|
||||||
|
|
||||||
public void testExcludedRoutesChangeEnabled() throws Exception {
|
|
||||||
installPackage(TEST_APK, true);
|
|
||||||
runDeviceCompatTest("testExcludedRoutesChangeEnabled");
|
|
||||||
}
|
|
||||||
|
|
||||||
public void testExcludedRoutesChangeDisabledPreT() throws Exception {
|
|
||||||
installPackage(TEST_APK_PRE_T, true);
|
|
||||||
runDeviceCompatTest("testExcludedRoutesChangeDisabled");
|
|
||||||
}
|
|
||||||
|
|
||||||
public void testExcludedRoutesChangeDisabledByOverrideOnDebugBuild() throws Exception {
|
|
||||||
// Must install APK even when skipping test, because tearDown expects uninstall to succeed.
|
|
||||||
installPackage(TEST_APK, true);
|
|
||||||
|
|
||||||
// This test uses an app with a target SDK where the compat change is on by default.
|
|
||||||
// Because user builds do not allow overriding compat changes, only run this test on debug
|
|
||||||
// builds. This seems better than deleting this test and not running it anywhere because we
|
|
||||||
// could in the future run this test on userdebug builds in presubmit.
|
|
||||||
//
|
|
||||||
// We cannot use assumeXyz here because CompatChangeGatingTestCase ultimately inherits from
|
|
||||||
// junit.framework.TestCase, which does not understand assumption failures.
|
|
||||||
if ("user".equals(getDevice().getProperty("ro.build.type"))) return;
|
|
||||||
|
|
||||||
runDeviceCompatTestWithChangeDisabled("testExcludedRoutesChangeDisabled");
|
|
||||||
}
|
|
||||||
|
|
||||||
public void testExcludedRoutesChangeEnabledByOverridePreT() throws Exception {
|
|
||||||
installPackage(TEST_APK_PRE_T, true);
|
|
||||||
runDeviceCompatTestWithChangeEnabled("testExcludedRoutesChangeEnabled");
|
|
||||||
}
|
|
||||||
|
|
||||||
private void runDeviceCompatTest(String methodName) throws Exception {
|
|
||||||
runDeviceCompatTest(TEST_PKG, TEST_CLASS, methodName, Set.of(), Set.of());
|
|
||||||
}
|
|
||||||
|
|
||||||
private void runDeviceCompatTestWithChangeEnabled(String methodName) throws Exception {
|
|
||||||
runDeviceCompatTest(TEST_PKG, TEST_CLASS, methodName, Set.of(EXCLUDED_ROUTES_CHANGE_ID),
|
|
||||||
Set.of());
|
|
||||||
}
|
|
||||||
|
|
||||||
private void runDeviceCompatTestWithChangeDisabled(String methodName) throws Exception {
|
|
||||||
runDeviceCompatTest(TEST_PKG, TEST_CLASS, methodName, Set.of(),
|
|
||||||
Set.of(EXCLUDED_ROUTES_CHANGE_ID));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
Reference in New Issue
Block a user