Convert BatterySaverButton controller to Slice compatible.

- Update preference key to match the key defined in SettingsSlicesContract
- Model TwoStateButtonPreference similar to TwoStatePreference (add
  setChecked, isChecked method)
- Remove TwoStateButtonPreferenceController entirely because all methods
  are moved into Preference directly for better encapsulation.
- Make BatterySaverButtonPrefController direclty implement
  TogglePreferenceController. It was not possible before because the
  interface between TwoStateButtonPreferene is too different from
  TwoStatePreference.

Bug: 80106671
Test: robotests
Change-Id: Ib72807dcf1b36e959e08df8d80538c3f9f79b76d
This commit is contained in:
Fan Zhang
2018-05-22 14:12:32 -07:00
committed by Matthew Fritze
parent c4a3393b45
commit ddc6c646c0
7 changed files with 159 additions and 198 deletions

View File

@@ -18,32 +18,35 @@
xmlns:android="http://schemas.android.com/apk/res/android" xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:settings="http://schemas.android.com/apk/res-auto" xmlns:settings="http://schemas.android.com/apk/res-auto"
android:title="@string/battery_saver" android:title="@string/battery_saver"
android:key="battery_saver"> android:key="battery_saver_page">
<!-- Turn on automatically --> <!-- Turn on automatically -->
<SwitchPreference <SwitchPreference
android:key="auto_battery_saver" android:key="auto_battery_saver"
android:title="@string/battery_saver_auto_title" android:title="@string/battery_saver_auto_title"
settings:controller="com.android.settings.fuelgauge.batterysaver.AutoBatterySaverPreferenceController"/> settings:controller="com.android.settings.fuelgauge.batterysaver.AutoBatterySaverPreferenceController" />
<com.android.settings.widget.SeekBarPreference <com.android.settings.widget.SeekBarPreference
android:key="battery_saver_seek_bar" android:key="battery_saver_seek_bar"
android:title="@string/battery_saver_seekbar_title_placeholder" android:title="@string/battery_saver_seekbar_title_placeholder"
android:max="75" android:max="75"
android:min="5"/> android:min="5" />
<com.android.settings.widget.TwoStateButtonPreference <com.android.settings.widget.TwoStateButtonPreference
android:key="battery_saver_button_container" android:key="battery_saver"
android:title="@string/battery_saver"
android:selectable="false" android:selectable="false"
settings:textOn="@string/battery_saver_button_turn_on" settings:textOn="@string/battery_saver_button_turn_on"
settings:textOff="@string/battery_saver_button_turn_off"/> settings:textOff="@string/battery_saver_button_turn_off"
settings:platform_slice="true"
settings:controller="com.android.settings.fuelgauge.batterysaver.BatterySaverButtonPreferenceController" />
<PreferenceCategory <PreferenceCategory
android:key="battery_saver_footer"> android:key="battery_saver_footer">
<com.android.settingslib.widget.FooterPreference <com.android.settingslib.widget.FooterPreference
android:key="battery_saver_footer_preference" android:key="battery_saver_footer_preference"
android:title="@*android:string/battery_saver_description" android:title="@*android:string/battery_saver_description"
android:selectable="false"/> android:selectable="false" />
</PreferenceCategory> </PreferenceCategory>
</PreferenceScreen> </PreferenceScreen>

View File

