Merge "Replace StringNetworkSpecifier & subId with TelephonyNetworkSpecifer" am: b2ff467a3a am: b5d058e25d am: 0fee898931
Change-Id: I9aee20185e189e51d537b6b0895fdc31c31d0ea2
This commit is contained in:
@@ -0,0 +1,82 @@
|
||||
/*
|
||||
* Copyright (C) 2018 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 android.net;
|
||||
|
||||
import static com.android.testutils.ParcelUtilsKt.assertParcelSane;
|
||||
|
||||
import static org.junit.Assert.assertEquals;
|
||||
|
||||
import android.telephony.SubscriptionManager;
|
||||
|
||||
import androidx.test.filters.SmallTest;
|
||||
|
||||
import org.junit.Test;
|
||||
|
||||
/**
|
||||
* Unit test for {@link android.net.TelephonyNetworkSpecifier}.
|
||||
*/
|
||||
@SmallTest
|
||||
public class TelephonyNetworkSpecifierTest {
|
||||
private static final int TEST_SUBID = 5;
|
||||
|
||||
/**
|
||||
* Validate that IllegalArgumentException will be thrown if build TelephonyNetworkSpecifier
|
||||
* without calling {@link TelephonyNetworkSpecifier.Builder#setSubscriptionId(int)}.
|
||||
*/
|
||||
@Test
|
||||
public void testBuilderBuildWithDefault() {
|
||||
try {
|
||||
new TelephonyNetworkSpecifier.Builder().build();
|
||||
} catch (IllegalArgumentException iae) {
|
||||
// expected, test pass
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Validate that no exception will be thrown even if pass invalid subscription id to
|
||||
* {@link TelephonyNetworkSpecifier.Builder#setSubscriptionId(int)}.
|
||||
*/
|
||||
@Test
|
||||
public void testBuilderBuildWithInvalidSubId() {
|
||||
TelephonyNetworkSpecifier specifier = new TelephonyNetworkSpecifier.Builder()
|
||||
.setSubscriptionId(SubscriptionManager.INVALID_SUBSCRIPTION_ID)
|
||||
.build();
|
||||
assertEquals(specifier.getSubscriptionId(), SubscriptionManager.INVALID_SUBSCRIPTION_ID);
|
||||
}
|
||||
|
||||
/**
|
||||
* Validate the correctness of TelephonyNetworkSpecifier when provide valid subId.
|
||||
*/
|
||||
@Test
|
||||
public void testBuilderBuildWithValidSubId() {
|
||||
final TelephonyNetworkSpecifier specifier = new TelephonyNetworkSpecifier.Builder()
|
||||
.setSubscriptionId(TEST_SUBID)
|
||||
.build();
|
||||
assertEquals(TEST_SUBID, specifier.getSubscriptionId());
|
||||
}
|
||||
|
||||
/**
|
||||
* Validate that parcel marshalling/unmarshalling works.
|
||||
*/
|
||||
@Test
|
||||
public void testParcel() {
|
||||
TelephonyNetworkSpecifier specifier = new TelephonyNetworkSpecifier.Builder()
|
||||
.setSubscriptionId(TEST_SUBID)
|
||||
.build();
|
||||
assertParcelSane(specifier, 1 /* fieldCount */);
|
||||
}
|
||||
}
|
||||
@@ -51,6 +51,7 @@ import android.net.NetworkPolicy;
|
||||
import android.net.NetworkPolicyManager;
|
||||
import android.net.NetworkTemplate;
|
||||
import android.net.StringNetworkSpecifier;
|
||||
import android.net.TelephonyNetworkSpecifier;
|
||||
import android.os.Handler;
|
||||
import android.provider.Settings;
|
||||
import android.telephony.TelephonyManager;
|
||||
@@ -229,7 +230,7 @@ public class MultipathPolicyTrackerTest {
|
||||
verify(mCM).registerNetworkCallback(any(), networkCallback.capture(), any());
|
||||
|
||||
// Simulate callback after capability changes
|
||||
final NetworkCapabilities capabilities = new NetworkCapabilities()
|
||||
NetworkCapabilities capabilities = new NetworkCapabilities()
|
||||
.addCapability(NET_CAPABILITY_INTERNET)
|
||||
.addTransportType(TRANSPORT_CELLULAR)
|
||||
.setNetworkSpecifier(new StringNetworkSpecifier("234"));
|
||||
@@ -239,6 +240,19 @@ public class MultipathPolicyTrackerTest {
|
||||
networkCallback.getValue().onCapabilitiesChanged(
|
||||
TEST_NETWORK,
|
||||
capabilities);
|
||||
|
||||
// make sure it also works with the new introduced TelephonyNetworkSpecifier
|
||||
capabilities = new NetworkCapabilities()
|
||||
.addCapability(NET_CAPABILITY_INTERNET)
|
||||
.addTransportType(TRANSPORT_CELLULAR)
|
||||
.setNetworkSpecifier(new TelephonyNetworkSpecifier.Builder()
|
||||
.setSubscriptionId(234).build());
|
||||
if (!roaming) {
|
||||
capabilities.addCapability(NET_CAPABILITY_NOT_ROAMING);
|
||||
}
|
||||
networkCallback.getValue().onCapabilitiesChanged(
|
||||
TEST_NETWORK,
|
||||
capabilities);
|
||||
}
|
||||
|
||||
@Test
|
||||
|
||||
Reference in New Issue
Block a user