Refactor UseOpenWifiPreferenceController into TogglePreferenceController
UseOpenWifiPreferenceController is essentially reimplementing TogglePreferenceController. Add below 2 changes for test failure of CodeInspectionTest 1. Remove some arguments from constructor of the controller 2. Declare the controller in xml instead of in code Bug: 132391311 Test: manual UseOpenWifiPreferenceControllerTest Change-Id: Ie52e79fd0bc66a227bd46f09c74d1fbec614f636
This commit is contained in:
@@ -31,7 +31,8 @@
|
|||||||
android:key="use_open_wifi_automatically"
|
android:key="use_open_wifi_automatically"
|
||||||
android:icon="@drawable/ic_open_wifi_autoconnect"
|
android:icon="@drawable/ic_open_wifi_autoconnect"
|
||||||
android:title="@string/use_open_wifi_automatically_title"
|
android:title="@string/use_open_wifi_automatically_title"
|
||||||
android:summary="@string/use_open_wifi_automatically_summary" />
|
android:summary="@string/use_open_wifi_automatically_summary"
|
||||||
|
settings:controller="com.android.settings.wifi.UseOpenWifiPreferenceController"/>
|
||||||
|
|
||||||
<SwitchPreference
|
<SwitchPreference
|
||||||
android:key="notify_open_networks"
|
android:key="notify_open_networks"
|
||||||
|
@@ -74,13 +74,10 @@ public class ConfigureWifiSettings extends DashboardFragment {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected List<AbstractPreferenceController> createPreferenceControllers(Context context) {
|
protected List<AbstractPreferenceController> createPreferenceControllers(Context context) {
|
||||||
mUseOpenWifiPreferenceController = new UseOpenWifiPreferenceController(context, this,
|
|
||||||
getSettingsLifecycle());
|
|
||||||
final WifiManager wifiManager = (WifiManager) getSystemService(WIFI_SERVICE);
|
final WifiManager wifiManager = (WifiManager) getSystemService(WIFI_SERVICE);
|
||||||
final List<AbstractPreferenceController> controllers = new ArrayList<>();
|
final List<AbstractPreferenceController> controllers = new ArrayList<>();
|
||||||
controllers.add(new NotifyOpenNetworksPreferenceController(context,
|
controllers.add(new NotifyOpenNetworksPreferenceController(context,
|
||||||
getSettingsLifecycle()));
|
getSettingsLifecycle()));
|
||||||
controllers.add(mUseOpenWifiPreferenceController);
|
|
||||||
controllers.add(new WifiInfoPreferenceController(context, getSettingsLifecycle(),
|
controllers.add(new WifiInfoPreferenceController(context, getSettingsLifecycle(),
|
||||||
wifiManager));
|
wifiManager));
|
||||||
controllers.add(new WifiP2pPreferenceController(context, getSettingsLifecycle(),
|
controllers.add(new WifiP2pPreferenceController(context, getSettingsLifecycle(),
|
||||||
@@ -92,8 +89,12 @@ public class ConfigureWifiSettings extends DashboardFragment {
|
|||||||
public void onAttach(Context context) {
|
public void onAttach(Context context) {
|
||||||
super.onAttach(context);
|
super.onAttach(context);
|
||||||
|
|
||||||
|
|
||||||
mWifiWakeupPreferenceController = use(WifiWakeupPreferenceController.class);
|
mWifiWakeupPreferenceController = use(WifiWakeupPreferenceController.class);
|
||||||
mWifiWakeupPreferenceController.setFragment(this);
|
mWifiWakeupPreferenceController.setFragment(this);
|
||||||
|
|
||||||
|
mUseOpenWifiPreferenceController = use(UseOpenWifiPreferenceController.class);
|
||||||
|
mUseOpenWifiPreferenceController.setFragment(this);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@@ -102,8 +103,7 @@ public class ConfigureWifiSettings extends DashboardFragment {
|
|||||||
mWifiWakeupPreferenceController.onActivityResult(requestCode, resultCode);
|
mWifiWakeupPreferenceController.onActivityResult(requestCode, resultCode);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if (requestCode == UseOpenWifiPreferenceController.REQUEST_CODE_OPEN_WIFI_AUTOMATICALLY
|
if (requestCode == UseOpenWifiPreferenceController.REQUEST_CODE_OPEN_WIFI_AUTOMATICALLY) {
|
||||||
&& mUseOpenWifiPreferenceController != null) {
|
|
||||||
mUseOpenWifiPreferenceController.onActivityResult(requestCode, resultCode);
|
mUseOpenWifiPreferenceController.onActivityResult(requestCode, resultCode);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@@ -17,12 +17,10 @@ import android.text.TextUtils;
|
|||||||
import androidx.fragment.app.Fragment;
|
import androidx.fragment.app.Fragment;
|
||||||
import androidx.preference.Preference;
|
import androidx.preference.Preference;
|
||||||
import androidx.preference.PreferenceScreen;
|
import androidx.preference.PreferenceScreen;
|
||||||
import androidx.preference.SwitchPreference;
|
|
||||||
|
|
||||||
import com.android.settings.R;
|
import com.android.settings.R;
|
||||||
import com.android.settings.core.PreferenceControllerMixin;
|
import com.android.settings.core.PreferenceControllerMixin;
|
||||||
import com.android.settingslib.core.AbstractPreferenceController;
|
import com.android.settings.core.TogglePreferenceController;
|
||||||
import com.android.settingslib.core.lifecycle.Lifecycle;
|
|
||||||
import com.android.settingslib.core.lifecycle.LifecycleObserver;
|
import com.android.settingslib.core.lifecycle.LifecycleObserver;
|
||||||
import com.android.settingslib.core.lifecycle.events.OnPause;
|
import com.android.settingslib.core.lifecycle.events.OnPause;
|
||||||
import com.android.settingslib.core.lifecycle.events.OnResume;
|
import com.android.settingslib.core.lifecycle.events.OnResume;
|
||||||
@@ -30,10 +28,10 @@ import com.android.settingslib.core.lifecycle.events.OnResume;
|
|||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* {@link AbstractPreferenceController} that controls whether a user wants to enable the "use open
|
* {@link TogglePreferenceController} that controls whether a user wants to enable the "use open
|
||||||
* networks automatically" feature provider by the current network recommendation provider.
|
* networks automatically" feature provided by the current network recommendation provider.
|
||||||
*/
|
*/
|
||||||
public class UseOpenWifiPreferenceController extends AbstractPreferenceController
|
public class UseOpenWifiPreferenceController extends TogglePreferenceController
|
||||||
implements PreferenceControllerMixin, Preference.OnPreferenceChangeListener,
|
implements PreferenceControllerMixin, Preference.OnPreferenceChangeListener,
|
||||||
LifecycleObserver, OnResume, OnPause {
|
LifecycleObserver, OnResume, OnPause {
|
||||||
public static final int REQUEST_CODE_OPEN_WIFI_AUTOMATICALLY = 400;
|
public static final int REQUEST_CODE_OPEN_WIFI_AUTOMATICALLY = 400;
|
||||||
@@ -41,7 +39,7 @@ public class UseOpenWifiPreferenceController extends AbstractPreferenceControlle
|
|||||||
private static final String KEY_USE_OPEN_WIFI_AUTOMATICALLY = "use_open_wifi_automatically";
|
private static final String KEY_USE_OPEN_WIFI_AUTOMATICALLY = "use_open_wifi_automatically";
|
||||||
|
|
||||||
private final ContentResolver mContentResolver;
|
private final ContentResolver mContentResolver;
|
||||||
private final Fragment mFragment;
|
private Fragment mFragment;
|
||||||
private final NetworkScoreManager mNetworkScoreManager;
|
private final NetworkScoreManager mNetworkScoreManager;
|
||||||
private final SettingObserver mSettingObserver;
|
private final SettingObserver mSettingObserver;
|
||||||
|
|
||||||
@@ -49,17 +47,18 @@ public class UseOpenWifiPreferenceController extends AbstractPreferenceControlle
|
|||||||
private ComponentName mEnableUseWifiComponentName;
|
private ComponentName mEnableUseWifiComponentName;
|
||||||
private boolean mDoFeatureSupportedScorersExist;
|
private boolean mDoFeatureSupportedScorersExist;
|
||||||
|
|
||||||
public UseOpenWifiPreferenceController(Context context, Fragment fragment,
|
public UseOpenWifiPreferenceController(Context context) {
|
||||||
Lifecycle lifecycle) {
|
super(context, KEY_USE_OPEN_WIFI_AUTOMATICALLY);
|
||||||
super(context);
|
|
||||||
mContentResolver = context.getContentResolver();
|
mContentResolver = context.getContentResolver();
|
||||||
mFragment = fragment;
|
|
||||||
mNetworkScoreManager =
|
mNetworkScoreManager =
|
||||||
(NetworkScoreManager) context.getSystemService(Context.NETWORK_SCORE_SERVICE);
|
(NetworkScoreManager) context.getSystemService(Context.NETWORK_SCORE_SERVICE);
|
||||||
mSettingObserver = new SettingObserver();
|
mSettingObserver = new SettingObserver();
|
||||||
updateEnableUseWifiComponentName();
|
updateEnableUseWifiComponentName();
|
||||||
checkForFeatureSupportedScorers();
|
checkForFeatureSupportedScorers();
|
||||||
lifecycle.addObserver(this);
|
}
|
||||||
|
|
||||||
|
public void setFragment(Fragment hostFragment) {
|
||||||
|
mFragment = hostFragment;
|
||||||
}
|
}
|
||||||
|
|
||||||
private void updateEnableUseWifiComponentName() {
|
private void updateEnableUseWifiComponentName() {
|
||||||
@@ -86,7 +85,7 @@ public class UseOpenWifiPreferenceController extends AbstractPreferenceControlle
|
|||||||
@Override
|
@Override
|
||||||
public void displayPreference(PreferenceScreen screen) {
|
public void displayPreference(PreferenceScreen screen) {
|
||||||
super.displayPreference(screen);
|
super.displayPreference(screen);
|
||||||
mPreference = screen.findPreference(KEY_USE_OPEN_WIFI_AUTOMATICALLY);
|
mPreference = screen.findPreference(getPreferenceKey());
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@@ -100,67 +99,54 @@ public class UseOpenWifiPreferenceController extends AbstractPreferenceControlle
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean isAvailable() {
|
public int getAvailabilityStatus() {
|
||||||
return mDoFeatureSupportedScorersExist;
|
return mDoFeatureSupportedScorersExist ? AVAILABLE : CONDITIONALLY_UNAVAILABLE;
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public String getPreferenceKey() {
|
|
||||||
return KEY_USE_OPEN_WIFI_AUTOMATICALLY;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void updateState(Preference preference) {
|
public void updateState(Preference preference) {
|
||||||
if (!(preference instanceof SwitchPreference)) {
|
super.updateState(preference);
|
||||||
return;
|
|
||||||
}
|
|
||||||
final SwitchPreference useOpenWifiPreference = (SwitchPreference) preference;
|
|
||||||
|
|
||||||
boolean isScorerSet = mNetworkScoreManager.getActiveScorerPackage() != null;
|
final boolean isScorerSet = mNetworkScoreManager.getActiveScorerPackage() != null;
|
||||||
boolean doesActiveScorerSupportFeature = mEnableUseWifiComponentName != null;
|
final boolean doesActiveScorerSupportFeature = mEnableUseWifiComponentName != null;
|
||||||
|
|
||||||
useOpenWifiPreference.setChecked(isSettingEnabled());
|
|
||||||
useOpenWifiPreference.setVisible(isAvailable());
|
|
||||||
useOpenWifiPreference.setEnabled(isScorerSet && doesActiveScorerSupportFeature);
|
|
||||||
|
|
||||||
|
preference.setEnabled(isScorerSet && doesActiveScorerSupportFeature);
|
||||||
if (!isScorerSet) {
|
if (!isScorerSet) {
|
||||||
useOpenWifiPreference.setSummary(
|
preference.setSummary(R.string.use_open_wifi_automatically_summary_scoring_disabled);
|
||||||
R.string.use_open_wifi_automatically_summary_scoring_disabled);
|
|
||||||
} else if (!doesActiveScorerSupportFeature) {
|
} else if (!doesActiveScorerSupportFeature) {
|
||||||
useOpenWifiPreference.setSummary(
|
preference.setSummary(
|
||||||
R.string.use_open_wifi_automatically_summary_scorer_unsupported_disabled);
|
R.string.use_open_wifi_automatically_summary_scorer_unsupported_disabled);
|
||||||
} else {
|
} else {
|
||||||
useOpenWifiPreference.setSummary(R.string.use_open_wifi_automatically_summary);
|
preference.setSummary(R.string.use_open_wifi_automatically_summary);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean onPreferenceChange(Preference preference, Object newValue) {
|
public boolean isChecked() {
|
||||||
if (!TextUtils.equals(preference.getKey(), KEY_USE_OPEN_WIFI_AUTOMATICALLY)
|
final String enabledUseOpenWifiPackage = Settings.Global.getString(mContentResolver,
|
||||||
|| !isAvailable()) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (isSettingEnabled()) {
|
|
||||||
Settings.Global.putString(mContentResolver,
|
|
||||||
Settings.Global.USE_OPEN_WIFI_PACKAGE, "");
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
Intent intent = new Intent(NetworkScoreManager.ACTION_CUSTOM_ENABLE);
|
|
||||||
intent.setComponent(mEnableUseWifiComponentName);
|
|
||||||
mFragment.startActivityForResult(intent, REQUEST_CODE_OPEN_WIFI_AUTOMATICALLY);
|
|
||||||
return false; // Updating state is done in onActivityResult.
|
|
||||||
}
|
|
||||||
|
|
||||||
private boolean isSettingEnabled() {
|
|
||||||
String enabledUseOpenWifiPackage = Settings.Global.getString(mContentResolver,
|
|
||||||
Settings.Global.USE_OPEN_WIFI_PACKAGE);
|
Settings.Global.USE_OPEN_WIFI_PACKAGE);
|
||||||
String currentUseOpenWifiPackage = mEnableUseWifiComponentName == null
|
final String currentUseOpenWifiPackage = mEnableUseWifiComponentName == null
|
||||||
? null : mEnableUseWifiComponentName.getPackageName();
|
? null : mEnableUseWifiComponentName.getPackageName();
|
||||||
return TextUtils.equals(enabledUseOpenWifiPackage, currentUseOpenWifiPackage);
|
return TextUtils.equals(enabledUseOpenWifiPackage, currentUseOpenWifiPackage);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean setChecked(boolean isChecked) {
|
||||||
|
if (isChecked) {
|
||||||
|
if (mFragment == null) {
|
||||||
|
throw new IllegalStateException("No fragment to start activity");
|
||||||
|
}
|
||||||
|
|
||||||
|
final Intent intent = new Intent(NetworkScoreManager.ACTION_CUSTOM_ENABLE);
|
||||||
|
intent.setComponent(mEnableUseWifiComponentName);
|
||||||
|
mFragment.startActivityForResult(intent, REQUEST_CODE_OPEN_WIFI_AUTOMATICALLY);
|
||||||
|
return false; // Updating state is done in onActivityResult.
|
||||||
|
} else {
|
||||||
|
Settings.Global.putString(mContentResolver, Settings.Global.USE_OPEN_WIFI_PACKAGE, "");
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
public boolean onActivityResult(int requestCode, int resultCode) {
|
public boolean onActivityResult(int requestCode, int resultCode) {
|
||||||
if (requestCode != REQUEST_CODE_OPEN_WIFI_AUTOMATICALLY) {
|
if (requestCode != REQUEST_CODE_OPEN_WIFI_AUTOMATICALLY) {
|
||||||
return false;
|
return false;
|
||||||
|
@@ -43,7 +43,6 @@ import androidx.preference.Preference;
|
|||||||
import androidx.preference.SwitchPreference;
|
import androidx.preference.SwitchPreference;
|
||||||
|
|
||||||
import com.android.settings.R;
|
import com.android.settings.R;
|
||||||
import com.android.settingslib.core.lifecycle.Lifecycle;
|
|
||||||
|
|
||||||
import com.google.common.collect.Lists;
|
import com.google.common.collect.Lists;
|
||||||
|
|
||||||
@@ -76,8 +75,6 @@ public class UseOpenWifiPreferenceControllerTest {
|
|||||||
sAppDataNoActivity = new NetworkScorerAppData(0, null, null, null, null);
|
sAppDataNoActivity = new NetworkScorerAppData(0, null, null, null, null);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Mock
|
|
||||||
private Lifecycle mLifecycle;
|
|
||||||
@Mock
|
@Mock
|
||||||
private Fragment mFragment;
|
private Fragment mFragment;
|
||||||
@Mock
|
@Mock
|
||||||
@@ -97,7 +94,8 @@ public class UseOpenWifiPreferenceControllerTest {
|
|||||||
}
|
}
|
||||||
|
|
||||||
private void createController() {
|
private void createController() {
|
||||||
mController = new UseOpenWifiPreferenceController(mContext, mFragment, mLifecycle);
|
mController = new UseOpenWifiPreferenceController(mContext);
|
||||||
|
mController.setFragment(mFragment);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -146,52 +144,28 @@ public class UseOpenWifiPreferenceControllerTest {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void onPreferenceChange_nonMatchingKey_shouldDoNothing() {
|
public void setChecked_withTrue_enableShouldStartEnableActivity() {
|
||||||
createController();
|
|
||||||
|
|
||||||
final SwitchPreference pref = new SwitchPreference(mContext);
|
|
||||||
|
|
||||||
assertThat(mController.onPreferenceChange(pref, null)).isFalse();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void onPreferenceChange_notAvailable_shouldDoNothing() {
|
|
||||||
createController();
|
|
||||||
|
|
||||||
final Preference pref = new Preference(mContext);
|
|
||||||
pref.setKey(mController.getPreferenceKey());
|
|
||||||
|
|
||||||
assertThat(mController.onPreferenceChange(pref, null)).isFalse();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void onPreferenceChange_matchingKeyAndAvailable_enableShouldStartEnableActivity() {
|
|
||||||
setupScorers(Lists.newArrayList(sAppData, sAppDataNoActivity));
|
setupScorers(Lists.newArrayList(sAppData, sAppDataNoActivity));
|
||||||
createController();
|
createController();
|
||||||
|
|
||||||
final SwitchPreference pref = new SwitchPreference(mContext);
|
mController.setChecked(true);
|
||||||
pref.setKey(mController.getPreferenceKey());
|
|
||||||
|
|
||||||
assertThat(mController.onPreferenceChange(pref, null)).isFalse();
|
|
||||||
verify(mFragment).startActivityForResult(mIntentCaptor.capture(),
|
verify(mFragment).startActivityForResult(mIntentCaptor.capture(),
|
||||||
eq(REQUEST_CODE_OPEN_WIFI_AUTOMATICALLY));
|
eq(REQUEST_CODE_OPEN_WIFI_AUTOMATICALLY));
|
||||||
Intent activityIntent = mIntentCaptor.getValue();
|
final Intent activityIntent = mIntentCaptor.getValue();
|
||||||
assertThat(activityIntent.getComponent()).isEqualTo(sEnableActivityComponent);
|
assertThat(activityIntent.getComponent()).isEqualTo(sEnableActivityComponent);
|
||||||
assertThat(activityIntent.getAction()).isEqualTo(NetworkScoreManager.ACTION_CUSTOM_ENABLE);
|
assertThat(activityIntent.getAction()).isEqualTo(NetworkScoreManager.ACTION_CUSTOM_ENABLE);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void onPreferenceChange_matchingKeyAndAvailable_disableShouldUpdateSetting() {
|
public void setChecked_withFalse_disableShouldUpdateSetting() {
|
||||||
setupScorers(Lists.newArrayList(sAppData, sAppDataNoActivity));
|
setupScorers(Lists.newArrayList(sAppData, sAppDataNoActivity));
|
||||||
Settings.Global.putString(mContext.getContentResolver(), USE_OPEN_WIFI_PACKAGE,
|
Settings.Global.putString(mContext.getContentResolver(), USE_OPEN_WIFI_PACKAGE,
|
||||||
sEnableActivityComponent.getPackageName());
|
sEnableActivityComponent.getPackageName());
|
||||||
|
|
||||||
createController();
|
createController();
|
||||||
|
|
||||||
final SwitchPreference pref = new SwitchPreference(mContext);
|
mController.setChecked(false);
|
||||||
pref.setKey(mController.getPreferenceKey());
|
|
||||||
|
|
||||||
assertThat(mController.onPreferenceChange(pref, null)).isTrue();
|
|
||||||
assertThat(Settings.Global.getString(mContext.getContentResolver(), USE_OPEN_WIFI_PACKAGE))
|
assertThat(Settings.Global.getString(mContext.getContentResolver(), USE_OPEN_WIFI_PACKAGE))
|
||||||
.isEqualTo("");
|
.isEqualTo("");
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user