summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorandroid-build-team Robot <android-build-team-robot@google.com>2020-06-02 07:02:58 +0000
committerandroid-build-team Robot <android-build-team-robot@google.com>2020-06-02 07:02:58 +0000
commit4b15c65a5857195bae1a7ba76a8992bf85bc058d (patch)
treebc666a6fa941674b31e19493cbeb04b3063d5330
parentc9b53f83ffe602788ca90fc63205ea05e2c731ca (diff)
parent7b0961dc0d3f2c3f811ba9c1c725eb3a22537f59 (diff)
downloadethernet-android11-mainline-sparse-2021-jan-release.tar.gz
Change-Id: Id8d8262de71d868b9d69ad8d8db40de86c40bb78
-rw-r--r--java/com/android/server/ethernet/EthernetTracker.java16
1 files changed, 12 insertions, 4 deletions
diff --git a/java/com/android/server/ethernet/EthernetTracker.java b/java/com/android/server/ethernet/EthernetTracker.java
index d37e0c9..d7fd408 100644
--- a/java/com/android/server/ethernet/EthernetTracker.java
+++ b/java/com/android/server/ethernet/EthernetTracker.java
@@ -70,6 +70,8 @@ final class EthernetTracker {
private final static String TAG = EthernetTracker.class.getSimpleName();
private final static boolean DBG = EthernetNetworkFactory.DBG;
+ private static final String TEST_IFACE_REGEXP = TEST_TAP_PREFIX + "\\d+";
+
/**
* Interface names we track. This is a product-dependent regular expression, plus,
* if setIncludeTestInterfaces is true, any test interfaces.
@@ -298,7 +300,8 @@ final class EthernetTracker {
// Try to resolve using mac address
nc = mNetworkCapabilities.get(hwAddress);
if (nc == null) {
- nc = createDefaultNetworkCapabilities();
+ final boolean isTestIface = iface.matches(TEST_IFACE_REGEXP);
+ nc = createDefaultNetworkCapabilities(isTestIface);
}
}
@@ -457,15 +460,20 @@ final class EthernetTracker {
}
}
- private static NetworkCapabilities createDefaultNetworkCapabilities() {
+ private static NetworkCapabilities createDefaultNetworkCapabilities(boolean isTestIface) {
NetworkCapabilities nc = createNetworkCapabilities(false /* clear default capabilities */);
- nc.addCapability(NetworkCapabilities.NET_CAPABILITY_INTERNET);
nc.addCapability(NetworkCapabilities.NET_CAPABILITY_NOT_RESTRICTED);
nc.addCapability(NetworkCapabilities.NET_CAPABILITY_NOT_METERED);
nc.addCapability(NetworkCapabilities.NET_CAPABILITY_NOT_ROAMING);
nc.addCapability(NetworkCapabilities.NET_CAPABILITY_NOT_CONGESTED);
nc.addCapability(NetworkCapabilities.NET_CAPABILITY_NOT_SUSPENDED);
+ if (isTestIface) {
+ nc.addTransportType(NetworkCapabilities.TRANSPORT_TEST);
+ } else {
+ nc.addCapability(NetworkCapabilities.NET_CAPABILITY_INTERNET);
+ }
+
return nc;
}
@@ -610,7 +618,7 @@ final class EthernetTracker {
final String match = mContext.getResources().getString(
com.android.internal.R.string.config_ethernet_iface_regex);
mIfaceMatch = mIncludeTestInterfaces
- ? "(" + match + "|" + TEST_TAP_PREFIX + "\\d+)"
+ ? "(" + match + "|" + TEST_IFACE_REGEXP + ")"
: match;
Log.d(TAG, "Interface match regexp set to '" + mIfaceMatch + "'");
}