Rename AvoidBadWifiTracker to MultinetworkPolicyTracker
Rename the class and ensure that all code related to bad wifi avoidance has names that reflect its purpose. This will allow us to reuse most of the the code for other purposes in future CLs. Test: runtest frameworks-net passes Bug: 34630278 Change-Id: Ida190e5a79e7a12f4eec07e1a3e4d9d138e83bcd
This commit is contained in:
@@ -78,7 +78,7 @@ import android.net.Uri;
|
|||||||
import android.net.metrics.DefaultNetworkEvent;
|
import android.net.metrics.DefaultNetworkEvent;
|
||||||
import android.net.metrics.IpConnectivityLog;
|
import android.net.metrics.IpConnectivityLog;
|
||||||
import android.net.metrics.NetworkEvent;
|
import android.net.metrics.NetworkEvent;
|
||||||
import android.net.util.AvoidBadWifiTracker;
|
import android.net.util.MultinetworkPolicyTracker;
|
||||||
import android.os.Binder;
|
import android.os.Binder;
|
||||||
import android.os.Build;
|
import android.os.Build;
|
||||||
import android.os.Bundle;
|
import android.os.Bundle;
|
||||||
@@ -499,7 +499,7 @@ public class ConnectivityService extends IConnectivityManager.Stub
|
|||||||
private final IpConnectivityLog mMetricsLog;
|
private final IpConnectivityLog mMetricsLog;
|
||||||
|
|
||||||
@VisibleForTesting
|
@VisibleForTesting
|
||||||
final AvoidBadWifiTracker mAvoidBadWifiTracker;
|
final MultinetworkPolicyTracker mMultinetworkPolicyTracker;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Implements support for the legacy "one network per network type" model.
|
* Implements support for the legacy "one network per network type" model.
|
||||||
@@ -849,9 +849,9 @@ public class ConnectivityService extends IConnectivityManager.Stub
|
|||||||
LingerMonitor.DEFAULT_NOTIFICATION_RATE_LIMIT_MILLIS);
|
LingerMonitor.DEFAULT_NOTIFICATION_RATE_LIMIT_MILLIS);
|
||||||
mLingerMonitor = new LingerMonitor(mContext, mNotifier, dailyLimit, rateLimit);
|
mLingerMonitor = new LingerMonitor(mContext, mNotifier, dailyLimit, rateLimit);
|
||||||
|
|
||||||
mAvoidBadWifiTracker = createAvoidBadWifiTracker(
|
mMultinetworkPolicyTracker = createMultinetworkPolicyTracker(
|
||||||
mContext, mHandler, () -> rematchForAvoidBadWifiUpdate());
|
mContext, mHandler, () -> rematchForAvoidBadWifiUpdate());
|
||||||
mAvoidBadWifiTracker.start();
|
mMultinetworkPolicyTracker.start();
|
||||||
}
|
}
|
||||||
|
|
||||||
private NetworkRequest createInternetRequestForTransport(
|
private NetworkRequest createInternetRequestForTransport(
|
||||||
@@ -2793,7 +2793,7 @@ public class ConnectivityService extends IConnectivityManager.Stub
|
|||||||
}
|
}
|
||||||
|
|
||||||
public boolean avoidBadWifi() {
|
public boolean avoidBadWifi() {
|
||||||
return mAvoidBadWifiTracker.currentValue();
|
return mMultinetworkPolicyTracker.getAvoidBadWifi();
|
||||||
}
|
}
|
||||||
|
|
||||||
private void rematchForAvoidBadWifiUpdate() {
|
private void rematchForAvoidBadWifiUpdate() {
|
||||||
@@ -2806,9 +2806,9 @@ public class ConnectivityService extends IConnectivityManager.Stub
|
|||||||
}
|
}
|
||||||
|
|
||||||
// TODO: Evaluate whether this is of interest to other consumers of
|
// TODO: Evaluate whether this is of interest to other consumers of
|
||||||
// AvoidBadWifiTracker and worth moving out of here.
|
// MultinetworkPolicyTracker and worth moving out of here.
|
||||||
private void dumpAvoidBadWifiSettings(IndentingPrintWriter pw) {
|
private void dumpAvoidBadWifiSettings(IndentingPrintWriter pw) {
|
||||||
final boolean configRestrict = mAvoidBadWifiTracker.configRestrictsAvoidBadWifi();
|
final boolean configRestrict = mMultinetworkPolicyTracker.configRestrictsAvoidBadWifi();
|
||||||
if (!configRestrict) {
|
if (!configRestrict) {
|
||||||
pw.println("Bad Wi-Fi avoidance: unrestricted");
|
pw.println("Bad Wi-Fi avoidance: unrestricted");
|
||||||
return;
|
return;
|
||||||
@@ -2818,7 +2818,7 @@ public class ConnectivityService extends IConnectivityManager.Stub
|
|||||||
pw.increaseIndent();
|
pw.increaseIndent();
|
||||||
pw.println("Config restrict: " + configRestrict);
|
pw.println("Config restrict: " + configRestrict);
|
||||||
|
|
||||||
final String value = mAvoidBadWifiTracker.getSettingsValue();
|
final String value = mMultinetworkPolicyTracker.getAvoidBadWifiSetting();
|
||||||
String description;
|
String description;
|
||||||
// Can't use a switch statement because strings are legal case labels, but null is not.
|
// Can't use a switch statement because strings are legal case labels, but null is not.
|
||||||
if ("0".equals(value)) {
|
if ("0".equals(value)) {
|
||||||
@@ -2886,7 +2886,7 @@ public class ConnectivityService extends IConnectivityManager.Stub
|
|||||||
if (DBG) log("handleNetworkUnvalidated " + nai.name() + " cap=" + nc);
|
if (DBG) log("handleNetworkUnvalidated " + nai.name() + " cap=" + nc);
|
||||||
|
|
||||||
if (nc.hasTransport(NetworkCapabilities.TRANSPORT_WIFI) &&
|
if (nc.hasTransport(NetworkCapabilities.TRANSPORT_WIFI) &&
|
||||||
mAvoidBadWifiTracker.shouldNotifyWifiUnvalidated()) {
|
mMultinetworkPolicyTracker.shouldNotifyWifiUnvalidated()) {
|
||||||
showValidationNotification(nai, NotificationType.LOST_INTERNET);
|
showValidationNotification(nai, NotificationType.LOST_INTERNET);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -5534,8 +5534,8 @@ public class ConnectivityService extends IConnectivityManager.Stub
|
|||||||
}
|
}
|
||||||
|
|
||||||
@VisibleForTesting
|
@VisibleForTesting
|
||||||
AvoidBadWifiTracker createAvoidBadWifiTracker(Context c, Handler h, Runnable r) {
|
MultinetworkPolicyTracker createMultinetworkPolicyTracker(Context c, Handler h, Runnable r) {
|
||||||
return new AvoidBadWifiTracker(c, h, r);
|
return new MultinetworkPolicyTracker(c, h, r);
|
||||||
}
|
}
|
||||||
|
|
||||||
@VisibleForTesting
|
@VisibleForTesting
|
||||||
|
|||||||
@@ -42,8 +42,8 @@ import static android.provider.Settings.Global.NETWORK_AVOID_BAD_WIFI;
|
|||||||
* This enables the device to switch to another form of connectivity, like
|
* This enables the device to switch to another form of connectivity, like
|
||||||
* mobile, if it's available and working.
|
* mobile, if it's available and working.
|
||||||
*
|
*
|
||||||
* The Runnable |cb|, if given, is called on the supplied Handler's thread
|
* The Runnable |avoidBadWifiCallback|, if given, is posted to the supplied
|
||||||
* whether the computed "avoid bad wifi" value changes.
|
* Handler' whenever the computed "avoid bad wifi" value changes.
|
||||||
*
|
*
|
||||||
* Disabling this reverts the device to a level of networking sophistication
|
* Disabling this reverts the device to a level of networking sophistication
|
||||||
* circa 2012-13 by disabling disparate code paths each of which contribute to
|
* circa 2012-13 by disabling disparate code paths each of which contribute to
|
||||||
@@ -51,28 +51,30 @@ import static android.provider.Settings.Global.NETWORK_AVOID_BAD_WIFI;
|
|||||||
*
|
*
|
||||||
* @hide
|
* @hide
|
||||||
*/
|
*/
|
||||||
public class AvoidBadWifiTracker {
|
public class MultinetworkPolicyTracker {
|
||||||
private static String TAG = AvoidBadWifiTracker.class.getSimpleName();
|
private static String TAG = MultinetworkPolicyTracker.class.getSimpleName();
|
||||||
|
|
||||||
private final Context mContext;
|
private final Context mContext;
|
||||||
private final Handler mHandler;
|
private final Handler mHandler;
|
||||||
private final Runnable mReevaluateRunnable;
|
private final Runnable mReevaluateRunnable;
|
||||||
private final Uri mUri;
|
private final Uri mAvoidBadWifiUri;
|
||||||
private final ContentResolver mResolver;
|
private final ContentResolver mResolver;
|
||||||
private final SettingObserver mSettingObserver;
|
private final SettingObserver mSettingObserver;
|
||||||
private final BroadcastReceiver mBroadcastReceiver;
|
private final BroadcastReceiver mBroadcastReceiver;
|
||||||
|
|
||||||
private volatile boolean mAvoidBadWifi = true;
|
private volatile boolean mAvoidBadWifi = true;
|
||||||
|
|
||||||
public AvoidBadWifiTracker(Context ctx, Handler handler) {
|
public MultinetworkPolicyTracker(Context ctx, Handler handler) {
|
||||||
this(ctx, handler, null);
|
this(ctx, handler, null);
|
||||||
}
|
}
|
||||||
|
|
||||||
public AvoidBadWifiTracker(Context ctx, Handler handler, Runnable cb) {
|
public MultinetworkPolicyTracker(Context ctx, Handler handler, Runnable avoidBadWifiCallback) {
|
||||||
mContext = ctx;
|
mContext = ctx;
|
||||||
mHandler = handler;
|
mHandler = handler;
|
||||||
mReevaluateRunnable = () -> { if (update() && cb != null) cb.run(); };
|
mReevaluateRunnable = () -> {
|
||||||
mUri = Settings.Global.getUriFor(NETWORK_AVOID_BAD_WIFI);
|
if (updateAvoidBadWifi() && avoidBadWifiCallback != null) avoidBadWifiCallback.run();
|
||||||
|
};
|
||||||
|
mAvoidBadWifiUri = Settings.Global.getUriFor(NETWORK_AVOID_BAD_WIFI);
|
||||||
mResolver = mContext.getContentResolver();
|
mResolver = mContext.getContentResolver();
|
||||||
mSettingObserver = new SettingObserver();
|
mSettingObserver = new SettingObserver();
|
||||||
mBroadcastReceiver = new BroadcastReceiver() {
|
mBroadcastReceiver = new BroadcastReceiver() {
|
||||||
@@ -82,11 +84,11 @@ public class AvoidBadWifiTracker {
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
update();
|
updateAvoidBadWifi();
|
||||||
}
|
}
|
||||||
|
|
||||||
public void start() {
|
public void start() {
|
||||||
mResolver.registerContentObserver(mUri, false, mSettingObserver);
|
mResolver.registerContentObserver(mAvoidBadWifiUri, false, mSettingObserver);
|
||||||
|
|
||||||
final IntentFilter intentFilter = new IntentFilter();
|
final IntentFilter intentFilter = new IntentFilter();
|
||||||
intentFilter.addAction(Intent.ACTION_CONFIGURATION_CHANGED);
|
intentFilter.addAction(Intent.ACTION_CONFIGURATION_CHANGED);
|
||||||
@@ -102,7 +104,7 @@ public class AvoidBadWifiTracker {
|
|||||||
mContext.unregisterReceiver(mBroadcastReceiver);
|
mContext.unregisterReceiver(mBroadcastReceiver);
|
||||||
}
|
}
|
||||||
|
|
||||||
public boolean currentValue() {
|
public boolean getAvoidBadWifi() {
|
||||||
return mAvoidBadWifi;
|
return mAvoidBadWifi;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -117,10 +119,10 @@ public class AvoidBadWifiTracker {
|
|||||||
* Whether we should display a notification when wifi becomes unvalidated.
|
* Whether we should display a notification when wifi becomes unvalidated.
|
||||||
*/
|
*/
|
||||||
public boolean shouldNotifyWifiUnvalidated() {
|
public boolean shouldNotifyWifiUnvalidated() {
|
||||||
return configRestrictsAvoidBadWifi() && getSettingsValue() == null;
|
return configRestrictsAvoidBadWifi() && getAvoidBadWifiSetting() == null;
|
||||||
}
|
}
|
||||||
|
|
||||||
public String getSettingsValue() {
|
public String getAvoidBadWifiSetting() {
|
||||||
return Settings.Global.getString(mResolver, NETWORK_AVOID_BAD_WIFI);
|
return Settings.Global.getString(mResolver, NETWORK_AVOID_BAD_WIFI);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -129,8 +131,8 @@ public class AvoidBadWifiTracker {
|
|||||||
mHandler.post(mReevaluateRunnable);
|
mHandler.post(mReevaluateRunnable);
|
||||||
}
|
}
|
||||||
|
|
||||||
public boolean update() {
|
public boolean updateAvoidBadWifi() {
|
||||||
final boolean settingAvoidBadWifi = "1".equals(getSettingsValue());
|
final boolean settingAvoidBadWifi = "1".equals(getAvoidBadWifiSetting());
|
||||||
final boolean prev = mAvoidBadWifi;
|
final boolean prev = mAvoidBadWifi;
|
||||||
mAvoidBadWifi = settingAvoidBadWifi || !configRestrictsAvoidBadWifi();
|
mAvoidBadWifi = settingAvoidBadWifi || !configRestrictsAvoidBadWifi();
|
||||||
return mAvoidBadWifi != prev;
|
return mAvoidBadWifi != prev;
|
||||||
@@ -148,7 +150,7 @@ public class AvoidBadWifiTracker {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onChange(boolean selfChange, Uri uri) {
|
public void onChange(boolean selfChange, Uri uri) {
|
||||||
if (!mUri.equals(uri)) return;
|
if (!mAvoidBadWifiUri.equals(uri)) return;
|
||||||
reevaluate();
|
reevaluate();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -53,7 +53,7 @@ import android.net.NetworkMisc;
|
|||||||
import android.net.NetworkRequest;
|
import android.net.NetworkRequest;
|
||||||
import android.net.RouteInfo;
|
import android.net.RouteInfo;
|
||||||
import android.net.metrics.IpConnectivityLog;
|
import android.net.metrics.IpConnectivityLog;
|
||||||
import android.net.util.AvoidBadWifiTracker;
|
import android.net.util.MultinetworkPolicyTracker;
|
||||||
import android.os.ConditionVariable;
|
import android.os.ConditionVariable;
|
||||||
import android.os.Handler;
|
import android.os.Handler;
|
||||||
import android.os.HandlerThread;
|
import android.os.HandlerThread;
|
||||||
@@ -593,10 +593,10 @@ public class ConnectivityServiceTest extends AndroidTestCase {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private class WrappedAvoidBadWifiTracker extends AvoidBadWifiTracker {
|
private class WrappedMultinetworkPolicyTracker extends MultinetworkPolicyTracker {
|
||||||
public volatile boolean configRestrictsAvoidBadWifi;
|
public volatile boolean configRestrictsAvoidBadWifi;
|
||||||
|
|
||||||
public WrappedAvoidBadWifiTracker(Context c, Handler h, Runnable r) {
|
public WrappedMultinetworkPolicyTracker(Context c, Handler h, Runnable r) {
|
||||||
super(c, h, r);
|
super(c, h, r);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -607,7 +607,7 @@ public class ConnectivityServiceTest extends AndroidTestCase {
|
|||||||
}
|
}
|
||||||
|
|
||||||
private class WrappedConnectivityService extends ConnectivityService {
|
private class WrappedConnectivityService extends ConnectivityService {
|
||||||
public WrappedAvoidBadWifiTracker wrappedAvoidBadWifiTracker;
|
public WrappedMultinetworkPolicyTracker wrappedMultinetworkPolicyTracker;
|
||||||
private WrappedNetworkMonitor mLastCreatedNetworkMonitor;
|
private WrappedNetworkMonitor mLastCreatedNetworkMonitor;
|
||||||
|
|
||||||
public WrappedConnectivityService(Context context, INetworkManagementService netManager,
|
public WrappedConnectivityService(Context context, INetworkManagementService netManager,
|
||||||
@@ -654,14 +654,14 @@ public class ConnectivityServiceTest extends AndroidTestCase {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public AvoidBadWifiTracker createAvoidBadWifiTracker(
|
public MultinetworkPolicyTracker createMultinetworkPolicyTracker(
|
||||||
Context c, Handler h, Runnable r) {
|
Context c, Handler h, Runnable r) {
|
||||||
final WrappedAvoidBadWifiTracker tracker = new WrappedAvoidBadWifiTracker(c, h, r);
|
final WrappedMultinetworkPolicyTracker tracker = new WrappedMultinetworkPolicyTracker(c, h, r);
|
||||||
return tracker;
|
return tracker;
|
||||||
}
|
}
|
||||||
|
|
||||||
public WrappedAvoidBadWifiTracker getAvoidBadWifiTracker() {
|
public WrappedMultinetworkPolicyTracker getMultinetworkPolicyTracker() {
|
||||||
return (WrappedAvoidBadWifiTracker) mAvoidBadWifiTracker;
|
return (WrappedMultinetworkPolicyTracker) mMultinetworkPolicyTracker;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@@ -2140,7 +2140,7 @@ public class ConnectivityServiceTest extends AndroidTestCase {
|
|||||||
@SmallTest
|
@SmallTest
|
||||||
public void testAvoidBadWifiSetting() throws Exception {
|
public void testAvoidBadWifiSetting() throws Exception {
|
||||||
final ContentResolver cr = mServiceContext.getContentResolver();
|
final ContentResolver cr = mServiceContext.getContentResolver();
|
||||||
final WrappedAvoidBadWifiTracker tracker = mService.getAvoidBadWifiTracker();
|
final WrappedMultinetworkPolicyTracker tracker = mService.getMultinetworkPolicyTracker();
|
||||||
final String settingName = Settings.Global.NETWORK_AVOID_BAD_WIFI;
|
final String settingName = Settings.Global.NETWORK_AVOID_BAD_WIFI;
|
||||||
|
|
||||||
tracker.configRestrictsAvoidBadWifi = false;
|
tracker.configRestrictsAvoidBadWifi = false;
|
||||||
@@ -2178,7 +2178,7 @@ public class ConnectivityServiceTest extends AndroidTestCase {
|
|||||||
@SmallTest
|
@SmallTest
|
||||||
public void testAvoidBadWifi() throws Exception {
|
public void testAvoidBadWifi() throws Exception {
|
||||||
final ContentResolver cr = mServiceContext.getContentResolver();
|
final ContentResolver cr = mServiceContext.getContentResolver();
|
||||||
final WrappedAvoidBadWifiTracker tracker = mService.getAvoidBadWifiTracker();
|
final WrappedMultinetworkPolicyTracker tracker = mService.getMultinetworkPolicyTracker();
|
||||||
|
|
||||||
// Pretend we're on a carrier that restricts switching away from bad wifi.
|
// Pretend we're on a carrier that restricts switching away from bad wifi.
|
||||||
tracker.configRestrictsAvoidBadWifi = true;
|
tracker.configRestrictsAvoidBadWifi = true;
|
||||||
|
|||||||
Reference in New Issue
Block a user