@@ -18,36 +18,45 @@ package com.android.settings.fuelgauge.batterysaver;
import android.content.Context; import android.content.Context;
import android.os.PowerManager; import android.os.PowerManager;
import androidx.annotation.VisibleForTesting;
import androidx.preference.Preference;
import com.android.settings.core.TogglePreferenceController;
import com.android.settings.fuelgauge.BatterySaverReceiver; import com.android.settings.fuelgauge.BatterySaverReceiver;
import com.android.settings.widget.TwoStateButtonPreferenceController; import com.android.settings.widget.TwoStateButtonPreference;
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.OnStart; import com.android.settingslib.core.lifecycle.events.OnStart;
import com.android.settingslib.core.lifecycle.events.OnStop; import com.android.settingslib.core.lifecycle.events.OnStop;
import com.android.settingslib.fuelgauge.BatterySaverUtils; import com.android.settingslib.fuelgauge.BatterySaverUtils;
import androidx.preference.Preference;
import androidx.preference.PreferenceScreen;
/** /**
* Controller to update the battery saver button * Controller to update the battery saver button
*/ */
public class BatterySaverButtonPreferenceController extends public class BatterySaverButtonPreferenceController extends
TwoStateButtonPreferenceController implements TogglePreferenceController implements
LifecycleObserver, OnStart, OnStop, BatterySaverReceiver.BatterySaverListener { LifecycleObserver, OnStart, OnStop, BatterySaverReceiver.BatterySaverListener {
private static final String KEY = "battery_saver_button_container";
private BatterySaverReceiver mBatterySaverReceiver;
@VisibleForTesting
PowerManager mPowerManager;
public BatterySaverButtonPreferenceController(Context context, Lifecycle lifecycle) { private final BatterySaverReceiver mBatterySaverReceiver;
super(context, KEY); private final PowerManager mPowerManager;
private TwoStateButtonPreference mPreference;
public BatterySaverButtonPreferenceController(Context context, String key) {
super(context, key);
mPowerManager = (PowerManager) context.getSystemService(Context.POWER_SERVICE); mPowerManager = (PowerManager) context.getSystemService(Context.POWER_SERVICE);
mBatterySaverReceiver = new BatterySaverReceiver(context); mBatterySaverReceiver = new BatterySaverReceiver(context);
mBatterySaverReceiver.setBatterySaverListener(this); mBatterySaverReceiver.setBatterySaverListener(this);
if (lifecycle != null) { }
lifecycle.addObserver(this);
} @Override
public int getAvailabilityStatus() {
return AVAILABLE;
}
@Override
public boolean isSliceable() {
return true;
} }
@Override @Override
@@ -60,30 +69,44 @@ public class BatterySaverButtonPreferenceController extends
mBatterySaverReceiver.setListening(false); mBatterySaverReceiver.setListening(false);
} }
@Override
public void displayPreference(PreferenceScreen screen) {
super.displayPreference(screen);
mPreference = (TwoStateButtonPreference) screen.findPreference(getPreferenceKey());
}
@Override
public boolean isChecked() {
return mPowerManager.isPowerSaveMode();
}
@Override
public boolean setChecked(boolean stateOn) {
// This screen already shows a warning, so we don't need another warning.
return BatterySaverUtils.setPowerSaveMode(mContext, stateOn,
false /* needFirstTimeWarning */);
}
@Override @Override
public void updateState(Preference preference) { public void updateState(Preference preference) {
super.updateState(preference); super.updateState(preference);
setButtonVisibility(!mPowerManager.isPowerSaveMode()); if (mPreference != null) {
} mPreference.setChecked(isChecked());
}
@Override
public int getAvailabilityStatus() {
return AVAILABLE;
}
@Override
public void onButtonClicked(boolean stateOn) {
// This screen already shows a warning, so we don't need another warning.
BatterySaverUtils.setPowerSaveMode(mContext, stateOn, /*needFirstTimeWarning*/ false);
} }
@Override @Override
public void onPowerSaveModeChanged() { public void onPowerSaveModeChanged() {
setButtonVisibility(!mPowerManager.isPowerSaveMode()); final boolean isChecked = isChecked();
if (mPreference != null && mPreference.isChecked() != isChecked) {
mPreference.setChecked(isChecked);
}
} }
@Override @Override
public void onBatteryChanged(boolean pluggedIn) { public void onBatteryChanged(boolean pluggedIn) {
setButtonEnabled(!pluggedIn); if (mPreference != null) {
mPreference.setButtonEnabled(!pluggedIn);
}
} }
} }

View File

@@ -75,7 +75,6 @@ public class BatterySaverSettings extends DashboardFragment {
final List<AbstractPreferenceController> controllers = new ArrayList<>(); final List<AbstractPreferenceController> controllers = new ArrayList<>();
controllers.add(new AutoBatterySaverPreferenceController(context)); controllers.add(new AutoBatterySaverPreferenceController(context));
controllers.add(new AutoBatterySeekBarPreferenceController(context, lifecycle)); controllers.add(new AutoBatterySeekBarPreferenceController(context, lifecycle));
controllers.add(new BatterySaverButtonPreferenceController(context, lifecycle));
return controllers; return controllers;
} }

View File

