Replace some customized RadioButtonPreferences
- Deleted ZenCustomRadioButtonPreference - Deleted RadioButtonPreferenceWithExtraWidget - Replaced with RadioButtonPreference Bug: 173472216 Test: robotest Change-Id: I645b59d65ae14af1f384f16ee7b76b3c98e23e1f
This commit is contained in:
@@ -1,110 +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.notification.zen;
|
||||
|
||||
import static com.google.common.truth.Truth.assertThat;
|
||||
|
||||
import static org.mockito.Mockito.mock;
|
||||
import static org.mockito.Mockito.verify;
|
||||
|
||||
import android.content.Context;
|
||||
import android.view.LayoutInflater;
|
||||
import android.view.View;
|
||||
import android.widget.RadioButton;
|
||||
|
||||
import androidx.preference.PreferenceViewHolder;
|
||||
|
||||
import com.android.settings.R;
|
||||
import com.android.settings.notification.zen.ZenCustomRadioButtonPreference;
|
||||
|
||||
import org.junit.Before;
|
||||
import org.junit.Test;
|
||||
import org.junit.runner.RunWith;
|
||||
import org.robolectric.RobolectricTestRunner;
|
||||
import org.robolectric.RuntimeEnvironment;
|
||||
|
||||
@RunWith(RobolectricTestRunner.class)
|
||||
public class ZenCustomRadioButtonPreferenceTest {
|
||||
|
||||
private Context mContext;
|
||||
|
||||
@Before
|
||||
public void setUp() {
|
||||
mContext = RuntimeEnvironment.application;
|
||||
}
|
||||
|
||||
@Test
|
||||
public void createNewPreference_shouldSetLayout() {
|
||||
final ZenCustomRadioButtonPreference preference
|
||||
= new ZenCustomRadioButtonPreference(mContext);
|
||||
|
||||
assertThat(preference.getLayoutResource()).isEqualTo(R.layout.preference_two_target_radio);
|
||||
assertThat(preference.getWidgetLayoutResource())
|
||||
.isEqualTo(R.layout.preference_widget_gear);
|
||||
}
|
||||
|
||||
@Test
|
||||
public void setChecked_shouldUpdateButtonCheckedState() {
|
||||
final ZenCustomRadioButtonPreference preference =
|
||||
new ZenCustomRadioButtonPreference(mContext);
|
||||
final PreferenceViewHolder holder = PreferenceViewHolder.createInstanceForTests(
|
||||
LayoutInflater.from(mContext).inflate(
|
||||
R.layout.preference_two_target_radio, null));
|
||||
final RadioButton toggle = (RadioButton) holder.findViewById(android.R.id.checkbox);
|
||||
preference.onBindViewHolder(holder);
|
||||
|
||||
preference.setChecked(true);
|
||||
assertThat(toggle.isChecked()).isTrue();
|
||||
|
||||
preference.setChecked(false);
|
||||
assertThat(toggle.isChecked()).isFalse();
|
||||
}
|
||||
|
||||
@Test
|
||||
public void clickRadioButton_shouldNotifyRadioButtonClicked() {
|
||||
final ZenCustomRadioButtonPreference preference
|
||||
= new ZenCustomRadioButtonPreference(mContext);
|
||||
final PreferenceViewHolder holder = PreferenceViewHolder.createInstanceForTests(
|
||||
LayoutInflater.from(mContext).inflate(R.layout.preference_two_target_radio, null));
|
||||
final View toggle = holder.findViewById(R.id.checkbox_frame);
|
||||
|
||||
ZenCustomRadioButtonPreference.OnRadioButtonClickListener l = mock(
|
||||
ZenCustomRadioButtonPreference.OnRadioButtonClickListener.class);
|
||||
preference.setOnRadioButtonClickListener(l);
|
||||
preference.onBindViewHolder(holder);
|
||||
|
||||
toggle.performClick();
|
||||
verify(l).onRadioButtonClick(preference);
|
||||
}
|
||||
|
||||
@Test
|
||||
public void clickWidgetView_shouldNotifyWidgetClicked() {
|
||||
final ZenCustomRadioButtonPreference preference =
|
||||
new ZenCustomRadioButtonPreference(mContext);
|
||||
final PreferenceViewHolder holder = PreferenceViewHolder.createInstanceForTests(
|
||||
LayoutInflater.from(mContext).inflate(R.layout.preference_two_target_radio, null));
|
||||
final View widgetView = holder.findViewById(android.R.id.widget_frame);
|
||||
|
||||
ZenCustomRadioButtonPreference.OnGearClickListener l = mock(
|
||||
ZenCustomRadioButtonPreference.OnGearClickListener.class);
|
||||
preference.setOnGearClickListener(l);
|
||||
preference.onBindViewHolder(holder);
|
||||
|
||||
widgetView.performClick();
|
||||
verify(l).onGearClick(preference);
|
||||
}
|
||||
}
|
@@ -40,11 +40,9 @@ import android.content.Context;
|
||||
|
||||
import androidx.preference.PreferenceScreen;
|
||||
|
||||
import com.android.settings.notification.zen.ZenCustomRadioButtonPreference;
|
||||
import com.android.settings.notification.zen.ZenModeBackend;
|
||||
import com.android.settings.notification.zen.ZenModeVisEffectsAllPreferenceController;
|
||||
import com.android.settings.testutils.FakeFeatureFactory;
|
||||
import com.android.settingslib.core.lifecycle.Lifecycle;
|
||||
import com.android.settingslib.widget.RadioButtonPreference;
|
||||
|
||||
import org.junit.Before;
|
||||
import org.junit.Test;
|
||||
@@ -63,7 +61,7 @@ public class ZenModeVisEffectsAllPreferenceControllerTest {
|
||||
@Mock
|
||||
private ZenModeBackend mBackend;
|
||||
@Mock
|
||||
private ZenCustomRadioButtonPreference mockPref;
|
||||
private RadioButtonPreference mPref;
|
||||
private Context mContext;
|
||||
private FakeFeatureFactory mFeatureFactory;
|
||||
@Mock
|
||||
@@ -86,7 +84,7 @@ public class ZenModeVisEffectsAllPreferenceControllerTest {
|
||||
mContext, mock(Lifecycle.class), PREF_KEY);
|
||||
ReflectionHelpers.setField(mController, "mBackend", mBackend);
|
||||
|
||||
when(mScreen.findPreference(mController.getPreferenceKey())).thenReturn(mockPref);
|
||||
when(mScreen.findPreference(mController.getPreferenceKey())).thenReturn(mPref);
|
||||
mController.displayPreference(mScreen);
|
||||
}
|
||||
|
||||
@@ -98,9 +96,9 @@ public class ZenModeVisEffectsAllPreferenceControllerTest {
|
||||
@Test
|
||||
public void updateState_notChecked() {
|
||||
mBackend.mPolicy = new NotificationManager.Policy(0, 0, 0, 1);
|
||||
mController.updateState(mockPref);
|
||||
mController.updateState(mPref);
|
||||
|
||||
verify(mockPref).setChecked(false);
|
||||
verify(mPref).setChecked(false);
|
||||
}
|
||||
|
||||
@Test
|
||||
@@ -115,9 +113,9 @@ public class ZenModeVisEffectsAllPreferenceControllerTest {
|
||||
| SUPPRESSED_EFFECT_PEEK
|
||||
| SUPPRESSED_EFFECT_NOTIFICATION_LIST;
|
||||
mBackend.mPolicy = new NotificationManager.Policy(0, 0, 0, allSuppressed);
|
||||
mController.updateState(mockPref);
|
||||
mController.updateState(mPref);
|
||||
|
||||
verify(mockPref).setChecked(true);
|
||||
verify(mPref).setChecked(true);
|
||||
}
|
||||
|
||||
@Test
|
||||
@@ -132,7 +130,7 @@ public class ZenModeVisEffectsAllPreferenceControllerTest {
|
||||
| SUPPRESSED_EFFECT_PEEK
|
||||
| SUPPRESSED_EFFECT_NOTIFICATION_LIST;
|
||||
mBackend.mPolicy = new NotificationManager.Policy(0, 0, 0, 1);
|
||||
mController.onRadioButtonClick(mockPref);
|
||||
mController.onRadioButtonClicked(mPref);
|
||||
verify(mBackend).saveVisualEffectsPolicy(allSuppressed, true);
|
||||
verify(mFeatureFactory.metricsFeatureProvider).action(eq(mContext),
|
||||
eq(ACTION_ZEN_SOUND_AND_VIS_EFFECTS),
|
||||
|
@@ -38,11 +38,9 @@ import android.content.Context;
|
||||
|
||||
import androidx.preference.PreferenceScreen;
|
||||
|
||||
import com.android.settings.notification.zen.ZenCustomRadioButtonPreference;
|
||||
import com.android.settings.notification.zen.ZenModeBackend;
|
||||
import com.android.settings.notification.zen.ZenModeVisEffectsCustomPreferenceController;
|
||||
import com.android.settings.testutils.FakeFeatureFactory;
|
||||
import com.android.settingslib.core.lifecycle.Lifecycle;
|
||||
import com.android.settingslib.widget.RadioButtonPreference;
|
||||
|
||||
import org.junit.Before;
|
||||
import org.junit.Test;
|
||||
@@ -61,7 +59,7 @@ public class ZenModeVisEffectsCustomPreferenceControllerTest {
|
||||
@Mock
|
||||
private ZenModeBackend mBackend;
|
||||
@Mock
|
||||
private ZenCustomRadioButtonPreference mockPref;
|
||||
private RadioButtonPreference mPref;
|
||||
private Context mContext;
|
||||
@Mock
|
||||
private PreferenceScreen mScreen;
|
||||
@@ -83,7 +81,7 @@ public class ZenModeVisEffectsCustomPreferenceControllerTest {
|
||||
mContext, mock(Lifecycle.class), PREF_KEY);
|
||||
ReflectionHelpers.setField(mController, "mBackend", mBackend);
|
||||
|
||||
when(mScreen.findPreference(mController.getPreferenceKey())).thenReturn(mockPref);
|
||||
when(mScreen.findPreference(mController.getPreferenceKey())).thenReturn(mPref);
|
||||
mController.displayPreference(mScreen);
|
||||
}
|
||||
|
||||
@@ -102,9 +100,9 @@ public class ZenModeVisEffectsCustomPreferenceControllerTest {
|
||||
@Test
|
||||
public void updateState_notChecked_noVisEffects() {
|
||||
mBackend.mPolicy = new NotificationManager.Policy(0, 0, 0, 0);
|
||||
mController.updateState(mockPref);
|
||||
mController.updateState(mPref);
|
||||
|
||||
verify(mockPref).setChecked(false);
|
||||
verify(mPref).setChecked(false);
|
||||
}
|
||||
|
||||
@Test
|
||||
@@ -119,25 +117,25 @@ public class ZenModeVisEffectsCustomPreferenceControllerTest {
|
||||
| SUPPRESSED_EFFECT_PEEK
|
||||
| SUPPRESSED_EFFECT_NOTIFICATION_LIST;
|
||||
mBackend.mPolicy = new NotificationManager.Policy(0, 0, 0, allSuppressed);
|
||||
mController.updateState(mockPref);
|
||||
mController.updateState(mPref);
|
||||
|
||||
verify(mockPref).setChecked(false);
|
||||
verify(mPref).setChecked(false);
|
||||
}
|
||||
|
||||
@Test
|
||||
public void updateState_checked() {
|
||||
mBackend.mPolicy = new NotificationManager.Policy(0, 0, 0, 2);
|
||||
mController.updateState(mockPref);
|
||||
mController.updateState(mPref);
|
||||
|
||||
verify(mockPref).setChecked(true);
|
||||
verify(mPref).setChecked(true);
|
||||
}
|
||||
|
||||
@Test
|
||||
public void updateState_listeners() {
|
||||
mBackend.mPolicy = new NotificationManager.Policy(0, 0, 0, 2);
|
||||
mController.updateState(mockPref);
|
||||
mController.updateState(mPref);
|
||||
|
||||
verify(mockPref).setOnGearClickListener(any());
|
||||
verify(mockPref).setOnRadioButtonClickListener(any());
|
||||
verify(mPref).setExtraWidgetOnClickListener(any());
|
||||
verify(mPref).setOnClickListener(any());
|
||||
}
|
||||
}
|
||||
|
@@ -40,11 +40,9 @@ import android.content.Context;
|
||||
|
||||
import androidx.preference.PreferenceScreen;
|
||||
|
||||
import com.android.settings.notification.zen.ZenCustomRadioButtonPreference;
|
||||
import com.android.settings.notification.zen.ZenModeBackend;
|
||||
import com.android.settings.notification.zen.ZenModeVisEffectsNonePreferenceController;
|
||||
import com.android.settings.testutils.FakeFeatureFactory;
|
||||
import com.android.settingslib.core.lifecycle.Lifecycle;
|
||||
import com.android.settingslib.widget.RadioButtonPreference;
|
||||
|
||||
import org.junit.Before;
|
||||
import org.junit.Test;
|
||||
@@ -63,7 +61,7 @@ public class ZenModeVisEffectsNonePreferenceControllerTest {
|
||||
@Mock
|
||||
private ZenModeBackend mBackend;
|
||||
@Mock
|
||||
private ZenCustomRadioButtonPreference mockPref;
|
||||
private RadioButtonPreference mMockPref;
|
||||
private Context mContext;
|
||||
private FakeFeatureFactory mFeatureFactory;
|
||||
@Mock
|
||||
@@ -86,7 +84,7 @@ public class ZenModeVisEffectsNonePreferenceControllerTest {
|
||||
mContext, mock(Lifecycle.class), PREF_KEY);
|
||||
ReflectionHelpers.setField(mController, "mBackend", mBackend);
|
||||
|
||||
when(mScreen.findPreference(mController.getPreferenceKey())).thenReturn(mockPref);
|
||||
when(mScreen.findPreference(mController.getPreferenceKey())).thenReturn(mMockPref);
|
||||
mController.displayPreference(mScreen);
|
||||
}
|
||||
|
||||
@@ -98,17 +96,17 @@ public class ZenModeVisEffectsNonePreferenceControllerTest {
|
||||
@Test
|
||||
public void updateState_notChecked() {
|
||||
mBackend.mPolicy = new NotificationManager.Policy(0, 0, 0, 1);
|
||||
mController.updateState(mockPref);
|
||||
mController.updateState(mMockPref);
|
||||
|
||||
verify(mockPref).setChecked(false);
|
||||
verify(mMockPref).setChecked(false);
|
||||
}
|
||||
|
||||
@Test
|
||||
public void updateState_checked() {
|
||||
mBackend.mPolicy = new NotificationManager.Policy(0, 0, 0, 0);
|
||||
mController.updateState(mockPref);
|
||||
mController.updateState(mMockPref);
|
||||
|
||||
verify(mockPref).setChecked(true);
|
||||
verify(mMockPref).setChecked(true);
|
||||
}
|
||||
|
||||
@Test
|
||||
@@ -123,7 +121,7 @@ public class ZenModeVisEffectsNonePreferenceControllerTest {
|
||||
| SUPPRESSED_EFFECT_PEEK
|
||||
| SUPPRESSED_EFFECT_NOTIFICATION_LIST;
|
||||
mBackend.mPolicy = new NotificationManager.Policy(0, 0, 0, 1);
|
||||
mController.onRadioButtonClick(mockPref);
|
||||
mController.onRadioButtonClicked(mMockPref);
|
||||
verify(mBackend).saveVisualEffectsPolicy(allSuppressed, false);
|
||||
verify(mFeatureFactory.metricsFeatureProvider).action(nullable(Context.class),
|
||||
eq(ACTION_ZEN_SOUND_ONLY),
|
||||
|
@@ -27,6 +27,7 @@ import android.service.notification.ZenPolicy;
|
||||
import androidx.preference.PreferenceScreen;
|
||||
|
||||
import com.android.settingslib.core.lifecycle.Lifecycle;
|
||||
import com.android.settingslib.widget.RadioButtonPreference;
|
||||
|
||||
import org.junit.Before;
|
||||
import org.junit.Test;
|
||||
@@ -47,7 +48,7 @@ public class ZenRuleCustomPolicyPreferenceControllerTest extends
|
||||
@Mock
|
||||
private NotificationManager mNotificationManager;
|
||||
@Mock
|
||||
private ZenCustomRadioButtonPreference mockPref;
|
||||
private RadioButtonPreference mMockPref;
|
||||
@Mock
|
||||
private PreferenceScreen mScreen;
|
||||
|
||||
@@ -70,21 +71,21 @@ public class ZenRuleCustomPolicyPreferenceControllerTest extends
|
||||
PREF_KEY);
|
||||
ReflectionHelpers.setField(mController, "mBackend", mBackend);
|
||||
when(mBackend.getAutomaticZenRule(RULE_ID)).thenReturn(mRule);
|
||||
when(mScreen.findPreference(mController.getPreferenceKey())).thenReturn(mockPref);
|
||||
when(mScreen.findPreference(mController.getPreferenceKey())).thenReturn(mMockPref);
|
||||
mController.displayPreference(mScreen);
|
||||
}
|
||||
|
||||
@Test
|
||||
public void updateState_nullZenPolicy() {
|
||||
updateControllerZenPolicy(null);
|
||||
mController.updateState(mockPref);
|
||||
verify(mockPref).setChecked(false);
|
||||
mController.updateState(mMockPref);
|
||||
verify(mMockPref).setChecked(false);
|
||||
}
|
||||
|
||||
@Test
|
||||
public void updateState_hasZenPolicy() {
|
||||
updateControllerZenPolicy(new ZenPolicy.Builder().build());
|
||||
mController.updateState(mockPref);
|
||||
verify(mockPref).setChecked(true);
|
||||
mController.updateState(mMockPref);
|
||||
verify(mMockPref).setChecked(true);
|
||||
}
|
||||
}
|
||||
|
@@ -27,6 +27,7 @@ import android.service.notification.ZenPolicy;
|
||||
import androidx.preference.PreferenceScreen;
|
||||
|
||||
import com.android.settingslib.core.lifecycle.Lifecycle;
|
||||
import com.android.settingslib.widget.RadioButtonPreference;
|
||||
|
||||
import org.junit.Before;
|
||||
import org.junit.Test;
|
||||
@@ -47,7 +48,7 @@ public class ZenRuleDefaultPolicyPreferenceControllerTest extends
|
||||
@Mock
|
||||
private NotificationManager mNotificationManager;
|
||||
@Mock
|
||||
private ZenCustomRadioButtonPreference mockPref;
|
||||
private RadioButtonPreference mMockPref;
|
||||
@Mock
|
||||
private PreferenceScreen mScreen;
|
||||
|
||||
@@ -70,21 +71,21 @@ public class ZenRuleDefaultPolicyPreferenceControllerTest extends
|
||||
PREF_KEY);
|
||||
ReflectionHelpers.setField(mController, "mBackend", mBackend);
|
||||
when(mBackend.getAutomaticZenRule(RULE_ID)).thenReturn(mRule);
|
||||
when(mScreen.findPreference(mController.getPreferenceKey())).thenReturn(mockPref);
|
||||
when(mScreen.findPreference(mController.getPreferenceKey())).thenReturn(mMockPref);
|
||||
mController.displayPreference(mScreen);
|
||||
}
|
||||
|
||||
@Test
|
||||
public void updateState_nullZenPolicy() {
|
||||
updateControllerZenPolicy(null);
|
||||
mController.updateState(mockPref);
|
||||
verify(mockPref).setChecked(true);
|
||||
mController.updateState(mMockPref);
|
||||
verify(mMockPref).setChecked(true);
|
||||
}
|
||||
|
||||
@Test
|
||||
public void updateState_hasZenPolicy() {
|
||||
updateControllerZenPolicy(new ZenPolicy.Builder().build());
|
||||
mController.updateState(mockPref);
|
||||
verify(mockPref).setChecked(false);
|
||||
mController.updateState(mMockPref);
|
||||
verify(mMockPref).setChecked(false);
|
||||
}
|
||||
}
|
||||
|
@@ -28,10 +28,8 @@ import android.content.Context;
|
||||
|
||||
import androidx.preference.PreferenceScreen;
|
||||
|
||||
import com.android.settings.notification.zen.AbstractZenCustomRulePreferenceController;
|
||||
import com.android.settings.notification.zen.ZenCustomRadioButtonPreference;
|
||||
import com.android.settings.notification.zen.ZenModeBackend;
|
||||
import com.android.settingslib.core.lifecycle.Lifecycle;
|
||||
import com.android.settingslib.widget.RadioButtonPreference;
|
||||
|
||||
import org.junit.Before;
|
||||
import org.junit.Test;
|
||||
@@ -51,7 +49,7 @@ public class ZenRulePreferenceControllerTest {
|
||||
@Mock
|
||||
private NotificationManager mNotificationManager;
|
||||
@Mock
|
||||
private ZenCustomRadioButtonPreference mockPref;
|
||||
private RadioButtonPreference mMockPref;
|
||||
@Mock
|
||||
private PreferenceScreen mScreen;
|
||||
|
||||
@@ -67,7 +65,7 @@ public class ZenRulePreferenceControllerTest {
|
||||
mContext = RuntimeEnvironment.application;
|
||||
mController = new TestablePreferenceController(mContext,"test", mock(Lifecycle.class));
|
||||
ReflectionHelpers.setField(mController, "mBackend", mBackend);
|
||||
when(mScreen.findPreference(mController.getPreferenceKey())).thenReturn(mockPref);
|
||||
when(mScreen.findPreference(mController.getPreferenceKey())).thenReturn(mMockPref);
|
||||
mController.displayPreference(mScreen);
|
||||
}
|
||||
|
||||
|
@@ -27,6 +27,7 @@ import android.service.notification.ZenPolicy;
|
||||
import androidx.preference.PreferenceScreen;
|
||||
|
||||
import com.android.settingslib.core.lifecycle.Lifecycle;
|
||||
import com.android.settingslib.widget.RadioButtonPreference;
|
||||
|
||||
import org.junit.Before;
|
||||
import org.junit.Test;
|
||||
@@ -47,7 +48,7 @@ public class ZenRuleVisEffectsAllPreferenceControllerTest extends
|
||||
@Mock
|
||||
private NotificationManager mNotificationManager;
|
||||
@Mock
|
||||
private ZenCustomRadioButtonPreference mockPref;
|
||||
private RadioButtonPreference mMockPref;
|
||||
@Mock
|
||||
private PreferenceScreen mScreen;
|
||||
|
||||
@@ -69,7 +70,7 @@ public class ZenRuleVisEffectsAllPreferenceControllerTest extends
|
||||
PREF_KEY);
|
||||
ReflectionHelpers.setField(mController, "mBackend", mBackend);
|
||||
when(mBackend.getAutomaticZenRule(RULE_ID)).thenReturn(mRule);
|
||||
when(mScreen.findPreference(mController.getPreferenceKey())).thenReturn(mockPref);
|
||||
when(mScreen.findPreference(mController.getPreferenceKey())).thenReturn(mMockPref);
|
||||
mController.displayPreference(mScreen);
|
||||
}
|
||||
|
||||
@@ -78,8 +79,8 @@ public class ZenRuleVisEffectsAllPreferenceControllerTest extends
|
||||
updateControllerZenPolicy(new ZenPolicy.Builder()
|
||||
.hideAllVisualEffects()
|
||||
.build());
|
||||
mController.updateState(mockPref);
|
||||
verify(mockPref).setChecked(false);
|
||||
mController.updateState(mMockPref);
|
||||
verify(mMockPref).setChecked(false);
|
||||
}
|
||||
|
||||
@Test
|
||||
@@ -87,8 +88,8 @@ public class ZenRuleVisEffectsAllPreferenceControllerTest extends
|
||||
updateControllerZenPolicy(new ZenPolicy.Builder()
|
||||
.showAllVisualEffects()
|
||||
.build());
|
||||
mController.updateState(mockPref);
|
||||
verify(mockPref).setChecked(true);
|
||||
mController.updateState(mMockPref);
|
||||
verify(mMockPref).setChecked(true);
|
||||
}
|
||||
|
||||
@Test
|
||||
@@ -97,8 +98,8 @@ public class ZenRuleVisEffectsAllPreferenceControllerTest extends
|
||||
.showPeeking(true)
|
||||
.showBadges(false)
|
||||
.build());
|
||||
mController.updateState(mockPref);
|
||||
mController.updateState(mMockPref);
|
||||
|
||||
verify(mockPref).setChecked(false);
|
||||
verify(mMockPref).setChecked(false);
|
||||
}
|
||||
}
|
||||
|
@@ -27,6 +27,7 @@ import android.service.notification.ZenPolicy;
|
||||
import androidx.preference.PreferenceScreen;
|
||||
|
||||
import com.android.settingslib.core.lifecycle.Lifecycle;
|
||||
import com.android.settingslib.widget.RadioButtonPreference;
|
||||
|
||||
import org.junit.Before;
|
||||
import org.junit.Test;
|
||||
@@ -47,7 +48,7 @@ public class ZenRuleVisEffectsCustomPreferenceControllerTest extends
|
||||
@Mock
|
||||
private NotificationManager mNotificationManager;
|
||||
@Mock
|
||||
private ZenCustomRadioButtonPreference mockPref;
|
||||
private RadioButtonPreference mMockPref;
|
||||
@Mock
|
||||
private PreferenceScreen mScreen;
|
||||
|
||||
@@ -69,7 +70,7 @@ public class ZenRuleVisEffectsCustomPreferenceControllerTest extends
|
||||
PREF_KEY);
|
||||
ReflectionHelpers.setField(mController, "mBackend", mBackend);
|
||||
when(mBackend.getAutomaticZenRule(RULE_ID)).thenReturn(mRule);
|
||||
when(mScreen.findPreference(mController.getPreferenceKey())).thenReturn(mockPref);
|
||||
when(mScreen.findPreference(mController.getPreferenceKey())).thenReturn(mMockPref);
|
||||
mController.displayPreference(mScreen);
|
||||
}
|
||||
|
||||
@@ -78,8 +79,8 @@ public class ZenRuleVisEffectsCustomPreferenceControllerTest extends
|
||||
updateControllerZenPolicy(new ZenPolicy.Builder()
|
||||
.hideAllVisualEffects()
|
||||
.build());
|
||||
mController.updateState(mockPref);
|
||||
verify(mockPref).setChecked(false);
|
||||
mController.updateState(mMockPref);
|
||||
verify(mMockPref).setChecked(false);
|
||||
}
|
||||
|
||||
@Test
|
||||
@@ -87,8 +88,8 @@ public class ZenRuleVisEffectsCustomPreferenceControllerTest extends
|
||||
updateControllerZenPolicy(new ZenPolicy.Builder()
|
||||
.showAllVisualEffects()
|
||||
.build());
|
||||
mController.updateState(mockPref);
|
||||
verify(mockPref).setChecked(false);
|
||||
mController.updateState(mMockPref);
|
||||
verify(mMockPref).setChecked(false);
|
||||
}
|
||||
|
||||
@Test
|
||||
@@ -97,8 +98,8 @@ public class ZenRuleVisEffectsCustomPreferenceControllerTest extends
|
||||
.showPeeking(true)
|
||||
.showBadges(false)
|
||||
.build());
|
||||
mController.updateState(mockPref);
|
||||
mController.updateState(mMockPref);
|
||||
|
||||
verify(mockPref).setChecked(true);
|
||||
verify(mMockPref).setChecked(true);
|
||||
}
|
||||
}
|
||||
|
@@ -27,6 +27,7 @@ import android.service.notification.ZenPolicy;
|
||||
import androidx.preference.PreferenceScreen;
|
||||
|
||||
import com.android.settingslib.core.lifecycle.Lifecycle;
|
||||
import com.android.settingslib.widget.RadioButtonPreference;
|
||||
|
||||
import org.junit.Before;
|
||||
import org.junit.Test;
|
||||
@@ -47,7 +48,7 @@ public class ZenRuleVisEffectsNonePreferenceControllerTest extends
|
||||
@Mock
|
||||
private NotificationManager mNotificationManager;
|
||||
@Mock
|
||||
private ZenCustomRadioButtonPreference mockPref;
|
||||
private RadioButtonPreference mMockPref;
|
||||
@Mock
|
||||
private PreferenceScreen mScreen;
|
||||
|
||||
@@ -69,7 +70,7 @@ public class ZenRuleVisEffectsNonePreferenceControllerTest extends
|
||||
PREF_KEY);
|
||||
ReflectionHelpers.setField(mController, "mBackend", mBackend);
|
||||
when(mBackend.getAutomaticZenRule(RULE_ID)).thenReturn(mRule);
|
||||
when(mScreen.findPreference(mController.getPreferenceKey())).thenReturn(mockPref);
|
||||
when(mScreen.findPreference(mController.getPreferenceKey())).thenReturn(mMockPref);
|
||||
mController.displayPreference(mScreen);
|
||||
}
|
||||
|
||||
@@ -78,8 +79,8 @@ public class ZenRuleVisEffectsNonePreferenceControllerTest extends
|
||||
updateControllerZenPolicy(new ZenPolicy.Builder()
|
||||
.hideAllVisualEffects()
|
||||
.build());
|
||||
mController.updateState(mockPref);
|
||||
verify(mockPref).setChecked(true);
|
||||
mController.updateState(mMockPref);
|
||||
verify(mMockPref).setChecked(true);
|
||||
}
|
||||
|
||||
@Test
|
||||
@@ -87,8 +88,8 @@ public class ZenRuleVisEffectsNonePreferenceControllerTest extends
|
||||
updateControllerZenPolicy(new ZenPolicy.Builder()
|
||||
.showAllVisualEffects()
|
||||
.build());
|
||||
mController.updateState(mockPref);
|
||||
verify(mockPref).setChecked(false);
|
||||
mController.updateState(mMockPref);
|
||||
verify(mMockPref).setChecked(false);
|
||||
}
|
||||
|
||||
@Test
|
||||
@@ -97,8 +98,8 @@ public class ZenRuleVisEffectsNonePreferenceControllerTest extends
|
||||
.showPeeking(true)
|
||||
.showBadges(false)
|
||||
.build());
|
||||
mController.updateState(mockPref);
|
||||
mController.updateState(mMockPref);
|
||||
|
||||
verify(mockPref).setChecked(false);
|
||||
verify(mMockPref).setChecked(false);
|
||||
}
|
||||
}
|
||||
|
@@ -1,140 +0,0 @@
|
||||
/*
|
||||
* Copyright (C) 2019 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 static com.android.settings.widget.RadioButtonPreferenceWithExtraWidget.EXTRA_WIDGET_VISIBILITY_GONE;
|
||||
import static com.android.settings.widget.RadioButtonPreferenceWithExtraWidget.EXTRA_WIDGET_VISIBILITY_INFO;
|
||||
import static com.android.settings.widget.RadioButtonPreferenceWithExtraWidget.EXTRA_WIDGET_VISIBILITY_SETTING;
|
||||
|
||||
import static com.google.common.truth.Truth.assertThat;
|
||||
|
||||
import static org.junit.Assert.assertEquals;
|
||||
|
||||
import android.app.Application;
|
||||
import android.view.LayoutInflater;
|
||||
import android.view.View;
|
||||
import android.widget.ImageView;
|
||||
import android.widget.TextView;
|
||||
|
||||
import androidx.preference.PreferenceViewHolder;
|
||||
|
||||
import com.android.settings.R;
|
||||
|
||||
import org.junit.Before;
|
||||
import org.junit.Test;
|
||||
import org.junit.runner.RunWith;
|
||||
import org.robolectric.RobolectricTestRunner;
|
||||
import org.robolectric.RuntimeEnvironment;
|
||||
|
||||
@RunWith(RobolectricTestRunner.class)
|
||||
public class RadioButtonPreferenceWithExtraWidgetTest {
|
||||
|
||||
private Application mContext;
|
||||
private RadioButtonPreferenceWithExtraWidget mPreference;
|
||||
|
||||
private TextView mSummary;
|
||||
private ImageView mExtraWidget;
|
||||
private View mExtraWidgetDivider;
|
||||
|
||||
private boolean mIsClickListenerCalled = false;
|
||||
private View.OnClickListener mClickListener = new View.OnClickListener() {
|
||||
@Override
|
||||
public void onClick(View v) {
|
||||
mIsClickListenerCalled = true;
|
||||
}
|
||||
};
|
||||
|
||||
@Before
|
||||
public void setUp() {
|
||||
mContext = RuntimeEnvironment.application;
|
||||
mPreference = new RadioButtonPreferenceWithExtraWidget(mContext);
|
||||
mPreference.setSummary("test summary");
|
||||
|
||||
View view = LayoutInflater.from(mContext)
|
||||
.inflate(R.layout.preference_radio_with_extra_widget, null);
|
||||
PreferenceViewHolder preferenceViewHolder =
|
||||
PreferenceViewHolder.createInstanceForTests(view);
|
||||
mPreference.onBindViewHolder(preferenceViewHolder);
|
||||
|
||||
mSummary = view.findViewById(android.R.id.summary);
|
||||
mExtraWidget = view.findViewById(R.id.radio_extra_widget);
|
||||
mExtraWidgetDivider = view.findViewById(R.id.radio_extra_widget_divider);
|
||||
}
|
||||
|
||||
@Test
|
||||
public void shouldHaveRadioPreferenceWithExtraWidgetLayout() {
|
||||
assertThat(mPreference.getLayoutResource())
|
||||
.isEqualTo(R.layout.preference_radio_with_extra_widget);
|
||||
}
|
||||
|
||||
@Test
|
||||
public void iconSpaceReservedShouldBeFalse() {
|
||||
assertThat(mPreference.isIconSpaceReserved()).isFalse();
|
||||
}
|
||||
|
||||
@Test
|
||||
public void summaryShouldBeVisible() {
|
||||
assertEquals(View.VISIBLE, mSummary.getVisibility());
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testSetExtraWidgetVisibility_gone() {
|
||||
mPreference.setExtraWidgetVisibility(EXTRA_WIDGET_VISIBILITY_GONE);
|
||||
assertEquals(View.GONE, mExtraWidget.getVisibility());
|
||||
assertEquals(View.GONE, mExtraWidgetDivider.getVisibility());
|
||||
assertThat(mExtraWidget.isClickable()).isFalse();
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testSetExtraWidgetVisibility_info() {
|
||||
mPreference.setExtraWidgetVisibility(EXTRA_WIDGET_VISIBILITY_INFO);
|
||||
assertEquals(View.VISIBLE, mExtraWidget.getVisibility());
|
||||
assertEquals(View.VISIBLE, mExtraWidgetDivider.getVisibility());
|
||||
assertThat(mExtraWidget.isClickable()).isTrue();
|
||||
assertEquals(mContext.getResources().getText(R.string.information_label),
|
||||
mExtraWidget.getContentDescription());
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testSetExtraWidgetVisibility_setting() {
|
||||
mPreference.setExtraWidgetVisibility(EXTRA_WIDGET_VISIBILITY_SETTING);
|
||||
assertEquals(View.VISIBLE, mExtraWidget.getVisibility());
|
||||
assertEquals(View.VISIBLE, mExtraWidgetDivider.getVisibility());
|
||||
assertThat(mExtraWidget.isClickable()).isTrue();
|
||||
assertEquals(mContext.getResources().getText(R.string.settings_label),
|
||||
mExtraWidget.getContentDescription());
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testSetExtraWidgetOnClickListener() {
|
||||
mPreference.setExtraWidgetOnClickListener(mClickListener);
|
||||
|
||||
assertThat(mIsClickListenerCalled).isFalse();
|
||||
mExtraWidget.callOnClick();
|
||||
assertThat(mIsClickListenerCalled).isTrue();
|
||||
}
|
||||
|
||||
@Test
|
||||
public void extraWidgetStaysEnabledWhenPreferenceIsDisabled() {
|
||||
mPreference.setEnabled(false);
|
||||
mExtraWidget.setEnabled(false);
|
||||
|
||||
assertThat(mExtraWidget.isEnabled()).isFalse();
|
||||
mPreference.setExtraWidgetOnClickListener(mClickListener);
|
||||
assertThat(mExtraWidget.isEnabled()).isTrue();
|
||||
}
|
||||
}
|
Reference in New Issue
Block a user