summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorandroid-build-team Robot <android-build-team-robot@google.com>2020-06-03 01:02:25 +0000
committerandroid-build-team Robot <android-build-team-robot@google.com>2020-06-03 01:02:25 +0000
commit7c7a11b6e499ec3a1f7a5dfec961f8f67094147b (patch)
treebc666a6fa941674b31e19493cbeb04b3063d5330
parent51e0c4bbb19d693225ce36e57a594cec8af19ee5 (diff)
parent8193fea316ac37b71043c11d619b8b48ab6d5740 (diff)
downloadethernet-android11-d1-s1-release.tar.gz
Change-Id: Ifdf6651ba70e811d32ee2d778d46f8121724a5a7
-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 + "'");
}