Merge "[Provider Model] Hide Connectivity Subsystems when recovering" into sc-dev am: 80fd8a7cce
Original change: https://googleplex-android-review.googlesource.com/c/platform/packages/apps/Settings/+/15124033 Change-Id: I41129960093a168d8e4683a8aa3a548b87a18419
This commit is contained in:
262
src/com/android/settings/network/InternetResetHelper.java
Normal file
262
src/com/android/settings/network/InternetResetHelper.java
Normal file
@@ -0,0 +1,262 @@
|
|||||||
|
/*
|
||||||
|
* 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 com.android.settings.network;
|
||||||
|
|
||||||
|
import android.content.BroadcastReceiver;
|
||||||
|
import android.content.Context;
|
||||||
|
import android.content.Intent;
|
||||||
|
import android.content.IntentFilter;
|
||||||
|
import android.net.wifi.WifiManager;
|
||||||
|
import android.os.Handler;
|
||||||
|
import android.os.HandlerThread;
|
||||||
|
import android.os.Process;
|
||||||
|
import android.text.TextUtils;
|
||||||
|
import android.util.Log;
|
||||||
|
|
||||||
|
import androidx.annotation.UiThread;
|
||||||
|
import androidx.annotation.VisibleForTesting;
|
||||||
|
import androidx.annotation.WorkerThread;
|
||||||
|
import androidx.lifecycle.Lifecycle;
|
||||||
|
import androidx.lifecycle.LifecycleObserver;
|
||||||
|
import androidx.lifecycle.OnLifecycleEvent;
|
||||||
|
import androidx.preference.Preference;
|
||||||
|
import androidx.preference.PreferenceCategory;
|
||||||
|
|
||||||
|
import com.android.settingslib.connectivity.ConnectivitySubsystemsRecoveryManager;
|
||||||
|
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Helper class to restart connectivity for all requested subsystems.
|
||||||
|
*/
|
||||||
|
public class InternetResetHelper implements LifecycleObserver,
|
||||||
|
ConnectivitySubsystemsRecoveryManager.RecoveryStatusCallback {
|
||||||
|
|
||||||
|
protected static final String TAG = "InternetResetHelper";
|
||||||
|
public static final long RESTART_TIMEOUT_MS = 15_000; // 15 seconds
|
||||||
|
|
||||||
|
protected final Context mContext;
|
||||||
|
protected Preference mResettingPreference;
|
||||||
|
protected NetworkMobileProviderController mMobileNetworkController;
|
||||||
|
protected Preference mWifiTogglePreferences;
|
||||||
|
protected List<PreferenceCategory> mWifiNetworkPreferences =
|
||||||
|
new ArrayList<PreferenceCategory>();
|
||||||
|
|
||||||
|
protected final WifiManager mWifiManager;
|
||||||
|
protected final IntentFilter mWifiStateFilter;
|
||||||
|
protected final BroadcastReceiver mWifiStateReceiver = new BroadcastReceiver() {
|
||||||
|
@Override
|
||||||
|
@WorkerThread
|
||||||
|
public void onReceive(Context context, Intent intent) {
|
||||||
|
if (intent != null && TextUtils.equals(intent.getAction(),
|
||||||
|
WifiManager.NETWORK_STATE_CHANGED_ACTION)) {
|
||||||
|
updateWifiStateChange();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
protected ConnectivitySubsystemsRecoveryManager mConnectivitySubsystemsRecoveryManager;
|
||||||
|
protected HandlerThread mWorkerThread;
|
||||||
|
protected boolean mIsRecoveryReady;
|
||||||
|
protected boolean mIsWifiReady;
|
||||||
|
protected HandlerInjector mHandlerInjector;
|
||||||
|
protected final Runnable mResumeRunnable = () -> {
|
||||||
|
resumePreferences();
|
||||||
|
};
|
||||||
|
protected final Runnable mTimeoutRunnable = () -> {
|
||||||
|
mIsRecoveryReady = true;
|
||||||
|
mIsWifiReady = true;
|
||||||
|
resumePreferences();
|
||||||
|
};
|
||||||
|
|
||||||
|
public InternetResetHelper(Context context, Lifecycle lifecycle) {
|
||||||
|
mContext = context;
|
||||||
|
mHandlerInjector = new HandlerInjector(context);
|
||||||
|
mWifiManager = mContext.getSystemService(WifiManager.class);
|
||||||
|
mWifiStateFilter = new IntentFilter(WifiManager.NETWORK_STATE_CHANGED_ACTION);
|
||||||
|
|
||||||
|
mWorkerThread = new HandlerThread(TAG
|
||||||
|
+ "{" + Integer.toHexString(System.identityHashCode(this)) + "}",
|
||||||
|
Process.THREAD_PRIORITY_BACKGROUND);
|
||||||
|
mWorkerThread.start();
|
||||||
|
mConnectivitySubsystemsRecoveryManager = new ConnectivitySubsystemsRecoveryManager(
|
||||||
|
mContext, mWorkerThread.getThreadHandler());
|
||||||
|
|
||||||
|
if (lifecycle != null) {
|
||||||
|
lifecycle.addObserver(this);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/** @OnLifecycleEvent(Lifecycle.Event.ON_RESUME) */
|
||||||
|
@OnLifecycleEvent(Lifecycle.Event.ON_RESUME)
|
||||||
|
public void onResume() {
|
||||||
|
mContext.registerReceiver(mWifiStateReceiver, mWifiStateFilter);
|
||||||
|
}
|
||||||
|
|
||||||
|
/** @OnLifecycleEvent(Lifecycle.Event.ON_PAUSE) */
|
||||||
|
@OnLifecycleEvent(Lifecycle.Event.ON_PAUSE)
|
||||||
|
public void onPause() {
|
||||||
|
mContext.unregisterReceiver(mWifiStateReceiver);
|
||||||
|
}
|
||||||
|
|
||||||
|
/** @OnLifecycleEvent(Lifecycle.Event.ON_DESTROY) */
|
||||||
|
@OnLifecycleEvent(Lifecycle.Event.ON_DESTROY)
|
||||||
|
public void onDestroy() {
|
||||||
|
mHandlerInjector.removeCallbacks(mResumeRunnable);
|
||||||
|
mHandlerInjector.removeCallbacks(mTimeoutRunnable);
|
||||||
|
mWorkerThread.quit();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
@WorkerThread
|
||||||
|
public void onSubsystemRestartOperationBegin() {
|
||||||
|
Log.d(TAG, "The connectivity subsystem is starting for recovery.");
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
@WorkerThread
|
||||||
|
public void onSubsystemRestartOperationEnd() {
|
||||||
|
Log.d(TAG, "The connectivity subsystem is done for recovery.");
|
||||||
|
if (!mIsRecoveryReady) {
|
||||||
|
mIsRecoveryReady = true;
|
||||||
|
mHandlerInjector.postDelayed(mResumeRunnable, 0 /* delayMillis */);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@VisibleForTesting
|
||||||
|
@WorkerThread
|
||||||
|
protected void updateWifiStateChange() {
|
||||||
|
if (!mIsWifiReady && mWifiManager.isWifiEnabled()) {
|
||||||
|
Log.d(TAG, "The Wi-Fi subsystem is done for recovery.");
|
||||||
|
mIsWifiReady = true;
|
||||||
|
mHandlerInjector.postDelayed(mResumeRunnable, 0 /* delayMillis */);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Sets the resetting preference.
|
||||||
|
*/
|
||||||
|
@UiThread
|
||||||
|
public void setResettingPreference(Preference preference) {
|
||||||
|
mResettingPreference = preference;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Sets the mobile network controller.
|
||||||
|
*/
|
||||||
|
@UiThread
|
||||||
|
public void setMobileNetworkController(NetworkMobileProviderController controller) {
|
||||||
|
mMobileNetworkController = controller;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Sets the Wi-Fi toggle preference.
|
||||||
|
*/
|
||||||
|
@UiThread
|
||||||
|
public void setWifiTogglePreference(Preference preference) {
|
||||||
|
mWifiTogglePreferences = preference;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Adds the Wi-Fi network preference.
|
||||||
|
*/
|
||||||
|
@UiThread
|
||||||
|
public void addWifiNetworkPreference(PreferenceCategory preference) {
|
||||||
|
if (preference != null) {
|
||||||
|
mWifiNetworkPreferences.add(preference);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@UiThread
|
||||||
|
protected void suspendPreferences() {
|
||||||
|
Log.d(TAG, "Suspend the subsystem preferences");
|
||||||
|
if (mMobileNetworkController != null) {
|
||||||
|
mMobileNetworkController.hidePreference(true /* hide */, true /* immediately */);
|
||||||
|
}
|
||||||
|
if (mWifiTogglePreferences != null) {
|
||||||
|
mWifiTogglePreferences.setVisible(false);
|
||||||
|
}
|
||||||
|
for (PreferenceCategory pref : mWifiNetworkPreferences) {
|
||||||
|
pref.removeAll();
|
||||||
|
pref.setVisible(false);
|
||||||
|
}
|
||||||
|
if (mResettingPreference != null) {
|
||||||
|
mResettingPreference.setVisible(true);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@UiThread
|
||||||
|
protected void resumePreferences() {
|
||||||
|
if (mIsRecoveryReady && mMobileNetworkController != null) {
|
||||||
|
Log.d(TAG, "Resume the Mobile Network controller");
|
||||||
|
mMobileNetworkController.hidePreference(false /* hide */, false /* immediately */);
|
||||||
|
}
|
||||||
|
if (mIsWifiReady && mWifiTogglePreferences != null) {
|
||||||
|
Log.d(TAG, "Resume the Wi-Fi preferences");
|
||||||
|
mWifiTogglePreferences.setVisible(true);
|
||||||
|
for (PreferenceCategory pref : mWifiNetworkPreferences) {
|
||||||
|
pref.setVisible(true);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (mIsRecoveryReady && mIsWifiReady) {
|
||||||
|
mHandlerInjector.removeCallbacks(mTimeoutRunnable);
|
||||||
|
if (mResettingPreference != null) {
|
||||||
|
Log.d(TAG, "Resume the Resetting preference");
|
||||||
|
mResettingPreference.setVisible(false);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Restart connectivity for all requested subsystems.
|
||||||
|
*/
|
||||||
|
@UiThread
|
||||||
|
public void restart() {
|
||||||
|
if (!mConnectivitySubsystemsRecoveryManager.isRecoveryAvailable()) {
|
||||||
|
Log.e(TAG, "The connectivity subsystem is not available to restart.");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
Log.d(TAG, "The connectivity subsystem is restarting for recovery.");
|
||||||
|
suspendPreferences();
|
||||||
|
mIsRecoveryReady = false;
|
||||||
|
mIsWifiReady = !mWifiManager.isWifiEnabled();
|
||||||
|
mHandlerInjector.postDelayed(mTimeoutRunnable, RESTART_TIMEOUT_MS);
|
||||||
|
mConnectivitySubsystemsRecoveryManager.triggerSubsystemRestart(null /* reason */, this);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Wrapper for testing compatibility.
|
||||||
|
*/
|
||||||
|
@VisibleForTesting
|
||||||
|
static class HandlerInjector {
|
||||||
|
protected final Handler mHandler;
|
||||||
|
|
||||||
|
HandlerInjector(Context context) {
|
||||||
|
mHandler = context.getMainThreadHandler();
|
||||||
|
}
|
||||||
|
|
||||||
|
public void postDelayed(Runnable runnable, long delayMillis) {
|
||||||
|
mHandler.postDelayed(runnable, delayMillis);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void removeCallbacks(Runnable runnable) {
|
||||||
|
mHandler.removeCallbacks(runnable);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
@@ -50,6 +50,7 @@ public class NetworkMobileProviderController extends BasePreferenceController im
|
|||||||
private SubscriptionsPreferenceController mSubscriptionsController;
|
private SubscriptionsPreferenceController mSubscriptionsController;
|
||||||
|
|
||||||
private int mOriginalExpandedChildrenCount;
|
private int mOriginalExpandedChildrenCount;
|
||||||
|
private boolean mHide;
|
||||||
|
|
||||||
public NetworkMobileProviderController(Context context, String key) {
|
public NetworkMobileProviderController(Context context, String key) {
|
||||||
super(context, key);
|
super(context, key);
|
||||||
@@ -94,7 +95,7 @@ public class NetworkMobileProviderController extends BasePreferenceController im
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public int getAvailabilityStatus() {
|
public int getAvailabilityStatus() {
|
||||||
if (mSubscriptionsController == null) {
|
if (mHide || mSubscriptionsController == null) {
|
||||||
return CONDITIONALLY_UNAVAILABLE;
|
return CONDITIONALLY_UNAVAILABLE;
|
||||||
}
|
}
|
||||||
return mSubscriptionsController.isAvailable() ? AVAILABLE : CONDITIONALLY_UNAVAILABLE;
|
return mSubscriptionsController.isAvailable() ? AVAILABLE : CONDITIONALLY_UNAVAILABLE;
|
||||||
@@ -122,4 +123,14 @@ public class NetworkMobileProviderController extends BasePreferenceController im
|
|||||||
mSubscriptionsController.setWifiPickerTrackerHelper(helper);
|
mSubscriptionsController.setWifiPickerTrackerHelper(helper);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Hides the preference.
|
||||||
|
*/
|
||||||
|
public void hidePreference(boolean hide, boolean immediately) {
|
||||||
|
mHide = hide;
|
||||||
|
if (immediately) {
|
||||||
|
mPreferenceCategory.setVisible(hide ? false : isAvailable());
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@@ -32,9 +32,7 @@ import android.net.wifi.WifiConfiguration;
|
|||||||
import android.net.wifi.WifiManager;
|
import android.net.wifi.WifiManager;
|
||||||
import android.os.Bundle;
|
import android.os.Bundle;
|
||||||
import android.os.Handler;
|
import android.os.Handler;
|
||||||
import android.os.HandlerThread;
|
|
||||||
import android.os.PowerManager;
|
import android.os.PowerManager;
|
||||||
import android.os.Process;
|
|
||||||
import android.provider.Settings;
|
import android.provider.Settings;
|
||||||
import android.telephony.TelephonyManager;
|
import android.telephony.TelephonyManager;
|
||||||
import android.text.TextUtils;
|
import android.text.TextUtils;
|
||||||
@@ -78,7 +76,6 @@ import com.android.settings.wifi.dpp.WifiDppUtils;
|
|||||||
import com.android.settingslib.HelpUtils;
|
import com.android.settingslib.HelpUtils;
|
||||||
import com.android.settingslib.RestrictedLockUtils;
|
import com.android.settingslib.RestrictedLockUtils;
|
||||||
import com.android.settingslib.RestrictedLockUtilsInternal;
|
import com.android.settingslib.RestrictedLockUtilsInternal;
|
||||||
import com.android.settingslib.connectivity.ConnectivitySubsystemsRecoveryManager;
|
|
||||||
import com.android.settingslib.search.Indexable;
|
import com.android.settingslib.search.Indexable;
|
||||||
import com.android.settingslib.search.SearchIndexable;
|
import com.android.settingslib.search.SearchIndexable;
|
||||||
import com.android.settingslib.utils.ThreadUtils;
|
import com.android.settingslib.utils.ThreadUtils;
|
||||||
@@ -101,7 +98,6 @@ import java.util.Optional;
|
|||||||
public class NetworkProviderSettings extends RestrictedSettingsFragment
|
public class NetworkProviderSettings extends RestrictedSettingsFragment
|
||||||
implements Indexable, WifiPickerTracker.WifiPickerTrackerCallback,
|
implements Indexable, WifiPickerTracker.WifiPickerTrackerCallback,
|
||||||
WifiDialog2.WifiDialog2Listener, DialogInterface.OnDismissListener,
|
WifiDialog2.WifiDialog2Listener, DialogInterface.OnDismissListener,
|
||||||
ConnectivitySubsystemsRecoveryManager.RecoveryStatusCallback,
|
|
||||||
AirplaneModeEnabler.OnAirplaneModeChangedListener, InternetUpdater.InternetChangeListener {
|
AirplaneModeEnabler.OnAirplaneModeChangedListener, InternetUpdater.InternetChangeListener {
|
||||||
|
|
||||||
public static final String ACTION_NETWORK_PROVIDER_SETTINGS =
|
public static final String ACTION_NETWORK_PROVIDER_SETTINGS =
|
||||||
@@ -192,9 +188,7 @@ public class NetworkProviderSettings extends RestrictedSettingsFragment
|
|||||||
private WifiManager.ActionListener mSaveListener;
|
private WifiManager.ActionListener mSaveListener;
|
||||||
private WifiManager.ActionListener mForgetListener;
|
private WifiManager.ActionListener mForgetListener;
|
||||||
|
|
||||||
@VisibleForTesting
|
protected InternetResetHelper mInternetResetHelper;
|
||||||
protected ConnectivitySubsystemsRecoveryManager mConnectivitySubsystemsRecoveryManager;
|
|
||||||
private HandlerThread mRecoveryThread;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The state of {@link #isUiRestricted()} at {@link #onCreate(Bundle)}}. This is necessary to
|
* The state of {@link #isUiRestricted()} at {@link #onCreate(Bundle)}}. This is necessary to
|
||||||
@@ -1274,39 +1268,17 @@ public class NetworkProviderSettings extends RestrictedSettingsFragment
|
|||||||
}
|
}
|
||||||
|
|
||||||
private void fixConnectivity() {
|
private void fixConnectivity() {
|
||||||
if (mConnectivitySubsystemsRecoveryManager == null) {
|
if (mInternetResetHelper == null) {
|
||||||
mRecoveryThread = new HandlerThread(TAG
|
mInternetResetHelper = new InternetResetHelper(getContext(), getLifecycle());
|
||||||
+ "{" + Integer.toHexString(System.identityHashCode(this)) + "}",
|
mInternetResetHelper.setResettingPreference(mResetInternetPreference);
|
||||||
Process.THREAD_PRIORITY_BACKGROUND);
|
mInternetResetHelper.setMobileNetworkController(mNetworkMobileProviderController);
|
||||||
mRecoveryThread.start();
|
mInternetResetHelper.setWifiTogglePreference(
|
||||||
mConnectivitySubsystemsRecoveryManager = new ConnectivitySubsystemsRecoveryManager(
|
findPreference(WifiSwitchPreferenceController.KEY));
|
||||||
getContext(), mRecoveryThread.getThreadHandler());
|
mInternetResetHelper.addWifiNetworkPreference(mConnectedWifiEntryPreferenceCategory);
|
||||||
}
|
mInternetResetHelper.addWifiNetworkPreference(mFirstWifiEntryPreferenceCategory);
|
||||||
if (mConnectivitySubsystemsRecoveryManager.isRecoveryAvailable()) {
|
mInternetResetHelper.addWifiNetworkPreference(mWifiEntryPreferenceCategory);
|
||||||
mConnectivitySubsystemsRecoveryManager.triggerSubsystemRestart(null /* reason */, this);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Callback for the internet recovery started.
|
|
||||||
*/
|
|
||||||
public void onSubsystemRestartOperationBegin() {
|
|
||||||
if (mResetInternetPreference != null) {
|
|
||||||
mResetInternetPreference.setVisible(true);
|
|
||||||
}
|
|
||||||
updateAirplaneModeMsgPreference(false /* visible */);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Callback for the internet recovery ended.
|
|
||||||
*/
|
|
||||||
public void onSubsystemRestartOperationEnd() {
|
|
||||||
if (mResetInternetPreference != null) {
|
|
||||||
mResetInternetPreference.setVisible(false);
|
|
||||||
}
|
|
||||||
if (mAirplaneModeEnabler.isAirplaneModeOn()) {
|
|
||||||
updateAirplaneModeMsgPreference(true /* visible */);
|
|
||||||
}
|
}
|
||||||
|
mInternetResetHelper.restart();
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@@ -66,7 +66,6 @@ import com.android.settings.wifi.AddWifiNetworkPreference;
|
|||||||
import com.android.settings.wifi.ConnectedWifiEntryPreference;
|
import com.android.settings.wifi.ConnectedWifiEntryPreference;
|
||||||
import com.android.settings.wifi.WifiConfigController2;
|
import com.android.settings.wifi.WifiConfigController2;
|
||||||
import com.android.settings.wifi.WifiDialog2;
|
import com.android.settings.wifi.WifiDialog2;
|
||||||
import com.android.settingslib.connectivity.ConnectivitySubsystemsRecoveryManager;
|
|
||||||
import com.android.settingslib.widget.LayoutPreference;
|
import com.android.settingslib.widget.LayoutPreference;
|
||||||
import com.android.settingslib.wifi.LongPressWifiEntryPreference;
|
import com.android.settingslib.wifi.LongPressWifiEntryPreference;
|
||||||
import com.android.wifitrackerlib.WifiEntry;
|
import com.android.wifitrackerlib.WifiEntry;
|
||||||
@@ -105,7 +104,7 @@ public class NetworkProviderSettingsTest {
|
|||||||
@Mock
|
@Mock
|
||||||
private PreferenceManager mPreferenceManager;
|
private PreferenceManager mPreferenceManager;
|
||||||
@Mock
|
@Mock
|
||||||
private ConnectivitySubsystemsRecoveryManager mConnectivitySubsystemsRecoveryManager;
|
private InternetResetHelper mInternetResetHelper;
|
||||||
@Mock
|
@Mock
|
||||||
private Preference mAirplaneModeMsgPreference;
|
private Preference mAirplaneModeMsgPreference;
|
||||||
@Mock
|
@Mock
|
||||||
@@ -439,49 +438,14 @@ public class NetworkProviderSettingsTest {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void onOptionsItemSelected_fixConnectivity_triggerSubsystemRestart() {
|
public void onOptionsItemSelected_fixConnectivity_restartInternet() {
|
||||||
doReturn(true).when(mConnectivitySubsystemsRecoveryManager).isRecoveryAvailable();
|
mNetworkProviderSettings.mInternetResetHelper = mInternetResetHelper;
|
||||||
mNetworkProviderSettings.mConnectivitySubsystemsRecoveryManager =
|
|
||||||
mConnectivitySubsystemsRecoveryManager;
|
|
||||||
doReturn(false).when(mNetworkProviderSettings).isPhoneOnCall();
|
doReturn(false).when(mNetworkProviderSettings).isPhoneOnCall();
|
||||||
doReturn(NetworkProviderSettings.MENU_FIX_CONNECTIVITY).when(mMenuItem).getItemId();
|
doReturn(NetworkProviderSettings.MENU_FIX_CONNECTIVITY).when(mMenuItem).getItemId();
|
||||||
|
|
||||||
mNetworkProviderSettings.onOptionsItemSelected(mMenuItem);
|
mNetworkProviderSettings.onOptionsItemSelected(mMenuItem);
|
||||||
|
|
||||||
verify(mConnectivitySubsystemsRecoveryManager).triggerSubsystemRestart(any(), any());
|
verify(mInternetResetHelper).restart();
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void onOptionsItemSelected_fixConnectivityOnCall_neverTriggerSubsystemRestart() {
|
|
||||||
doReturn(true).when(mConnectivitySubsystemsRecoveryManager).isRecoveryAvailable();
|
|
||||||
mNetworkProviderSettings.mConnectivitySubsystemsRecoveryManager =
|
|
||||||
mConnectivitySubsystemsRecoveryManager;
|
|
||||||
doReturn(true).when(mNetworkProviderSettings).isPhoneOnCall();
|
|
||||||
doNothing().when(mNetworkProviderSettings).showResetInternetDialog();
|
|
||||||
doReturn(NetworkProviderSettings.MENU_FIX_CONNECTIVITY).when(mMenuItem).getItemId();
|
|
||||||
|
|
||||||
mNetworkProviderSettings.onOptionsItemSelected(mMenuItem);
|
|
||||||
|
|
||||||
verify(mConnectivitySubsystemsRecoveryManager, never()).triggerSubsystemRestart(any(),
|
|
||||||
any());
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void onSubsystemRestartOperationBegin_showResetInternetHideApmMsg() {
|
|
||||||
mNetworkProviderSettings.onSubsystemRestartOperationBegin();
|
|
||||||
|
|
||||||
verify(mResetInternetPreference).setVisible(true);
|
|
||||||
verify(mAirplaneModeMsgPreference).setVisible(false);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void onSubsystemRestartOperationEnd_showApmMsgHideResetInternet() {
|
|
||||||
doReturn(true).when(mAirplaneModeEnabler).isAirplaneModeOn();
|
|
||||||
|
|
||||||
mNetworkProviderSettings.onSubsystemRestartOperationEnd();
|
|
||||||
|
|
||||||
verify(mResetInternetPreference).setVisible(false);
|
|
||||||
verify(mAirplaneModeMsgPreference).setVisible(true);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
|
@@ -0,0 +1,282 @@
|
|||||||
|
/*
|
||||||
|
* 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 com.android.settings.network;
|
||||||
|
|
||||||
|
import static com.google.common.truth.Truth.assertThat;
|
||||||
|
|
||||||
|
import static org.mockito.ArgumentMatchers.any;
|
||||||
|
import static org.mockito.Mockito.mock;
|
||||||
|
import static org.mockito.Mockito.never;
|
||||||
|
import static org.mockito.Mockito.spy;
|
||||||
|
import static org.mockito.Mockito.verify;
|
||||||
|
import static org.mockito.Mockito.when;
|
||||||
|
|
||||||
|
import android.content.BroadcastReceiver;
|
||||||
|
import android.content.Context;
|
||||||
|
import android.content.IntentFilter;
|
||||||
|
import android.net.wifi.WifiManager;
|
||||||
|
import android.os.HandlerThread;
|
||||||
|
import android.os.Looper;
|
||||||
|
|
||||||
|
import androidx.lifecycle.Lifecycle;
|
||||||
|
import androidx.preference.Preference;
|
||||||
|
import androidx.preference.PreferenceCategory;
|
||||||
|
import androidx.test.core.app.ApplicationProvider;
|
||||||
|
import androidx.test.ext.junit.runners.AndroidJUnit4;
|
||||||
|
|
||||||
|
import com.android.settingslib.connectivity.ConnectivitySubsystemsRecoveryManager;
|
||||||
|
|
||||||
|
import org.junit.Before;
|
||||||
|
import org.junit.Rule;
|
||||||
|
import org.junit.Test;
|
||||||
|
import org.junit.runner.RunWith;
|
||||||
|
import org.mockito.Mock;
|
||||||
|
import org.mockito.junit.MockitoJUnit;
|
||||||
|
import org.mockito.junit.MockitoRule;
|
||||||
|
|
||||||
|
@RunWith(AndroidJUnit4.class)
|
||||||
|
public class InternetResetHelperTest {
|
||||||
|
|
||||||
|
@Rule
|
||||||
|
public final MockitoRule mMockitoRule = MockitoJUnit.rule();
|
||||||
|
@Mock
|
||||||
|
private WifiManager mWifiManager;
|
||||||
|
@Mock
|
||||||
|
public HandlerThread mWorkerThread;
|
||||||
|
@Mock
|
||||||
|
public ConnectivitySubsystemsRecoveryManager mConnectivitySubsystemsRecoveryManager;
|
||||||
|
@Mock
|
||||||
|
public NetworkMobileProviderController mMobileNetworkController;
|
||||||
|
|
||||||
|
private Context mContext;
|
||||||
|
private InternetResetHelper mInternetResetHelper;
|
||||||
|
private Preference mResettingPreference;
|
||||||
|
private Preference mWifiTogglePreferences;
|
||||||
|
private PreferenceCategory mConnectedWifiEntryPreferences;
|
||||||
|
private PreferenceCategory mWifiEntryPreferences;
|
||||||
|
|
||||||
|
private FakeHandlerInjector mFakeHandlerInjector;
|
||||||
|
|
||||||
|
private static class FakeHandlerInjector extends InternetResetHelper.HandlerInjector {
|
||||||
|
|
||||||
|
private Runnable mRunnable;
|
||||||
|
|
||||||
|
FakeHandlerInjector(Context context) {
|
||||||
|
super(context);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void postDelayed(Runnable runnable, long delayMillis) {
|
||||||
|
mRunnable = runnable;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Runnable getRunnable() {
|
||||||
|
return mRunnable;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Before
|
||||||
|
public void setUp() {
|
||||||
|
mContext = spy(ApplicationProvider.getApplicationContext());
|
||||||
|
when(mContext.getSystemService(WifiManager.class)).thenReturn(mWifiManager);
|
||||||
|
if (Looper.myLooper() == null) {
|
||||||
|
Looper.prepare();
|
||||||
|
}
|
||||||
|
mResettingPreference = new Preference(mContext);
|
||||||
|
mWifiTogglePreferences = new Preference(mContext);
|
||||||
|
mConnectedWifiEntryPreferences = spy(new PreferenceCategory(mContext));
|
||||||
|
mWifiEntryPreferences = spy(new PreferenceCategory(mContext));
|
||||||
|
|
||||||
|
final Lifecycle lifecycle = mock(Lifecycle.class);
|
||||||
|
mInternetResetHelper = new InternetResetHelper(mContext, lifecycle);
|
||||||
|
mInternetResetHelper.mWorkerThread = mWorkerThread;
|
||||||
|
mFakeHandlerInjector = new FakeHandlerInjector(mContext);
|
||||||
|
mInternetResetHelper.mHandlerInjector = mFakeHandlerInjector;
|
||||||
|
mInternetResetHelper.mConnectivitySubsystemsRecoveryManager =
|
||||||
|
mConnectivitySubsystemsRecoveryManager;
|
||||||
|
mInternetResetHelper.setResettingPreference(mResettingPreference);
|
||||||
|
mInternetResetHelper.setMobileNetworkController(mMobileNetworkController);
|
||||||
|
mInternetResetHelper.setWifiTogglePreference(mWifiTogglePreferences);
|
||||||
|
mInternetResetHelper.addWifiNetworkPreference(mConnectedWifiEntryPreferences);
|
||||||
|
mInternetResetHelper.addWifiNetworkPreference(mWifiEntryPreferences);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void onResume_registerReceiver() {
|
||||||
|
mInternetResetHelper.onResume();
|
||||||
|
|
||||||
|
verify(mContext).registerReceiver(any(BroadcastReceiver.class), any(IntentFilter.class));
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void onPause_unregisterReceiver() {
|
||||||
|
mInternetResetHelper.onResume();
|
||||||
|
|
||||||
|
mInternetResetHelper.onPause();
|
||||||
|
|
||||||
|
verify(mContext).unregisterReceiver(any(BroadcastReceiver.class));
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void onDestroy_quitWorkerThread() {
|
||||||
|
mInternetResetHelper.onDestroy();
|
||||||
|
|
||||||
|
verify(mWorkerThread).quit();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void onSubsystemRestartOperationEnd_recoveryIsNotReady_postResumeRunnable() {
|
||||||
|
mInternetResetHelper.mIsRecoveryReady = false;
|
||||||
|
|
||||||
|
mInternetResetHelper.onSubsystemRestartOperationEnd();
|
||||||
|
|
||||||
|
assertThat(mInternetResetHelper.mIsRecoveryReady).isTrue();
|
||||||
|
assertThat(mFakeHandlerInjector.getRunnable())
|
||||||
|
.isEqualTo(mInternetResetHelper.mResumeRunnable);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void onSubsystemRestartOperationEnd_recoveryIsReady_doNothing() {
|
||||||
|
mInternetResetHelper.mIsRecoveryReady = true;
|
||||||
|
|
||||||
|
mInternetResetHelper.onSubsystemRestartOperationEnd();
|
||||||
|
|
||||||
|
assertThat(mFakeHandlerInjector.getRunnable()).isNull();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void updateWifiStateChange_wifiIsNotReadyAndWifiDisabled_doNothing() {
|
||||||
|
mInternetResetHelper.mIsWifiReady = false;
|
||||||
|
when(mWifiManager.isWifiEnabled()).thenReturn(false);
|
||||||
|
|
||||||
|
mInternetResetHelper.updateWifiStateChange();
|
||||||
|
|
||||||
|
assertThat(mInternetResetHelper.mIsWifiReady).isFalse();
|
||||||
|
assertThat(mFakeHandlerInjector.getRunnable()).isNull();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void updateWifiStateChange_wifiIsNotReadyAndWifiEnabled_postResumeRunnable() {
|
||||||
|
mInternetResetHelper.mIsWifiReady = false;
|
||||||
|
when(mWifiManager.isWifiEnabled()).thenReturn(true);
|
||||||
|
|
||||||
|
mInternetResetHelper.updateWifiStateChange();
|
||||||
|
|
||||||
|
assertThat(mInternetResetHelper.mIsWifiReady).isTrue();
|
||||||
|
assertThat(mFakeHandlerInjector.getRunnable())
|
||||||
|
.isEqualTo(mInternetResetHelper.mResumeRunnable);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void updateWifiStateChange_wifiIsReady_doNothing() {
|
||||||
|
mInternetResetHelper.mIsWifiReady = true;
|
||||||
|
|
||||||
|
mInternetResetHelper.updateWifiStateChange();
|
||||||
|
|
||||||
|
assertThat(mInternetResetHelper.mIsWifiReady).isTrue();
|
||||||
|
assertThat(mFakeHandlerInjector.getRunnable()).isNull();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void suspendPreferences_shouldShowResettingHideSubSys() {
|
||||||
|
mInternetResetHelper.suspendPreferences();
|
||||||
|
|
||||||
|
// Show resetting preference
|
||||||
|
assertThat(mResettingPreference.isVisible()).isTrue();
|
||||||
|
// Hide subsystem preferences
|
||||||
|
verify(mMobileNetworkController).hidePreference(true /* hide */, true /* immediately*/);
|
||||||
|
assertThat(mWifiTogglePreferences.isVisible()).isFalse();
|
||||||
|
verify(mConnectedWifiEntryPreferences).removeAll();
|
||||||
|
assertThat(mConnectedWifiEntryPreferences.isVisible()).isFalse();
|
||||||
|
verify(mWifiEntryPreferences).removeAll();
|
||||||
|
assertThat(mWifiEntryPreferences.isVisible()).isFalse();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void resumePreferences_onlyRecoveryReady_shouldShowSubSysHideResetting() {
|
||||||
|
mInternetResetHelper.suspendPreferences();
|
||||||
|
mInternetResetHelper.mIsRecoveryReady = true;
|
||||||
|
mInternetResetHelper.mIsWifiReady = false;
|
||||||
|
|
||||||
|
mInternetResetHelper.resumePreferences();
|
||||||
|
|
||||||
|
// Show resetting preference
|
||||||
|
assertThat(mResettingPreference.isVisible()).isTrue();
|
||||||
|
// Show Mobile Network controller
|
||||||
|
verify(mMobileNetworkController).hidePreference(false /* hide */, false /* immediately*/);
|
||||||
|
// Hide Wi-Fi preferences
|
||||||
|
assertThat(mWifiTogglePreferences.isVisible()).isFalse();
|
||||||
|
assertThat(mConnectedWifiEntryPreferences.isVisible()).isFalse();
|
||||||
|
assertThat(mWifiEntryPreferences.isVisible()).isFalse();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void resumePreferences_onlyWifiReady_shouldShowSubSysHideResetting() {
|
||||||
|
mInternetResetHelper.suspendPreferences();
|
||||||
|
mInternetResetHelper.mIsRecoveryReady = false;
|
||||||
|
mInternetResetHelper.mIsWifiReady = true;
|
||||||
|
|
||||||
|
mInternetResetHelper.resumePreferences();
|
||||||
|
|
||||||
|
// Show resetting preference
|
||||||
|
assertThat(mResettingPreference.isVisible()).isTrue();
|
||||||
|
// Show Wi-Fi preferences
|
||||||
|
assertThat(mWifiTogglePreferences.isVisible()).isTrue();
|
||||||
|
assertThat(mConnectedWifiEntryPreferences.isVisible()).isTrue();
|
||||||
|
assertThat(mWifiEntryPreferences.isVisible()).isTrue();
|
||||||
|
// Hide Mobile Network controller
|
||||||
|
verify(mMobileNetworkController, never())
|
||||||
|
.hidePreference(false /* hide */, false /* immediately*/);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void resumePreferences_allReady_shouldShowSubSysHideResetting() {
|
||||||
|
mInternetResetHelper.suspendPreferences();
|
||||||
|
mInternetResetHelper.mIsRecoveryReady = true;
|
||||||
|
mInternetResetHelper.mIsWifiReady = true;
|
||||||
|
mInternetResetHelper.resumePreferences();
|
||||||
|
|
||||||
|
// Show subsystem preferences
|
||||||
|
verify(mMobileNetworkController).hidePreference(false, false);
|
||||||
|
assertThat(mWifiTogglePreferences.isVisible()).isTrue();
|
||||||
|
assertThat(mConnectedWifiEntryPreferences.isVisible()).isTrue();
|
||||||
|
assertThat(mWifiEntryPreferences.isVisible()).isTrue();
|
||||||
|
// Hide resetting preference
|
||||||
|
assertThat(mResettingPreference.isVisible()).isFalse();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void restart_recoveryNotAvailable_shouldDoTriggerSubsystemRestart() {
|
||||||
|
when(mConnectivitySubsystemsRecoveryManager.isRecoveryAvailable()).thenReturn(false);
|
||||||
|
|
||||||
|
mInternetResetHelper.restart();
|
||||||
|
|
||||||
|
verify(mConnectivitySubsystemsRecoveryManager, never())
|
||||||
|
.triggerSubsystemRestart(any(), any());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void restart_recoveryAvailable_triggerSubsystemRestart() {
|
||||||
|
when(mConnectivitySubsystemsRecoveryManager.isRecoveryAvailable()).thenReturn(true);
|
||||||
|
|
||||||
|
mInternetResetHelper.restart();
|
||||||
|
|
||||||
|
assertThat(mFakeHandlerInjector.getRunnable())
|
||||||
|
.isEqualTo(mInternetResetHelper.mTimeoutRunnable);
|
||||||
|
verify(mConnectivitySubsystemsRecoveryManager).triggerSubsystemRestart(any(), any());
|
||||||
|
}
|
||||||
|
}
|
@@ -173,6 +173,44 @@ public class NetworkMobileProviderControllerTest {
|
|||||||
assertEquals(mPreferenceScreen.getInitialExpandedChildrenCount(), Integer.MAX_VALUE);
|
assertEquals(mPreferenceScreen.getInitialExpandedChildrenCount(), Integer.MAX_VALUE);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void hidePreference_hidePreferenceTrue_preferenceIsNotVisible() {
|
||||||
|
when(mSubscriptionsController.isAvailable()).thenReturn(true);
|
||||||
|
setupNetworkMobileProviderController();
|
||||||
|
mPreferenceCategory.setVisible(true);
|
||||||
|
|
||||||
|
mNetworkMobileProviderController.hidePreference(true /* hide */, true /* immediately*/);
|
||||||
|
|
||||||
|
assertThat(mPreferenceCategory.isVisible()).isFalse();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void hidePreference_hidePreferenceFalse_preferenceIsVisible() {
|
||||||
|
when(mSubscriptionsController.isAvailable()).thenReturn(true);
|
||||||
|
setupNetworkMobileProviderController();
|
||||||
|
|
||||||
|
mNetworkMobileProviderController.hidePreference(false /* hide */, true /* immediately*/);
|
||||||
|
|
||||||
|
assertThat(mPreferenceCategory.isVisible()).isTrue();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void hidePreference_hidePreferenceFalse_preferenceIsNotVisibleImmediately() {
|
||||||
|
when(mSubscriptionsController.isAvailable()).thenReturn(true);
|
||||||
|
setupNetworkMobileProviderController();
|
||||||
|
mPreferenceCategory.setVisible(false);
|
||||||
|
|
||||||
|
mNetworkMobileProviderController.hidePreference(false /* hide */, false /* immediately*/);
|
||||||
|
|
||||||
|
// The preference is not visible immediately.
|
||||||
|
assertThat(mPreferenceCategory.isVisible()).isFalse();
|
||||||
|
|
||||||
|
mNetworkMobileProviderController.displayPreference(mPreferenceScreen);
|
||||||
|
|
||||||
|
// The preference is visible after displayPreference() updated.
|
||||||
|
assertThat(mPreferenceCategory.isVisible()).isTrue();
|
||||||
|
}
|
||||||
|
|
||||||
private void setupNetworkMobileProviderController() {
|
private void setupNetworkMobileProviderController() {
|
||||||
mNetworkMobileProviderController.init(mLifecycle);
|
mNetworkMobileProviderController.init(mLifecycle);
|
||||||
mNetworkMobileProviderController.displayPreference(mPreferenceScreen);
|
mNetworkMobileProviderController.displayPreference(mPreferenceScreen);
|
||||||
|
Reference in New Issue
Block a user