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:
@@ -43,7 +43,6 @@ import androidx.preference.Preference;
|
||||
import androidx.preference.SwitchPreference;
|
||||
|
||||
import com.android.settings.R;
|
||||
import com.android.settingslib.core.lifecycle.Lifecycle;
|
||||
|
||||
import com.google.common.collect.Lists;
|
||||
|
||||
@@ -76,8 +75,6 @@ public class UseOpenWifiPreferenceControllerTest {
|
||||
sAppDataNoActivity = new NetworkScorerAppData(0, null, null, null, null);
|
||||
}
|
||||
|
||||
@Mock
|
||||
private Lifecycle mLifecycle;
|
||||
@Mock
|
||||
private Fragment mFragment;
|
||||
@Mock
|
||||
@@ -97,7 +94,8 @@ public class UseOpenWifiPreferenceControllerTest {
|
||||
}
|
||||
|
||||
private void createController() {
|
||||
mController = new UseOpenWifiPreferenceController(mContext, mFragment, mLifecycle);
|
||||
mController = new UseOpenWifiPreferenceController(mContext);
|
||||
mController.setFragment(mFragment);
|
||||
}
|
||||
|
||||
/**
|
||||
@@ -146,52 +144,28 @@ public class UseOpenWifiPreferenceControllerTest {
|
||||
}
|
||||
|
||||
@Test
|
||||
public void onPreferenceChange_nonMatchingKey_shouldDoNothing() {
|
||||
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() {
|
||||
public void setChecked_withTrue_enableShouldStartEnableActivity() {
|
||||
setupScorers(Lists.newArrayList(sAppData, sAppDataNoActivity));
|
||||
createController();
|
||||
|
||||
final SwitchPreference pref = new SwitchPreference(mContext);
|
||||
pref.setKey(mController.getPreferenceKey());
|
||||
mController.setChecked(true);
|
||||
|
||||
assertThat(mController.onPreferenceChange(pref, null)).isFalse();
|
||||
verify(mFragment).startActivityForResult(mIntentCaptor.capture(),
|
||||
eq(REQUEST_CODE_OPEN_WIFI_AUTOMATICALLY));
|
||||
Intent activityIntent = mIntentCaptor.getValue();
|
||||
final Intent activityIntent = mIntentCaptor.getValue();
|
||||
assertThat(activityIntent.getComponent()).isEqualTo(sEnableActivityComponent);
|
||||
assertThat(activityIntent.getAction()).isEqualTo(NetworkScoreManager.ACTION_CUSTOM_ENABLE);
|
||||
}
|
||||
|
||||
@Test
|
||||
public void onPreferenceChange_matchingKeyAndAvailable_disableShouldUpdateSetting() {
|
||||
public void setChecked_withFalse_disableShouldUpdateSetting() {
|
||||
setupScorers(Lists.newArrayList(sAppData, sAppDataNoActivity));
|
||||
Settings.Global.putString(mContext.getContentResolver(), USE_OPEN_WIFI_PACKAGE,
|
||||
sEnableActivityComponent.getPackageName());
|
||||
|
||||
createController();
|
||||
|
||||
final SwitchPreference pref = new SwitchPreference(mContext);
|
||||
pref.setKey(mController.getPreferenceKey());
|
||||
mController.setChecked(false);
|
||||
|
||||
assertThat(mController.onPreferenceChange(pref, null)).isTrue();
|
||||
assertThat(Settings.Global.getString(mContext.getContentResolver(), USE_OPEN_WIFI_PACKAGE))
|
||||
.isEqualTo("");
|
||||
}
|
||||
|
Reference in New Issue
Block a user