Pre-set initial state to wifi tether switches.
The preset initial state helps eliminating animation jank when first landing on the page. Change-Id: Ia7ba83983f18409b1c653cc1ebb0f3aad281358c Fixes: 64811322 Test: robotests
This commit is contained in:
@@ -40,6 +40,7 @@ public class WifiTetherSwitchBarController implements SwitchWidgetController.OnS
|
|||||||
private final SwitchWidgetController mSwitchBar;
|
private final SwitchWidgetController mSwitchBar;
|
||||||
private final ConnectivityManager mConnectivityManager;
|
private final ConnectivityManager mConnectivityManager;
|
||||||
private final DataSaverBackend mDataSaverBackend;
|
private final DataSaverBackend mDataSaverBackend;
|
||||||
|
private final WifiManager mWifiManager;
|
||||||
|
|
||||||
WifiTetherSwitchBarController(Context context, SwitchWidgetController switchBar) {
|
WifiTetherSwitchBarController(Context context, SwitchWidgetController switchBar) {
|
||||||
mContext = context;
|
mContext = context;
|
||||||
@@ -47,6 +48,8 @@ public class WifiTetherSwitchBarController implements SwitchWidgetController.OnS
|
|||||||
mDataSaverBackend = new DataSaverBackend(context);
|
mDataSaverBackend = new DataSaverBackend(context);
|
||||||
mConnectivityManager =
|
mConnectivityManager =
|
||||||
(ConnectivityManager) context.getSystemService(Context.CONNECTIVITY_SERVICE);
|
(ConnectivityManager) context.getSystemService(Context.CONNECTIVITY_SERVICE);
|
||||||
|
mWifiManager = (WifiManager) context.getSystemService(Context.WIFI_SERVICE);
|
||||||
|
mSwitchBar.setChecked(mWifiManager.getWifiApState() == WifiManager.WIFI_AP_STATE_ENABLED);
|
||||||
mSwitchBar.setListener(this);
|
mSwitchBar.setListener(this);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@@ -37,15 +37,16 @@ import android.support.v7.preference.PreferenceScreen;
|
|||||||
|
|
||||||
import com.android.settings.R;
|
import com.android.settings.R;
|
||||||
import com.android.settings.TestConfig;
|
import com.android.settings.TestConfig;
|
||||||
|
import com.android.settings.testutils.FakeFeatureFactory;
|
||||||
import com.android.settings.testutils.SettingsRobolectricTestRunner;
|
import com.android.settings.testutils.SettingsRobolectricTestRunner;
|
||||||
import com.android.settings.widget.MasterSwitchPreference;
|
import com.android.settings.widget.MasterSwitchPreference;
|
||||||
import com.android.settings.widget.SwitchWidgetController;
|
|
||||||
import com.android.settingslib.core.lifecycle.Lifecycle;
|
import com.android.settingslib.core.lifecycle.Lifecycle;
|
||||||
|
|
||||||
import org.junit.After;
|
import org.junit.After;
|
||||||
import org.junit.Before;
|
import org.junit.Before;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
import org.junit.runner.RunWith;
|
import org.junit.runner.RunWith;
|
||||||
|
import org.mockito.Answers;
|
||||||
import org.mockito.Mock;
|
import org.mockito.Mock;
|
||||||
import org.mockito.MockitoAnnotations;
|
import org.mockito.MockitoAnnotations;
|
||||||
import org.robolectric.RuntimeEnvironment;
|
import org.robolectric.RuntimeEnvironment;
|
||||||
@@ -65,6 +66,8 @@ import java.util.ArrayList;
|
|||||||
})
|
})
|
||||||
public class WifiTetherPreferenceControllerTest {
|
public class WifiTetherPreferenceControllerTest {
|
||||||
|
|
||||||
|
@Mock(answer = Answers.RETURNS_DEEP_STUBS)
|
||||||
|
private Context mFeatureFactoryContext;
|
||||||
@Mock
|
@Mock
|
||||||
private Context mContext;
|
private Context mContext;
|
||||||
@Mock
|
@Mock
|
||||||
@@ -82,6 +85,7 @@ public class WifiTetherPreferenceControllerTest {
|
|||||||
public void setUp() {
|
public void setUp() {
|
||||||
MockitoAnnotations.initMocks(this);
|
MockitoAnnotations.initMocks(this);
|
||||||
mLifecycle = new Lifecycle();
|
mLifecycle = new Lifecycle();
|
||||||
|
FakeFeatureFactory.setupForTest(mFeatureFactoryContext);
|
||||||
mPreference = new MasterSwitchPreference(RuntimeEnvironment.application);
|
mPreference = new MasterSwitchPreference(RuntimeEnvironment.application);
|
||||||
when(mContext.getSystemService(Context.CONNECTIVITY_SERVICE))
|
when(mContext.getSystemService(Context.CONNECTIVITY_SERVICE))
|
||||||
.thenReturn(mConnectivityManager);
|
.thenReturn(mConnectivityManager);
|
||||||
@@ -124,6 +128,36 @@ public class WifiTetherPreferenceControllerTest {
|
|||||||
verify(mContext).unregisterReceiver(receiver);
|
verify(mContext).unregisterReceiver(receiver);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void start_wifiApOff_shouldSetInitialStateToOff() {
|
||||||
|
when(mWifiManager.getWifiApState()).thenReturn(WifiManager.WIFI_AP_STATE_DISABLED);
|
||||||
|
final BroadcastReceiver receiver = ReflectionHelpers.getField(mController, "mReceiver");
|
||||||
|
final MasterSwitchPreference pref = mock(MasterSwitchPreference.class);
|
||||||
|
when(mScreen.findPreference(anyString())).thenReturn(pref);
|
||||||
|
|
||||||
|
mController.displayPreference(mScreen);
|
||||||
|
mLifecycle.onStart();
|
||||||
|
|
||||||
|
assertThat(ShadowWifiTetherSwitchBarController.onStartCalled).isTrue();
|
||||||
|
verify(mContext).registerReceiver(eq(receiver), any(IntentFilter.class));
|
||||||
|
verify(pref).setChecked(false);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void start_wifiApOn_shouldSetInitialStateToOn() {
|
||||||
|
when(mWifiManager.getWifiApState()).thenReturn(WifiManager.WIFI_AP_STATE_ENABLED);
|
||||||
|
final BroadcastReceiver receiver = ReflectionHelpers.getField(mController, "mReceiver");
|
||||||
|
final MasterSwitchPreference pref = mock(MasterSwitchPreference.class);
|
||||||
|
when(mScreen.findPreference(anyString())).thenReturn(pref);
|
||||||
|
|
||||||
|
mController.displayPreference(mScreen);
|
||||||
|
mLifecycle.onStart();
|
||||||
|
|
||||||
|
assertThat(ShadowWifiTetherSwitchBarController.onStartCalled).isTrue();
|
||||||
|
verify(mContext).registerReceiver(eq(receiver), any(IntentFilter.class));
|
||||||
|
verify(pref).setChecked(true);
|
||||||
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testReceiver_apStateChangedToDisabled_shouldUpdatePreferenceSummary() {
|
public void testReceiver_apStateChangedToDisabled_shouldUpdatePreferenceSummary() {
|
||||||
mController.displayPreference(mScreen);
|
mController.displayPreference(mScreen);
|
||||||
@@ -199,9 +233,6 @@ public class WifiTetherPreferenceControllerTest {
|
|||||||
public static boolean onStartCalled;
|
public static boolean onStartCalled;
|
||||||
public static boolean onStopCalled;
|
public static boolean onStopCalled;
|
||||||
|
|
||||||
public void __constructor__(Context context, SwitchWidgetController switchWidget) {
|
|
||||||
}
|
|
||||||
|
|
||||||
public static void reset() {
|
public static void reset() {
|
||||||
onStartCalled = false;
|
onStartCalled = false;
|
||||||
onStopCalled = false;
|
onStopCalled = false;
|
||||||
|
Reference in New Issue
Block a user