Merge "Fix Bluetooth switch status in Connected devices screen" into oc-mr1-dev
This commit is contained in:
committed by
Android (Google) Code Review
commit
c3b47925e3
@@ -157,7 +157,9 @@ public final class BluetoothEnabler implements SwitchWidgetController.OnSwitchCh
|
|||||||
}
|
}
|
||||||
|
|
||||||
private void setChecked(boolean isChecked) {
|
private void setChecked(boolean isChecked) {
|
||||||
if (isChecked != mSwitchWidget.isChecked()) {
|
final boolean currentState =
|
||||||
|
(mSwitchWidget.getSwitch() != null) && mSwitchWidget.getSwitch().isChecked();
|
||||||
|
if (isChecked != currentState) {
|
||||||
// set listener to null, so onCheckedChanged won't be called
|
// set listener to null, so onCheckedChanged won't be called
|
||||||
// if the checked status on Switch isn't changed by user click
|
// if the checked status on Switch isn't changed by user click
|
||||||
if (mValidListener) {
|
if (mValidListener) {
|
||||||
|
@@ -15,14 +15,24 @@
|
|||||||
*/
|
*/
|
||||||
package com.android.settings.bluetooth;
|
package com.android.settings.bluetooth;
|
||||||
|
|
||||||
|
import android.bluetooth.BluetoothAdapter;
|
||||||
|
import android.content.BroadcastReceiver;
|
||||||
import android.content.ComponentName;
|
import android.content.ComponentName;
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
|
import android.content.Intent;
|
||||||
|
import android.content.IntentFilter;
|
||||||
import android.os.UserManager;
|
import android.os.UserManager;
|
||||||
|
import android.support.v7.preference.PreferenceViewHolder;
|
||||||
|
import android.view.View;
|
||||||
|
import android.widget.Switch;
|
||||||
|
|
||||||
|
import com.android.settings.R;
|
||||||
import com.android.settings.testutils.SettingsRobolectricTestRunner;
|
import com.android.settings.testutils.SettingsRobolectricTestRunner;
|
||||||
import com.android.settings.TestConfig;
|
import com.android.settings.TestConfig;
|
||||||
import com.android.settings.core.instrumentation.MetricsFeatureProvider;
|
import com.android.settings.core.instrumentation.MetricsFeatureProvider;
|
||||||
|
import com.android.settings.testutils.shadow.SettingsShadowResources;
|
||||||
import com.android.settings.widget.MasterSwitchController;
|
import com.android.settings.widget.MasterSwitchController;
|
||||||
|
import com.android.settings.widget.MasterSwitchPreference;
|
||||||
import com.android.settingslib.RestrictedLockUtils.EnforcedAdmin;
|
import com.android.settingslib.RestrictedLockUtils.EnforcedAdmin;
|
||||||
import com.android.settingslib.bluetooth.LocalBluetoothAdapter;
|
import com.android.settingslib.bluetooth.LocalBluetoothAdapter;
|
||||||
import com.android.settingslib.bluetooth.LocalBluetoothManager;
|
import com.android.settingslib.bluetooth.LocalBluetoothManager;
|
||||||
@@ -30,22 +40,26 @@ import com.android.settingslib.bluetooth.LocalBluetoothManager;
|
|||||||
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.ArgumentCaptor;
|
||||||
import org.mockito.Mock;
|
import org.mockito.Mock;
|
||||||
import org.mockito.MockitoAnnotations;
|
import org.mockito.MockitoAnnotations;
|
||||||
|
import org.robolectric.RuntimeEnvironment;
|
||||||
import org.robolectric.annotation.Config;
|
import org.robolectric.annotation.Config;
|
||||||
|
|
||||||
import static com.google.common.truth.Truth.assertThat;
|
import static com.google.common.truth.Truth.assertThat;
|
||||||
import static junit.framework.TestCase.assertNotNull;
|
|
||||||
import static junit.framework.TestCase.assertEquals;
|
|
||||||
import static org.mockito.Mockito.mock;
|
import static org.mockito.Mockito.mock;
|
||||||
import static org.mockito.Matchers.any;
|
import static org.mockito.Matchers.any;
|
||||||
import static org.mockito.Matchers.anyBoolean;
|
import static org.mockito.Matchers.anyBoolean;
|
||||||
import static org.mockito.Mockito.never;
|
import static org.mockito.Mockito.never;
|
||||||
|
import static org.mockito.Mockito.spy;
|
||||||
import static org.mockito.Mockito.verify;
|
import static org.mockito.Mockito.verify;
|
||||||
import static org.mockito.Mockito.when;
|
import static org.mockito.Mockito.when;
|
||||||
|
|
||||||
@RunWith(SettingsRobolectricTestRunner.class)
|
@RunWith(SettingsRobolectricTestRunner.class)
|
||||||
@Config(manifest = TestConfig.MANIFEST_PATH, sdk = TestConfig.SDK_VERSION)
|
@Config(manifest = TestConfig.MANIFEST_PATH, sdk = TestConfig.SDK_VERSION, shadows = {
|
||||||
|
SettingsShadowResources.class, SettingsShadowResources.SettingsShadowTheme.class
|
||||||
|
})
|
||||||
public class BluetoothEnablerTest {
|
public class BluetoothEnablerTest {
|
||||||
|
|
||||||
private static final EnforcedAdmin FAKE_ENFORCED_ADMIN =
|
private static final EnforcedAdmin FAKE_ENFORCED_ADMIN =
|
||||||
@@ -54,22 +68,27 @@ public class BluetoothEnablerTest {
|
|||||||
@Mock
|
@Mock
|
||||||
private MetricsFeatureProvider mMetricsFeatureProvider;
|
private MetricsFeatureProvider mMetricsFeatureProvider;
|
||||||
@Mock
|
@Mock
|
||||||
private Context mContext;
|
|
||||||
@Mock
|
|
||||||
private MasterSwitchController mMasterSwitchController;
|
|
||||||
@Mock
|
|
||||||
private RestrictionUtils mRestrictionUtils;
|
private RestrictionUtils mRestrictionUtils;
|
||||||
@Mock
|
@Mock
|
||||||
private LocalBluetoothManager mBluetoothManager;
|
private LocalBluetoothManager mBluetoothManager;
|
||||||
@Mock
|
@Mock
|
||||||
private LocalBluetoothAdapter mBluetoothAdapter;
|
private LocalBluetoothAdapter mBluetoothAdapter;
|
||||||
|
|
||||||
|
private Context mContext;
|
||||||
|
Switch mSwitch;
|
||||||
|
private MasterSwitchPreference mMasterSwitchPreference;
|
||||||
|
private MasterSwitchController mMasterSwitchController;
|
||||||
private BluetoothEnabler mBluetoothEnabler;
|
private BluetoothEnabler mBluetoothEnabler;
|
||||||
|
|
||||||
@Before
|
@Before
|
||||||
public void setUp() {
|
public void setUp() {
|
||||||
MockitoAnnotations.initMocks(this);
|
MockitoAnnotations.initMocks(this);
|
||||||
|
mContext = spy(RuntimeEnvironment.application);
|
||||||
when(mBluetoothManager.getBluetoothAdapter()).thenReturn(mBluetoothAdapter);
|
when(mBluetoothManager.getBluetoothAdapter()).thenReturn(mBluetoothAdapter);
|
||||||
|
|
||||||
|
mSwitch = new Switch(mContext);
|
||||||
|
mMasterSwitchPreference = new MasterSwitchPreference(mContext);
|
||||||
|
mMasterSwitchController = spy(new MasterSwitchController(mMasterSwitchPreference));
|
||||||
mBluetoothEnabler = new BluetoothEnabler(
|
mBluetoothEnabler = new BluetoothEnabler(
|
||||||
mContext,
|
mContext,
|
||||||
mMasterSwitchController,
|
mMasterSwitchController,
|
||||||
@@ -77,6 +96,9 @@ public class BluetoothEnablerTest {
|
|||||||
mBluetoothManager,
|
mBluetoothManager,
|
||||||
123,
|
123,
|
||||||
mRestrictionUtils);
|
mRestrictionUtils);
|
||||||
|
PreferenceViewHolder holder = PreferenceViewHolder.createInstanceForTests(mock(View.class));
|
||||||
|
when(holder.findViewById(R.id.switchWidget)).thenReturn(mSwitch);
|
||||||
|
mMasterSwitchPreference.onBindViewHolder(holder);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
@@ -155,4 +177,71 @@ public class BluetoothEnablerTest {
|
|||||||
verify(mMasterSwitchController, never()).setEnabled(true);
|
verify(mMasterSwitchController, never()).setEnabled(true);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void startWithBluetoothOff_switchIsOff() {
|
||||||
|
when(mBluetoothAdapter.getBluetoothState()).thenReturn(BluetoothAdapter.STATE_OFF);
|
||||||
|
verify(mMasterSwitchController, never()).setChecked(anyBoolean());
|
||||||
|
mBluetoothEnabler.resume(mContext);
|
||||||
|
verify(mMasterSwitchController, never()).setChecked(true);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void startWithBluetoothOn_switchIsOn() {
|
||||||
|
when(mBluetoothAdapter.getBluetoothState()).thenReturn(BluetoothAdapter.STATE_ON);
|
||||||
|
verify(mMasterSwitchController, never()).setChecked(anyBoolean());
|
||||||
|
mBluetoothEnabler.resume(mContext);
|
||||||
|
verify(mMasterSwitchController, never()).setChecked(false);
|
||||||
|
verify(mMasterSwitchController).setChecked(true);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void bluetoothTurnsOff_switchTurnsOff() {
|
||||||
|
// Start up with bluetooth turned on. The switch should get turned on.
|
||||||
|
assertThat(mSwitch.isChecked()).isFalse();
|
||||||
|
ArgumentCaptor<BroadcastReceiver> captor = ArgumentCaptor.forClass(BroadcastReceiver.class);
|
||||||
|
when(mContext.registerReceiver(captor.capture(), any(IntentFilter.class))).thenReturn(null);
|
||||||
|
when(mBluetoothAdapter.getBluetoothState()).thenReturn(BluetoothAdapter.STATE_ON);
|
||||||
|
verify(mMasterSwitchController, never()).setChecked(anyBoolean());
|
||||||
|
mBluetoothEnabler.resume(mContext);
|
||||||
|
verify(mMasterSwitchController, never()).setChecked(false);
|
||||||
|
verify(mMasterSwitchController).setChecked(true);
|
||||||
|
|
||||||
|
// Now simulate bluetooth being turned off via an event.
|
||||||
|
BroadcastReceiver receiver = captor.getValue();
|
||||||
|
Intent turningOff = new Intent(BluetoothAdapter.ACTION_STATE_CHANGED);
|
||||||
|
turningOff.putExtra(BluetoothAdapter.EXTRA_STATE, BluetoothAdapter.STATE_TURNING_OFF);
|
||||||
|
receiver.onReceive(mContext, turningOff);
|
||||||
|
Intent off = new Intent(BluetoothAdapter.ACTION_STATE_CHANGED);
|
||||||
|
off.putExtra(BluetoothAdapter.EXTRA_STATE, BluetoothAdapter.STATE_OFF);
|
||||||
|
receiver.onReceive(mContext, off);
|
||||||
|
|
||||||
|
// Make sure the switch was turned off.
|
||||||
|
verify(mMasterSwitchController).setChecked(false);
|
||||||
|
assertThat(mSwitch.isChecked()).isFalse();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void bluetoothTurnsOn_switchTurnsOn() {
|
||||||
|
// Start up with bluetooth turned on. The switch should be left off.
|
||||||
|
assertThat(mSwitch.isChecked()).isFalse();
|
||||||
|
ArgumentCaptor<BroadcastReceiver> captor = ArgumentCaptor.forClass(BroadcastReceiver.class);
|
||||||
|
when(mContext.registerReceiver(captor.capture(), any(IntentFilter.class))).thenReturn(null);
|
||||||
|
when(mBluetoothAdapter.getBluetoothState()).thenReturn(BluetoothAdapter.STATE_OFF);
|
||||||
|
verify(mMasterSwitchController, never()).setChecked(anyBoolean());
|
||||||
|
mBluetoothEnabler.resume(mContext);
|
||||||
|
verify(mMasterSwitchController, never()).setChecked(anyBoolean());
|
||||||
|
|
||||||
|
// Now simulate bluetooth being turned on via an event.
|
||||||
|
BroadcastReceiver receiver = captor.getValue();
|
||||||
|
Intent turningOn = new Intent(BluetoothAdapter.ACTION_STATE_CHANGED);
|
||||||
|
turningOn.putExtra(BluetoothAdapter.EXTRA_STATE, BluetoothAdapter.STATE_TURNING_ON);
|
||||||
|
receiver.onReceive(mContext, turningOn);
|
||||||
|
Intent on = new Intent(BluetoothAdapter.ACTION_STATE_CHANGED);
|
||||||
|
on.putExtra(BluetoothAdapter.EXTRA_STATE, BluetoothAdapter.STATE_ON);
|
||||||
|
receiver.onReceive(mContext, on);
|
||||||
|
|
||||||
|
// Make sure the switch was turned on.
|
||||||
|
verify(mMasterSwitchController).setChecked(true);
|
||||||
|
assertThat(mSwitch.isChecked()).isTrue();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user