Merge changes from topic "ethernet_specifier"
* changes: Fix common tests on Q and R Add Ethernet, TestNetworkSpecifier API
This commit is contained in:
@@ -51,6 +51,14 @@ package android.net {
|
|||||||
field public static final String TEST_TAP_PREFIX = "testtap";
|
field public static final String TEST_TAP_PREFIX = "testtap";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public final class TestNetworkSpecifier extends android.net.NetworkSpecifier implements android.os.Parcelable {
|
||||||
|
ctor public TestNetworkSpecifier(@NonNull String);
|
||||||
|
method public int describeContents();
|
||||||
|
method @Nullable public String getInterfaceName();
|
||||||
|
method public void writeToParcel(@NonNull android.os.Parcel, int);
|
||||||
|
field @NonNull public static final android.os.Parcelable.Creator<android.net.TestNetworkSpecifier> CREATOR;
|
||||||
|
}
|
||||||
|
|
||||||
public final class VpnTransportInfo implements android.os.Parcelable android.net.TransportInfo {
|
public final class VpnTransportInfo implements android.os.Parcelable android.net.TransportInfo {
|
||||||
ctor public VpnTransportInfo(int);
|
ctor public VpnTransportInfo(int);
|
||||||
method public int describeContents();
|
method public int describeContents();
|
||||||
|
|||||||
@@ -31,6 +31,7 @@ import static android.net.NetworkCapabilities.NET_CAPABILITY_PARTIAL_CONNECTIVIT
|
|||||||
import static android.net.NetworkCapabilities.NET_CAPABILITY_TEMPORARILY_NOT_METERED;
|
import static android.net.NetworkCapabilities.NET_CAPABILITY_TEMPORARILY_NOT_METERED;
|
||||||
import static android.net.NetworkCapabilities.NET_CAPABILITY_TRUSTED;
|
import static android.net.NetworkCapabilities.NET_CAPABILITY_TRUSTED;
|
||||||
import static android.net.NetworkCapabilities.NET_CAPABILITY_VALIDATED;
|
import static android.net.NetworkCapabilities.NET_CAPABILITY_VALIDATED;
|
||||||
|
import static android.net.NetworkCapabilities.TRANSPORT_TEST;
|
||||||
|
|
||||||
import android.annotation.NonNull;
|
import android.annotation.NonNull;
|
||||||
import android.annotation.Nullable;
|
import android.annotation.Nullable;
|
||||||
@@ -387,11 +388,17 @@ public class NetworkRequest implements Parcelable {
|
|||||||
return setNetworkSpecifier(new TelephonyNetworkSpecifier.Builder()
|
return setNetworkSpecifier(new TelephonyNetworkSpecifier.Builder()
|
||||||
.setSubscriptionId(subId).build());
|
.setSubscriptionId(subId).build());
|
||||||
} catch (NumberFormatException nfe) {
|
} catch (NumberFormatException nfe) {
|
||||||
// A StringNetworkSpecifier does not accept null or empty ("") strings. When network
|
// An EthernetNetworkSpecifier or TestNetworkSpecifier does not accept null or empty
|
||||||
// specifiers were strings a null string and an empty string were considered
|
// ("") strings. When network specifiers were strings a null string and an empty
|
||||||
// equivalent. Hence no meaning is attached to a null or empty ("") string.
|
// string were considered equivalent. Hence no meaning is attached to a null or
|
||||||
return setNetworkSpecifier(TextUtils.isEmpty(networkSpecifier) ? null
|
// empty ("") string.
|
||||||
: new StringNetworkSpecifier(networkSpecifier));
|
if (TextUtils.isEmpty(networkSpecifier)) {
|
||||||
|
return setNetworkSpecifier((NetworkSpecifier) null);
|
||||||
|
} else if (mNetworkCapabilities.hasTransport(TRANSPORT_TEST)) {
|
||||||
|
return setNetworkSpecifier(new TestNetworkSpecifier(networkSpecifier));
|
||||||
|
} else {
|
||||||
|
return setNetworkSpecifier(new EthernetNetworkSpecifier(networkSpecifier));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
97
framework/src/android/net/TestNetworkSpecifier.java
Normal file
97
framework/src/android/net/TestNetworkSpecifier.java
Normal file
@@ -0,0 +1,97 @@
|
|||||||
|
/*
|
||||||
|
* 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.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package android.net;
|
||||||
|
|
||||||
|
import android.annotation.NonNull;
|
||||||
|
import android.annotation.Nullable;
|
||||||
|
import android.annotation.SystemApi;
|
||||||
|
import android.os.Parcel;
|
||||||
|
import android.os.Parcelable;
|
||||||
|
import android.text.TextUtils;
|
||||||
|
|
||||||
|
import com.android.internal.util.Preconditions;
|
||||||
|
|
||||||
|
import java.util.Objects;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* A {@link NetworkSpecifier} used to identify test interfaces.
|
||||||
|
*
|
||||||
|
* @see TestNetworkManager
|
||||||
|
* @hide
|
||||||
|
*/
|
||||||
|
@SystemApi(client = SystemApi.Client.MODULE_LIBRARIES)
|
||||||
|
public final class TestNetworkSpecifier extends NetworkSpecifier implements Parcelable {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Name of the network interface.
|
||||||
|
*/
|
||||||
|
@NonNull
|
||||||
|
private final String mInterfaceName;
|
||||||
|
|
||||||
|
public TestNetworkSpecifier(@NonNull String interfaceName) {
|
||||||
|
Preconditions.checkStringNotEmpty(interfaceName);
|
||||||
|
mInterfaceName = interfaceName;
|
||||||
|
}
|
||||||
|
|
||||||
|
// This may be null in the future to support specifiers based on data other than the interface
|
||||||
|
// name.
|
||||||
|
@Nullable
|
||||||
|
public String getInterfaceName() {
|
||||||
|
return mInterfaceName;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean canBeSatisfiedBy(@Nullable NetworkSpecifier other) {
|
||||||
|
return equals(other);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean equals(Object o) {
|
||||||
|
if (!(o instanceof TestNetworkSpecifier)) return false;
|
||||||
|
return TextUtils.equals(mInterfaceName, ((TestNetworkSpecifier) o).mInterfaceName);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int hashCode() {
|
||||||
|
return Objects.hashCode(mInterfaceName);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String toString() {
|
||||||
|
return "TestNetworkSpecifier (" + mInterfaceName + ")";
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int describeContents() {
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void writeToParcel(@NonNull Parcel dest, int flags) {
|
||||||
|
dest.writeString(mInterfaceName);
|
||||||
|
}
|
||||||
|
|
||||||
|
public static final @NonNull Creator<TestNetworkSpecifier> CREATOR =
|
||||||
|
new Creator<TestNetworkSpecifier>() {
|
||||||
|
public TestNetworkSpecifier createFromParcel(Parcel in) {
|
||||||
|
return new TestNetworkSpecifier(in.readString());
|
||||||
|
}
|
||||||
|
public TestNetworkSpecifier[] newArray(int size) {
|
||||||
|
return new TestNetworkSpecifier[size];
|
||||||
|
}
|
||||||
|
};
|
||||||
|
}
|
||||||
@@ -33,8 +33,8 @@ import android.net.NetworkAgentConfig;
|
|||||||
import android.net.NetworkCapabilities;
|
import android.net.NetworkCapabilities;
|
||||||
import android.net.NetworkProvider;
|
import android.net.NetworkProvider;
|
||||||
import android.net.RouteInfo;
|
import android.net.RouteInfo;
|
||||||
import android.net.StringNetworkSpecifier;
|
|
||||||
import android.net.TestNetworkInterface;
|
import android.net.TestNetworkInterface;
|
||||||
|
import android.net.TestNetworkSpecifier;
|
||||||
import android.net.util.NetdService;
|
import android.net.util.NetdService;
|
||||||
import android.os.Binder;
|
import android.os.Binder;
|
||||||
import android.os.Handler;
|
import android.os.Handler;
|
||||||
@@ -242,7 +242,7 @@ class TestNetworkService extends ITestNetworkManager.Stub {
|
|||||||
nc.addCapability(NetworkCapabilities.NET_CAPABILITY_NOT_SUSPENDED);
|
nc.addCapability(NetworkCapabilities.NET_CAPABILITY_NOT_SUSPENDED);
|
||||||
nc.addCapability(NetworkCapabilities.NET_CAPABILITY_NOT_RESTRICTED);
|
nc.addCapability(NetworkCapabilities.NET_CAPABILITY_NOT_RESTRICTED);
|
||||||
nc.addCapability(NetworkCapabilities.NET_CAPABILITY_NOT_VCN_MANAGED);
|
nc.addCapability(NetworkCapabilities.NET_CAPABILITY_NOT_VCN_MANAGED);
|
||||||
nc.setNetworkSpecifier(new StringNetworkSpecifier(iface));
|
nc.setNetworkSpecifier(new TestNetworkSpecifier(iface));
|
||||||
nc.setAdministratorUids(administratorUids);
|
nc.setAdministratorUids(administratorUids);
|
||||||
if (!isMetered) {
|
if (!isMetered) {
|
||||||
nc.addCapability(NetworkCapabilities.NET_CAPABILITY_NOT_METERED);
|
nc.addCapability(NetworkCapabilities.NET_CAPABILITY_NOT_METERED);
|
||||||
|
|||||||
@@ -68,6 +68,7 @@ import android.util.ArraySet;
|
|||||||
import androidx.test.runner.AndroidJUnit4;
|
import androidx.test.runner.AndroidJUnit4;
|
||||||
|
|
||||||
import com.android.modules.utils.build.SdkLevel;
|
import com.android.modules.utils.build.SdkLevel;
|
||||||
|
import com.android.testutils.CompatUtil;
|
||||||
import com.android.testutils.DevSdkIgnoreRule;
|
import com.android.testutils.DevSdkIgnoreRule;
|
||||||
import com.android.testutils.DevSdkIgnoreRule.IgnoreUpTo;
|
import com.android.testutils.DevSdkIgnoreRule.IgnoreUpTo;
|
||||||
|
|
||||||
@@ -211,7 +212,7 @@ public class NetworkCapabilitiesTest {
|
|||||||
nc1 = new NetworkCapabilities().addTransportType(TRANSPORT_WIFI);
|
nc1 = new NetworkCapabilities().addTransportType(TRANSPORT_WIFI);
|
||||||
nc2 = new NetworkCapabilities()
|
nc2 = new NetworkCapabilities()
|
||||||
.addTransportType(TRANSPORT_WIFI)
|
.addTransportType(TRANSPORT_WIFI)
|
||||||
.setNetworkSpecifier(new StringNetworkSpecifier("specs"));
|
.setNetworkSpecifier(CompatUtil.makeEthernetNetworkSpecifier("eth42"));
|
||||||
assertNotEquals("", nc1.describeImmutableDifferences(nc2));
|
assertNotEquals("", nc1.describeImmutableDifferences(nc2));
|
||||||
assertEquals("", nc1.describeImmutableDifferences(nc1));
|
assertEquals("", nc1.describeImmutableDifferences(nc1));
|
||||||
}
|
}
|
||||||
@@ -671,7 +672,7 @@ public class NetworkCapabilitiesTest {
|
|||||||
NetworkCapabilities nc1 = new NetworkCapabilities();
|
NetworkCapabilities nc1 = new NetworkCapabilities();
|
||||||
nc1.addTransportType(TRANSPORT_CELLULAR).addTransportType(TRANSPORT_WIFI);
|
nc1.addTransportType(TRANSPORT_CELLULAR).addTransportType(TRANSPORT_WIFI);
|
||||||
try {
|
try {
|
||||||
nc1.setNetworkSpecifier(new StringNetworkSpecifier("specs"));
|
nc1.setNetworkSpecifier(CompatUtil.makeEthernetNetworkSpecifier("eth0"));
|
||||||
fail("Cannot set NetworkSpecifier on a NetworkCapability with multiple transports!");
|
fail("Cannot set NetworkSpecifier on a NetworkCapability with multiple transports!");
|
||||||
} catch (IllegalStateException expected) {
|
} catch (IllegalStateException expected) {
|
||||||
// empty
|
// empty
|
||||||
@@ -680,7 +681,7 @@ public class NetworkCapabilitiesTest {
|
|||||||
// Sequence 2: Transport + NetworkSpecifier + Transport
|
// Sequence 2: Transport + NetworkSpecifier + Transport
|
||||||
NetworkCapabilities nc2 = new NetworkCapabilities();
|
NetworkCapabilities nc2 = new NetworkCapabilities();
|
||||||
nc2.addTransportType(TRANSPORT_CELLULAR).setNetworkSpecifier(
|
nc2.addTransportType(TRANSPORT_CELLULAR).setNetworkSpecifier(
|
||||||
new StringNetworkSpecifier("specs"));
|
CompatUtil.makeEthernetNetworkSpecifier("testtap3"));
|
||||||
try {
|
try {
|
||||||
nc2.addTransportType(TRANSPORT_WIFI);
|
nc2.addTransportType(TRANSPORT_WIFI);
|
||||||
fail("Cannot set a second TransportType of a network which has a NetworkSpecifier!");
|
fail("Cannot set a second TransportType of a network which has a NetworkSpecifier!");
|
||||||
|
|||||||
@@ -27,6 +27,7 @@ import android.os.HandlerThread
|
|||||||
import android.os.Looper
|
import android.os.Looper
|
||||||
import androidx.test.InstrumentationRegistry
|
import androidx.test.InstrumentationRegistry
|
||||||
import com.android.net.module.util.ArrayTrackRecord
|
import com.android.net.module.util.ArrayTrackRecord
|
||||||
|
import com.android.testutils.CompatUtil
|
||||||
import com.android.testutils.DevSdkIgnoreRule.IgnoreUpTo
|
import com.android.testutils.DevSdkIgnoreRule.IgnoreUpTo
|
||||||
import com.android.testutils.DevSdkIgnoreRunner
|
import com.android.testutils.DevSdkIgnoreRunner
|
||||||
import com.android.testutils.isDevSdkInRange
|
import com.android.testutils.isDevSdkInRange
|
||||||
@@ -102,7 +103,8 @@ class NetworkProviderTest {
|
|||||||
mCm.registerNetworkProvider(provider)
|
mCm.registerNetworkProvider(provider)
|
||||||
assertNotEquals(provider.getProviderId(), NetworkProvider.ID_NONE)
|
assertNotEquals(provider.getProviderId(), NetworkProvider.ID_NONE)
|
||||||
|
|
||||||
val specifier = StringNetworkSpecifier(UUID.randomUUID().toString())
|
val specifier = CompatUtil.makeTestNetworkSpecifier(
|
||||||
|
UUID.randomUUID().toString())
|
||||||
val nr: NetworkRequest = NetworkRequest.Builder()
|
val nr: NetworkRequest = NetworkRequest.Builder()
|
||||||
.addTransportType(TRANSPORT_TEST)
|
.addTransportType(TRANSPORT_TEST)
|
||||||
.setNetworkSpecifier(specifier)
|
.setNetworkSpecifier(specifier)
|
||||||
@@ -183,7 +185,8 @@ class NetworkProviderTest {
|
|||||||
|
|
||||||
mCm.registerNetworkProvider(provider)
|
mCm.registerNetworkProvider(provider)
|
||||||
|
|
||||||
val specifier = StringNetworkSpecifier(UUID.randomUUID().toString())
|
val specifier = CompatUtil.makeTestNetworkSpecifier(
|
||||||
|
UUID.randomUUID().toString())
|
||||||
val nr: NetworkRequest = NetworkRequest.Builder()
|
val nr: NetworkRequest = NetworkRequest.Builder()
|
||||||
.addTransportType(TRANSPORT_TEST)
|
.addTransportType(TRANSPORT_TEST)
|
||||||
.setNetworkSpecifier(specifier)
|
.setNetworkSpecifier(specifier)
|
||||||
|
|||||||
@@ -46,12 +46,12 @@ import android.content.Intent;
|
|||||||
import android.content.pm.ApplicationInfo;
|
import android.content.pm.ApplicationInfo;
|
||||||
import android.content.res.Resources;
|
import android.content.res.Resources;
|
||||||
import android.net.ConnectivityManager;
|
import android.net.ConnectivityManager;
|
||||||
|
import android.net.EthernetNetworkSpecifier;
|
||||||
import android.net.Network;
|
import android.net.Network;
|
||||||
import android.net.NetworkCapabilities;
|
import android.net.NetworkCapabilities;
|
||||||
import android.net.NetworkPolicy;
|
import android.net.NetworkPolicy;
|
||||||
import android.net.NetworkPolicyManager;
|
import android.net.NetworkPolicyManager;
|
||||||
import android.net.NetworkTemplate;
|
import android.net.NetworkTemplate;
|
||||||
import android.net.StringNetworkSpecifier;
|
|
||||||
import android.net.TelephonyNetworkSpecifier;
|
import android.net.TelephonyNetworkSpecifier;
|
||||||
import android.os.Handler;
|
import android.os.Handler;
|
||||||
import android.os.UserHandle;
|
import android.os.UserHandle;
|
||||||
@@ -240,7 +240,7 @@ public class MultipathPolicyTrackerTest {
|
|||||||
NetworkCapabilities capabilities = new NetworkCapabilities()
|
NetworkCapabilities capabilities = new NetworkCapabilities()
|
||||||
.addCapability(NET_CAPABILITY_INTERNET)
|
.addCapability(NET_CAPABILITY_INTERNET)
|
||||||
.addTransportType(TRANSPORT_CELLULAR)
|
.addTransportType(TRANSPORT_CELLULAR)
|
||||||
.setNetworkSpecifier(new StringNetworkSpecifier("234"));
|
.setNetworkSpecifier(new EthernetNetworkSpecifier("eth234"));
|
||||||
if (!roaming) {
|
if (!roaming) {
|
||||||
capabilities.addCapability(NET_CAPABILITY_NOT_ROAMING);
|
capabilities.addCapability(NET_CAPABILITY_NOT_ROAMING);
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user