New feature “Text and reading options” for SetupWizard, Wallpaper, and Settings (8/n).
- Extending the LabeledSeekBarPreference 1) Add new attributes, "iconStart", "iconEnd", "iconStartContentDescription", "iconEndContentDescription" 2) Add new interface setOnSeekBarChangeListener - It will be integrated with display/font size items in next patches. Bug: 211503117 Test: make -j64 RunSettingsRoboTests ROBOTEST_FILTER=LabeledSeekBarPreferenceTest Change-Id: Id8fe4fb68062c0e92ca4c291d2f7c47303e8691e
This commit is contained in:
@@ -18,12 +18,17 @@ package com.android.settings.gestures;
|
||||
|
||||
import static com.google.common.truth.Truth.assertThat;
|
||||
|
||||
import static org.mockito.ArgumentMatchers.any;
|
||||
import static org.mockito.ArgumentMatchers.anyBoolean;
|
||||
import static org.mockito.ArgumentMatchers.anyInt;
|
||||
import static org.mockito.Mockito.times;
|
||||
import static org.mockito.Mockito.verify;
|
||||
|
||||
import android.content.Context;
|
||||
import android.util.AttributeSet;
|
||||
import android.view.LayoutInflater;
|
||||
import android.view.View;
|
||||
import android.view.ViewGroup;
|
||||
import android.widget.LinearLayout;
|
||||
import android.widget.SeekBar;
|
||||
import android.widget.TextView;
|
||||
@@ -31,42 +36,59 @@ import android.widget.TextView;
|
||||
import androidx.preference.Preference;
|
||||
import androidx.preference.PreferenceViewHolder;
|
||||
|
||||
import com.android.internal.R;
|
||||
import com.android.settings.R;
|
||||
import com.android.settings.testutils.shadow.ShadowUserManager;
|
||||
import com.android.settings.widget.LabeledSeekBarPreference;
|
||||
|
||||
import org.junit.Before;
|
||||
import org.junit.Test;
|
||||
import org.junit.runner.RunWith;
|
||||
import org.mockito.Mock;
|
||||
import org.mockito.Mockito;
|
||||
import org.mockito.MockitoAnnotations;
|
||||
import org.robolectric.Robolectric;
|
||||
import org.robolectric.RobolectricTestRunner;
|
||||
import org.robolectric.RuntimeEnvironment;
|
||||
import org.robolectric.annotation.Config;
|
||||
|
||||
/**
|
||||
* Tests for {@link LabeledSeekBarPreference}.
|
||||
*/
|
||||
@RunWith(RobolectricTestRunner.class)
|
||||
@Config(shadows = {
|
||||
ShadowUserManager.class
|
||||
})
|
||||
public class LabeledSeekBarPreferenceTest {
|
||||
|
||||
private Context mContext;
|
||||
private PreferenceViewHolder mViewHolder;
|
||||
private SeekBar mSeekBar;
|
||||
private TextView mSummary;
|
||||
private ViewGroup mIconStartFrame;
|
||||
private ViewGroup mIconEndFrame;
|
||||
private LabeledSeekBarPreference mSeekBarPreference;
|
||||
|
||||
@Mock
|
||||
private Preference.OnPreferenceChangeListener mListener;
|
||||
|
||||
@Mock
|
||||
private SeekBar.OnSeekBarChangeListener mSeekBarChangeListener;
|
||||
|
||||
@Before
|
||||
public void setUp() {
|
||||
MockitoAnnotations.initMocks(this);
|
||||
|
||||
mContext = RuntimeEnvironment.application;
|
||||
mContext = Mockito.spy(RuntimeEnvironment.application);
|
||||
mSeekBarPreference = new LabeledSeekBarPreference(mContext, null);
|
||||
LayoutInflater inflater = LayoutInflater.from(mContext);
|
||||
final View view =
|
||||
inflater.inflate(mSeekBarPreference.getLayoutResource(),
|
||||
new LinearLayout(mContext), false);
|
||||
mViewHolder = PreferenceViewHolder.createInstanceForTests(view);
|
||||
mSeekBar = (SeekBar) mViewHolder.findViewById(R.id.seekbar);
|
||||
mSummary = (TextView) mViewHolder.findViewById(R.id.summary);
|
||||
mSeekBar = (SeekBar) mViewHolder.findViewById(com.android.internal.R.id.seekbar);
|
||||
mSummary = (TextView) mViewHolder.findViewById(android.R.id.summary);
|
||||
mIconStartFrame = (ViewGroup) mViewHolder.findViewById(R.id.icon_start_frame);
|
||||
mIconEndFrame = (ViewGroup) mViewHolder.findViewById(R.id.icon_end_frame);
|
||||
}
|
||||
|
||||
@Test
|
||||
@@ -97,4 +119,96 @@ public class LabeledSeekBarPreferenceTest {
|
||||
assertThat(mSummary.getText()).isEqualTo("");
|
||||
assertThat(mSummary.getVisibility()).isEqualTo(View.GONE);
|
||||
}
|
||||
|
||||
@Test
|
||||
public void setIconAttributes_iconVisible() {
|
||||
final AttributeSet attributeSet = Robolectric.buildAttributeSet()
|
||||
.addAttribute(R.attr.iconStart, "@drawable/ic_remove_24dp")
|
||||
.addAttribute(R.attr.iconEnd, "@drawable/ic_add_24dp")
|
||||
.build();
|
||||
final LabeledSeekBarPreference seekBarPreference =
|
||||
new LabeledSeekBarPreference(mContext, attributeSet);
|
||||
|
||||
seekBarPreference.onBindViewHolder(mViewHolder);
|
||||
|
||||
assertThat(mIconStartFrame.getVisibility()).isEqualTo(View.VISIBLE);
|
||||
assertThat(mIconEndFrame.getVisibility()).isEqualTo(View.VISIBLE);
|
||||
}
|
||||
|
||||
@Test
|
||||
public void notSetIconAttributes_iconGone() {
|
||||
final AttributeSet attributeSet = Robolectric.buildAttributeSet()
|
||||
.build();
|
||||
final LabeledSeekBarPreference seekBarPreference =
|
||||
new LabeledSeekBarPreference(mContext, attributeSet);
|
||||
|
||||
seekBarPreference.onBindViewHolder(mViewHolder);
|
||||
|
||||
assertThat(mIconStartFrame.getVisibility()).isEqualTo(View.GONE);
|
||||
assertThat(mIconEndFrame.getVisibility()).isEqualTo(View.GONE);
|
||||
}
|
||||
|
||||
@Test
|
||||
public void setSeekBarListener_success() {
|
||||
mSeekBarPreference.setOnSeekBarChangeListener(mSeekBarChangeListener);
|
||||
mSeekBarPreference.onStartTrackingTouch(mSeekBar);
|
||||
mSeekBarPreference.onProgressChanged(mSeekBar, /* progress= */ 0,
|
||||
/* fromUser= */ false);
|
||||
mSeekBarPreference.onStopTrackingTouch(mSeekBar);
|
||||
|
||||
verify(mSeekBarChangeListener).onStartTrackingTouch(any(SeekBar.class));
|
||||
verify(mSeekBarChangeListener).onProgressChanged(any(SeekBar.class), anyInt(),
|
||||
anyBoolean());
|
||||
verify(mSeekBarChangeListener).onStopTrackingTouch(any(SeekBar.class));
|
||||
}
|
||||
|
||||
@Test(expected = IllegalArgumentException.class)
|
||||
public void setContentDescriptionWithoutIcon_throwException() {
|
||||
final AttributeSet attributeSet = Robolectric.buildAttributeSet()
|
||||
.addAttribute(R.attr.iconStartContentDescription,
|
||||
"@string/screen_zoom_make_smaller_desc")
|
||||
.addAttribute(R.attr.iconEndContentDescription,
|
||||
"@string/screen_zoom_make_larger_desc")
|
||||
.build();
|
||||
|
||||
new LabeledSeekBarPreference(mContext, attributeSet);
|
||||
}
|
||||
|
||||
@Test
|
||||
public void setContentDescriptionWithIcon_success() {
|
||||
final String startDescription =
|
||||
mContext.getResources().getString(R.string.screen_zoom_make_smaller_desc);
|
||||
final String endDescription =
|
||||
mContext.getResources().getString(R.string.screen_zoom_make_larger_desc);
|
||||
final AttributeSet attributeSet = Robolectric.buildAttributeSet()
|
||||
.addAttribute(R.attr.iconStart, "@drawable/ic_remove_24dp")
|
||||
.addAttribute(R.attr.iconEnd, "@drawable/ic_add_24dp")
|
||||
.addAttribute(R.attr.iconStartContentDescription,
|
||||
"@string/screen_zoom_make_smaller_desc")
|
||||
.addAttribute(R.attr.iconEndContentDescription,
|
||||
"@string/screen_zoom_make_larger_desc")
|
||||
.build();
|
||||
final LabeledSeekBarPreference seekBarPreference =
|
||||
new LabeledSeekBarPreference(mContext, attributeSet);
|
||||
|
||||
seekBarPreference.onBindViewHolder(mViewHolder);
|
||||
|
||||
assertThat(mIconStartFrame.getContentDescription().toString().contentEquals(
|
||||
startDescription)).isTrue();
|
||||
assertThat(mIconEndFrame.getContentDescription().toString().contentEquals(
|
||||
endDescription)).isTrue();
|
||||
}
|
||||
|
||||
@Test
|
||||
public void notSetContentDescriptionAttributes_noDescription() {
|
||||
final AttributeSet attributeSet = Robolectric.buildAttributeSet()
|
||||
.build();
|
||||
final LabeledSeekBarPreference seekBarPreference =
|
||||
new LabeledSeekBarPreference(mContext, attributeSet);
|
||||
|
||||
seekBarPreference.onBindViewHolder(mViewHolder);
|
||||
|
||||
assertThat(mIconStartFrame.getContentDescription()).isNull();
|
||||
assertThat(mIconEndFrame.getContentDescription()).isNull();
|
||||
}
|
||||
}
|
||||
|
Reference in New Issue
Block a user