@@ -18,22 +18,34 @@ package com.android.settings.widget;
import android.content.Context; import android.content.Context;
import android.content.res.TypedArray; import android.content.res.TypedArray;
import androidx.core.content.res.TypedArrayUtils;
import android.util.AttributeSet; import android.util.AttributeSet;
import android.view.View;
import android.widget.Button; import android.widget.Button;
import com.android.settings.R; import com.android.settings.R;
import com.android.settings.applications.LayoutPreference; import com.android.settings.applications.LayoutPreference;
import androidx.annotation.VisibleForTesting;
import androidx.core.content.res.TypedArrayUtils;
/** /**
* Preference that presents a button with two states(On vs Off) * Preference that presents a button with two states(On vs Off)
*/ */
public class TwoStateButtonPreference extends LayoutPreference { public class TwoStateButtonPreference extends LayoutPreference implements
View.OnClickListener {
private boolean mIsChecked;
private final Button mButtonOn;
private final Button mButtonOff;
public TwoStateButtonPreference(Context context, AttributeSet attrs) { public TwoStateButtonPreference(Context context, AttributeSet attrs) {
super(context, attrs, TypedArrayUtils.getAttr( super(context, attrs, TypedArrayUtils.getAttr(
context, R.attr.twoStateButtonPreferenceStyle, android.R.attr.preferenceStyle)); context, R.attr.twoStateButtonPreferenceStyle, android.R.attr.preferenceStyle));
if (attrs != null) { if (attrs == null) {
mButtonOn = null;
mButtonOff = null;
} else {
final TypedArray styledAttrs = context.obtainStyledAttributes(attrs, final TypedArray styledAttrs = context.obtainStyledAttributes(attrs,
R.styleable.TwoStateButtonPreference); R.styleable.TwoStateButtonPreference);
final int textOnId = styledAttrs.getResourceId( final int textOnId = styledAttrs.getResourceId(
@@ -44,19 +56,52 @@ public class TwoStateButtonPreference extends LayoutPreference {
R.string.summary_placeholder); R.string.summary_placeholder);
styledAttrs.recycle(); styledAttrs.recycle();
final Button buttonOn = getStateOnButton(); mButtonOn = findViewById(R.id.state_on_button);
buttonOn.setText(textOnId); mButtonOn.setText(textOnId);
final Button buttonOff = getStateOffButton(); mButtonOn.setOnClickListener(this);
buttonOff.setText(textOffId); mButtonOff = findViewById(R.id.state_off_button);
mButtonOff.setText(textOffId);
mButtonOff.setOnClickListener(this);
setChecked(isChecked());
} }
} }
public Button getStateOnButton() { @Override
return findViewById(R.id.state_on_button); public void onClick(View v) {
final boolean stateOn = v.getId() == R.id.state_on_button;
setChecked(stateOn);
callChangeListener(stateOn);
} }
public void setChecked(boolean checked) {
// Update state
mIsChecked = checked;
// And update UI
if (checked) {
mButtonOn.setVisibility(View.GONE);
mButtonOff.setVisibility(View.VISIBLE);
} else {
mButtonOn.setVisibility(View.VISIBLE);
mButtonOff.setVisibility(View.GONE);
}
}
public boolean isChecked() {
return mIsChecked;
}
public void setButtonEnabled(boolean enabled) {
mButtonOn.setEnabled(enabled);
mButtonOff.setEnabled(enabled);
}
@VisibleForTesting
public Button getStateOnButton() {
return mButtonOn;
}
@VisibleForTesting
public Button getStateOffButton() { public Button getStateOffButton() {
return findViewById(R.id.state_off_button); return mButtonOff;
} }
} }

View File

@@ -1,78 +0,0 @@
/*
* Copyright (C) 2018 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.widget;
import android.content.Context;
import androidx.preference.PreferenceScreen;
import android.view.View;
import android.widget.Button;
import com.android.settings.R;
import com.android.settings.core.BasePreferenceController;
/**
* Controller to update the button with two states(On vs Off).
*/
public abstract class TwoStateButtonPreferenceController extends BasePreferenceController
implements View.OnClickListener {
private Button mButtonOn;
private Button mButtonOff;
public TwoStateButtonPreferenceController(Context context, String key) {
super(context, key);
}
@Override
public void displayPreference(PreferenceScreen screen) {
super.displayPreference(screen);
final TwoStateButtonPreference preference =
(TwoStateButtonPreference) screen.findPreference(getPreferenceKey());
mButtonOn = preference.getStateOnButton();
mButtonOn.setOnClickListener(this);
mButtonOff = preference.getStateOffButton();
mButtonOff.setOnClickListener(this);
}
protected void setButtonVisibility(boolean stateOn) {
if (stateOn) {
mButtonOff.setVisibility(View.GONE);
mButtonOn.setVisibility(View.VISIBLE);
} else {
mButtonOff.setVisibility(View.VISIBLE);
mButtonOn.setVisibility(View.GONE);
}
}
protected void setButtonEnabled(boolean enabled) {
mButtonOn.setEnabled(enabled);
mButtonOff.setEnabled(enabled);
}
@Override
public void onClick(View v) {
final boolean stateOn = v.getId() == R.id.state_on_button;
onButtonClicked(stateOn);
}
/**
* Callback when button is clicked
*
* @param stateOn {@code true} if stateOn button is clicked, otherwise it means stateOff
* button is clicked
*/
public abstract void onButtonClicked(boolean stateOn);
}

View File

@@ -21,17 +21,12 @@ import static org.mockito.Matchers.anyString;
import static org.mockito.Mockito.doReturn; import static org.mockito.Mockito.doReturn;
import static org.mockito.Mockito.spy; import static org.mockito.Mockito.spy;
import androidx.lifecycle.LifecycleOwner;
import android.content.Context; import android.content.Context;
import android.os.PowerManager; import android.os.PowerManager;
import androidx.preference.PreferenceScreen;
import android.view.View;
import android.widget.Button; import android.widget.Button;
import com.android.settings.R;
import com.android.settings.testutils.SettingsRobolectricTestRunner; import com.android.settings.testutils.SettingsRobolectricTestRunner;
import com.android.settings.widget.TwoStateButtonPreference; import com.android.settings.widget.TwoStateButtonPreference;
import com.android.settingslib.core.lifecycle.Lifecycle;
import org.junit.Before; import org.junit.Before;
import org.junit.Test; import org.junit.Test;
@@ -41,6 +36,9 @@ import org.mockito.MockitoAnnotations;
import org.robolectric.RuntimeEnvironment; import org.robolectric.RuntimeEnvironment;
import org.robolectric.annotation.Config; import org.robolectric.annotation.Config;
import org.robolectric.shadows.ShadowPowerManager; import org.robolectric.shadows.ShadowPowerManager;
import org.robolectric.util.ReflectionHelpers;
import androidx.preference.PreferenceScreen;
@RunWith(SettingsRobolectricTestRunner.class) @RunWith(SettingsRobolectricTestRunner.class)
@Config(shadows = ShadowPowerManager.class) @Config(shadows = ShadowPowerManager.class)
@@ -48,67 +46,58 @@ public class BatterySaverButtonPreferenceControllerTest {
private BatterySaverButtonPreferenceController mController; private BatterySaverButtonPreferenceController mController;
private Context mContext; private Context mContext;
private Lifecycle mLifecycle;
private LifecycleOwner mLifecycleOwner;
private Button mButtonOn; private Button mButtonOn;
private Button mButtonOff; private Button mButtonOff;
private PowerManager mPowerManager; private PowerManager mPowerManager;
@Mock
private TwoStateButtonPreference mPreference; private TwoStateButtonPreference mPreference;
@Mock @Mock
private PreferenceScreen mPreferenceScreen; private PreferenceScreen mPreferenceScreen;
@Before @Before
public void setUp() { public void setUp() {
MockitoAnnotations.initMocks(this); MockitoAnnotations.initMocks(this);
mLifecycleOwner = () -> mLifecycle;
mLifecycle = new Lifecycle(mLifecycleOwner);
mContext = spy(RuntimeEnvironment.application); mContext = spy(RuntimeEnvironment.application);
mButtonOn = new Button(mContext);
mButtonOff = new Button(mContext);
mPowerManager = (PowerManager) mContext.getSystemService(Context.POWER_SERVICE); mPowerManager = (PowerManager) mContext.getSystemService(Context.POWER_SERVICE);
mPreference = spy(new TwoStateButtonPreference(mContext, null /* AttributeSet */));
ReflectionHelpers.setField(mPreference, "mButtonOn", mButtonOn);
ReflectionHelpers.setField(mPreference, "mButtonOff", mButtonOff);
doReturn(mPreference).when(mPreferenceScreen).findPreference(anyString()); doReturn(mPreference).when(mPreferenceScreen).findPreference(anyString());
mButtonOn = new Button(mContext); mController = new BatterySaverButtonPreferenceController(mContext, "test_key");
mButtonOn.setId(R.id.state_on_button);
doReturn(mButtonOn).when(mPreference).getStateOnButton();
mButtonOff = new Button(mContext);
mButtonOff.setId(R.id.state_off_button);
doReturn(mButtonOff).when(mPreference).getStateOffButton();
mController = new BatterySaverButtonPreferenceController(mContext, mLifecycle);
mController.displayPreference(mPreferenceScreen); mController.displayPreference(mPreferenceScreen);
} }
@Test @Test
public void testUpdateState_lowPowerOn_displayButtonOff() { public void updateState_lowPowerOn_preferenceIsChecked() {
mPowerManager.setPowerSaveMode(true); mPowerManager.setPowerSaveMode(true);
mController.updateState(mPreference); mController.updateState(mPreference);
assertThat(mButtonOn.getVisibility()).isEqualTo(View.GONE); assertThat(mPreference.isChecked()).isTrue();
assertThat(mButtonOff.getVisibility()).isEqualTo(View.VISIBLE);
} }
@Test @Test
public void testUpdateState_lowPowerOff_displayButtonOn() { public void testUpdateState_lowPowerOff_preferenceIsUnchecked() {
mPowerManager.setPowerSaveMode(false); mPowerManager.setPowerSaveMode(false);
mController.updateState(mPreference); mController.updateState(mPreference);
assertThat(mButtonOn.getVisibility()).isEqualTo(View.VISIBLE); assertThat(mPreference.isChecked()).isFalse();
assertThat(mButtonOff.getVisibility()).isEqualTo(View.GONE);
} }
@Test @Test
public void testOnClick_clickButtonOn_setPowerSaveMode() { public void setChecked_on_setPowerSaveMode() {
mController.onClick(mButtonOn); mController.setChecked(true);
assertThat(mPowerManager.isPowerSaveMode()).isTrue(); assertThat(mPowerManager.isPowerSaveMode()).isTrue();
} }
@Test @Test
public void testOnClick_clickButtonOff_clearPowerSaveMode() { public void setChecked_off_unsetPowerSaveMode() {
mController.onClick(mButtonOff); mController.setChecked(false);
assertThat(mPowerManager.isPowerSaveMode()).isFalse(); assertThat(mPowerManager.isPowerSaveMode()).isFalse();
} }

View File

@@ -17,34 +17,27 @@
package com.android.settings.widget; package com.android.settings.widget;
import static com.google.common.truth.Truth.assertThat; import static com.google.common.truth.Truth.assertThat;
import static org.mockito.Matchers.anyString;
import static org.mockito.Mockito.doReturn;
import static org.mockito.Mockito.spy; import static org.mockito.Mockito.spy;
import static org.mockito.Mockito.verify;
import android.content.Context; import android.content.Context;
import androidx.preference.PreferenceScreen;
import android.view.View; import android.view.View;
import android.widget.Button; import android.widget.Button;
import com.android.settings.R;
import com.android.settings.testutils.SettingsRobolectricTestRunner; import com.android.settings.testutils.SettingsRobolectricTestRunner;
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.Mock;
import org.mockito.MockitoAnnotations; import org.mockito.MockitoAnnotations;
import org.robolectric.RuntimeEnvironment; import org.robolectric.RuntimeEnvironment;
import org.robolectric.util.ReflectionHelpers;
@RunWith(SettingsRobolectricTestRunner.class) @RunWith(SettingsRobolectricTestRunner.class)
public class TwoStateButtonPreferenceControllerTest { public class TwoStateButtonPreferenceTest {
private static final String KEY = "pref_key";
@Mock
private PreferenceScreen mPreferenceScreen;
@Mock
private TwoStateButtonPreference mPreference; private TwoStateButtonPreference mPreference;
private TwoStateButtonPreferenceController mController;
private Context mContext; private Context mContext;
private Button mButtonOn; private Button mButtonOn;
private Button mButtonOff; private Button mButtonOff;
@@ -53,35 +46,34 @@ public class TwoStateButtonPreferenceControllerTest {
public void setUp() { public void setUp() {
MockitoAnnotations.initMocks(this); MockitoAnnotations.initMocks(this);
mContext = spy(RuntimeEnvironment.application); mContext = spy(RuntimeEnvironment.application);
doReturn(mPreference).when(mPreferenceScreen).findPreference(anyString()); mPreference = spy(new TwoStateButtonPreference(mContext, null /* AttributeSet */));
mButtonOn = new Button(mContext); mButtonOn = new Button(mContext);
doReturn(mButtonOn).when(mPreference).getStateOnButton(); mButtonOn.setId(R.id.state_on_button);
mButtonOff = new Button(mContext); mButtonOff = new Button(mContext);
doReturn(mButtonOff).when(mPreference).getStateOffButton(); mButtonOff.setId(R.id.state_off_button);
ReflectionHelpers.setField(mPreference, "mButtonOn", mButtonOn);
mController = new TestButtonsPreferenceController(mContext, KEY); ReflectionHelpers.setField(mPreference, "mButtonOff", mButtonOff);
mController.displayPreference(mPreferenceScreen);
} }
@Test @Test
public void testSetButtonVisibility_stateOn_onlyShowButtonOn() { public void testSetButtonVisibility_stateOn_onlyShowButtonOn() {
mController.setButtonVisibility(true /* stateOn */); mPreference.setChecked(true /* stateOn */);
assertThat(mButtonOn.getVisibility()).isEqualTo(View.VISIBLE);
assertThat(mButtonOff.getVisibility()).isEqualTo(View.GONE);
}
@Test
public void testSetButtonVisibility_stateOff_onlyShowButtonOff() {
mController.setButtonVisibility(false /* stateOn */);
assertThat(mButtonOn.getVisibility()).isEqualTo(View.GONE); assertThat(mButtonOn.getVisibility()).isEqualTo(View.GONE);
assertThat(mButtonOff.getVisibility()).isEqualTo(View.VISIBLE); assertThat(mButtonOff.getVisibility()).isEqualTo(View.VISIBLE);
} }
@Test
public void testSetButtonVisibility_stateOff_onlyShowButtonOff() {
mPreference.setChecked(false /* stateOn */);
assertThat(mButtonOn.getVisibility()).isEqualTo(View.VISIBLE);
assertThat(mButtonOff.getVisibility()).isEqualTo(View.GONE);
}
@Test @Test
public void testSetButtonEnabled_enabled_buttonEnabled() { public void testSetButtonEnabled_enabled_buttonEnabled() {
mController.setButtonEnabled(true /* enabled */); mPreference.setButtonEnabled(true /* enabled */);
assertThat(mButtonOn.isEnabled()).isTrue(); assertThat(mButtonOn.isEnabled()).isTrue();
assertThat(mButtonOff.isEnabled()).isTrue(); assertThat(mButtonOff.isEnabled()).isTrue();
@@ -89,30 +81,18 @@ public class TwoStateButtonPreferenceControllerTest {
@Test @Test
public void testSetButtonEnabled_disabled_buttonDisabled() { public void testSetButtonEnabled_disabled_buttonDisabled() {
mController.setButtonEnabled(false /* enabled */); mPreference.setButtonEnabled(false /* enabled */);
assertThat(mButtonOn.isEnabled()).isFalse(); assertThat(mButtonOn.isEnabled()).isFalse();
assertThat(mButtonOff.isEnabled()).isFalse(); assertThat(mButtonOff.isEnabled()).isFalse();
} }
/** @Test
* Controller to test methods in {@link TwoStateButtonPreferenceController} public void onClick_shouldPropagateChangeToListener() {
*/ mPreference.onClick(mButtonOn);
public static class TestButtonsPreferenceController verify(mPreference).callChangeListener(true);
extends TwoStateButtonPreferenceController {
TestButtonsPreferenceController(Context context, String key) { mPreference.onClick(mButtonOff);
super(context, key); verify(mPreference).callChangeListener(false);
}
@Override
public void onButtonClicked(boolean stateOn) {
//do nothing
}
@Override
public int getAvailabilityStatus() {
return AVAILABLE;
}
} }
} }