Revert "Fix "Free up space" not clickable issue"
Revert submission 27450348-cherrypicker-L62500030004014460:N91700030063291466 Reason for revert: Droidmonitor triggered revert due to build breakage in b/342043629. Will be verifying through ABTD before submission. Reverted changes: /q/submissionid:27450348-cherrypicker-L62500030004014460:N91700030063291466 Change-Id: Ifaf5fbee7f18719e89d5278585ae80bed3808bb5
This commit is contained in:
committed by
Android (Google) Code Review
parent
567f04603d
commit
4916f22ad5
@@ -33,7 +33,7 @@
|
|||||||
android:selectable="false"
|
android:selectable="false"
|
||||||
settings:searchable="false" />
|
settings:searchable="false" />
|
||||||
|
|
||||||
<com.android.settings.widget.TipCardPreference
|
<com.android.settings.widget.CardPreference
|
||||||
android:key="battery_tip"
|
android:key="battery_tip"
|
||||||
android:title="@string/summary_placeholder"
|
android:title="@string/summary_placeholder"
|
||||||
settings:controller="com.android.settings.fuelgauge.batterytip.BatteryTipPreferenceController" />
|
settings:controller="com.android.settings.fuelgauge.batterytip.BatteryTipPreferenceController" />
|
||||||
|
@@ -33,7 +33,7 @@ import com.android.settings.core.InstrumentedPreferenceFragment;
|
|||||||
import com.android.settings.fuelgauge.batterytip.actions.BatteryTipAction;
|
import com.android.settings.fuelgauge.batterytip.actions.BatteryTipAction;
|
||||||
import com.android.settings.fuelgauge.batterytip.tips.BatteryTip;
|
import com.android.settings.fuelgauge.batterytip.tips.BatteryTip;
|
||||||
import com.android.settings.overlay.FeatureFactory;
|
import com.android.settings.overlay.FeatureFactory;
|
||||||
import com.android.settings.widget.TipCardPreference;
|
import com.android.settings.widget.CardPreference;
|
||||||
import com.android.settingslib.core.instrumentation.MetricsFeatureProvider;
|
import com.android.settingslib.core.instrumentation.MetricsFeatureProvider;
|
||||||
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
@@ -55,7 +55,7 @@ public class BatteryTipPreferenceController extends BasePreferenceController {
|
|||||||
private SettingsActivity mSettingsActivity;
|
private SettingsActivity mSettingsActivity;
|
||||||
private MetricsFeatureProvider mMetricsFeatureProvider;
|
private MetricsFeatureProvider mMetricsFeatureProvider;
|
||||||
private boolean mNeedUpdate;
|
private boolean mNeedUpdate;
|
||||||
@VisibleForTesting TipCardPreference mCardPreference;
|
@VisibleForTesting CardPreference mCardPreference;
|
||||||
@VisibleForTesting Context mPrefContext;
|
@VisibleForTesting Context mPrefContext;
|
||||||
InstrumentedPreferenceFragment mFragment;
|
InstrumentedPreferenceFragment mFragment;
|
||||||
|
|
||||||
|
@@ -28,6 +28,7 @@ import androidx.preference.Preference;
|
|||||||
|
|
||||||
import com.android.settings.R;
|
import com.android.settings.R;
|
||||||
import com.android.settings.overlay.FeatureFactory;
|
import com.android.settings.overlay.FeatureFactory;
|
||||||
|
import com.android.settings.widget.CardPreference;
|
||||||
import com.android.settingslib.HelpUtils;
|
import com.android.settingslib.HelpUtils;
|
||||||
import com.android.settingslib.core.instrumentation.MetricsFeatureProvider;
|
import com.android.settingslib.core.instrumentation.MetricsFeatureProvider;
|
||||||
|
|
||||||
@@ -79,9 +80,9 @@ public class BatteryDefenderTip extends BatteryTip {
|
|||||||
super.updatePreference(preference);
|
super.updatePreference(preference);
|
||||||
final Context context = preference.getContext();
|
final Context context = preference.getContext();
|
||||||
|
|
||||||
var cardPreference = castToTipCardPreferenceSafely(preference);
|
CardPreference cardPreference = castToCardPreferenceSafely(preference);
|
||||||
if (cardPreference == null) {
|
if (cardPreference == null) {
|
||||||
Log.e(TAG, "cast Preference to TipCardPreference failed");
|
Log.e(TAG, "cast Preference to CardPreference failed");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@@ -23,11 +23,10 @@ import android.util.SparseIntArray;
|
|||||||
|
|
||||||
import androidx.annotation.DrawableRes;
|
import androidx.annotation.DrawableRes;
|
||||||
import androidx.annotation.IntDef;
|
import androidx.annotation.IntDef;
|
||||||
import androidx.annotation.Nullable;
|
|
||||||
import androidx.annotation.VisibleForTesting;
|
import androidx.annotation.VisibleForTesting;
|
||||||
import androidx.preference.Preference;
|
import androidx.preference.Preference;
|
||||||
|
|
||||||
import com.android.settings.widget.TipCardPreference;
|
import com.android.settings.widget.CardPreference;
|
||||||
import com.android.settingslib.core.instrumentation.MetricsFeatureProvider;
|
import com.android.settingslib.core.instrumentation.MetricsFeatureProvider;
|
||||||
|
|
||||||
import java.lang.annotation.Retention;
|
import java.lang.annotation.Retention;
|
||||||
@@ -169,7 +168,7 @@ public abstract class BatteryTip implements Comparable<BatteryTip>, Parcelable {
|
|||||||
preference.setTitle(getTitle(context));
|
preference.setTitle(getTitle(context));
|
||||||
preference.setSummary(getSummary(context));
|
preference.setSummary(getSummary(context));
|
||||||
preference.setIcon(getIconId());
|
preference.setIcon(getIconId());
|
||||||
final TipCardPreference cardPreference = castToTipCardPreferenceSafely(preference);
|
final CardPreference cardPreference = castToCardPreferenceSafely(preference);
|
||||||
if (cardPreference != null) {
|
if (cardPreference != null) {
|
||||||
cardPreference.resetLayoutState();
|
cardPreference.resetLayoutState();
|
||||||
}
|
}
|
||||||
@@ -210,9 +209,7 @@ public abstract class BatteryTip implements Comparable<BatteryTip>, Parcelable {
|
|||||||
return "type=" + mType + " state=" + mState;
|
return "type=" + mType + " state=" + mState;
|
||||||
}
|
}
|
||||||
|
|
||||||
/** Returns the converted {@link TipCardPreference} if it is valid. */
|
public CardPreference castToCardPreferenceSafely(Preference preference) {
|
||||||
@Nullable
|
return preference instanceof CardPreference ? (CardPreference) preference : null;
|
||||||
public TipCardPreference castToTipCardPreferenceSafely(Preference preference) {
|
|
||||||
return preference instanceof TipCardPreference ? (TipCardPreference) preference : null;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@@ -26,6 +26,7 @@ import androidx.core.app.ActivityCompat;
|
|||||||
import androidx.preference.Preference;
|
import androidx.preference.Preference;
|
||||||
|
|
||||||
import com.android.settings.R;
|
import com.android.settings.R;
|
||||||
|
import com.android.settings.widget.CardPreference;
|
||||||
import com.android.settingslib.HelpUtils;
|
import com.android.settingslib.HelpUtils;
|
||||||
import com.android.settingslib.core.instrumentation.MetricsFeatureProvider;
|
import com.android.settingslib.core.instrumentation.MetricsFeatureProvider;
|
||||||
|
|
||||||
@@ -73,7 +74,7 @@ public final class IncompatibleChargerTip extends BatteryTip {
|
|||||||
public void updatePreference(Preference preference) {
|
public void updatePreference(Preference preference) {
|
||||||
super.updatePreference(preference);
|
super.updatePreference(preference);
|
||||||
final Context context = preference.getContext();
|
final Context context = preference.getContext();
|
||||||
final var cardPreference = castToTipCardPreferenceSafely(preference);
|
final CardPreference cardPreference = castToCardPreferenceSafely(preference);
|
||||||
if (cardPreference == null) {
|
if (cardPreference == null) {
|
||||||
Log.e(TAG, "cast Preference to CardPreference failed");
|
Log.e(TAG, "cast Preference to CardPreference failed");
|
||||||
return;
|
return;
|
||||||
|
@@ -1,164 +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 android.content.Context;
|
|
||||||
import android.util.AttributeSet;
|
|
||||||
import android.view.View;
|
|
||||||
import android.widget.Button;
|
|
||||||
|
|
||||||
import androidx.annotation.Nullable;
|
|
||||||
import androidx.preference.Preference;
|
|
||||||
import androidx.preference.PreferenceViewHolder;
|
|
||||||
|
|
||||||
import com.android.settings.R;
|
|
||||||
|
|
||||||
import com.google.android.material.card.MaterialCardView;
|
|
||||||
|
|
||||||
import java.util.Optional;
|
|
||||||
|
|
||||||
/** Preference that wrapped by {@link MaterialCardView} */
|
|
||||||
public class CardPreference extends Preference {
|
|
||||||
@Nullable private View.OnClickListener mPrimaryBtnClickListener = null;
|
|
||||||
@Nullable private View.OnClickListener mSecondaryBtnClickListener = null;
|
|
||||||
@Nullable private String mPrimaryButtonText = null;
|
|
||||||
@Nullable private String mSecondaryButtonText = null;
|
|
||||||
private Optional<Button> mPrimaryButton = Optional.empty();
|
|
||||||
private Optional<Button> mSecondaryButton = Optional.empty();
|
|
||||||
private Optional<View> mButtonsGroup = Optional.empty();
|
|
||||||
private boolean mPrimaryButtonVisible = false;
|
|
||||||
private boolean mSecondaryButtonVisible = false;
|
|
||||||
|
|
||||||
public CardPreference(Context context) {
|
|
||||||
this(context, null /* attrs */);
|
|
||||||
}
|
|
||||||
|
|
||||||
public CardPreference(Context context, @Nullable AttributeSet attrs) {
|
|
||||||
super(context, attrs, R.attr.cardPreferenceStyle);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void onBindViewHolder(PreferenceViewHolder holder) {
|
|
||||||
super.onBindViewHolder(holder);
|
|
||||||
initButtonsAndLayout(holder);
|
|
||||||
}
|
|
||||||
|
|
||||||
private void initButtonsAndLayout(PreferenceViewHolder holder) {
|
|
||||||
mPrimaryButton = Optional.ofNullable((Button) holder.findViewById(android.R.id.button1));
|
|
||||||
mSecondaryButton = Optional.ofNullable((Button) holder.findViewById(android.R.id.button2));
|
|
||||||
mButtonsGroup = Optional.ofNullable(holder.findViewById(R.id.card_preference_buttons));
|
|
||||||
setPrimaryButtonText(mPrimaryButtonText);
|
|
||||||
setPrimaryButtonClickListener(mPrimaryBtnClickListener);
|
|
||||||
setPrimaryButtonVisible(mPrimaryButtonVisible);
|
|
||||||
setSecondaryButtonText(mSecondaryButtonText);
|
|
||||||
setSecondaryButtonClickListener(mSecondaryBtnClickListener);
|
|
||||||
setSecondaryButtonVisible(mSecondaryButtonVisible);
|
|
||||||
}
|
|
||||||
|
|
||||||
/** Clear layout state if needed */
|
|
||||||
public void resetLayoutState() {
|
|
||||||
setPrimaryButtonVisible(false);
|
|
||||||
setSecondaryButtonVisible(false);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Register a callback to be invoked when the primary button is clicked.
|
|
||||||
*
|
|
||||||
* @param l the callback that will run
|
|
||||||
*/
|
|
||||||
public void setPrimaryButtonClickListener(View.OnClickListener l) {
|
|
||||||
mPrimaryButton.ifPresent(button -> button.setOnClickListener(l));
|
|
||||||
mPrimaryBtnClickListener = l;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Register a callback to be invoked when the secondary button is clicked.
|
|
||||||
*
|
|
||||||
* @param l the callback that will run
|
|
||||||
*/
|
|
||||||
public void setSecondaryButtonClickListener(View.OnClickListener l) {
|
|
||||||
mSecondaryButton.ifPresent(button -> button.setOnClickListener(l));
|
|
||||||
mSecondaryBtnClickListener = l;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Sets the text to be displayed on primary button.
|
|
||||||
*
|
|
||||||
* @param text text to be displayed
|
|
||||||
*/
|
|
||||||
public void setPrimaryButtonText(String text) {
|
|
||||||
mPrimaryButton.ifPresent(button -> button.setText(text));
|
|
||||||
mPrimaryButtonText = text;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Sets the text to be displayed on secondary button.
|
|
||||||
*
|
|
||||||
* @param text text to be displayed
|
|
||||||
*/
|
|
||||||
public void setSecondaryButtonText(String text) {
|
|
||||||
mSecondaryButton.ifPresent(button -> button.setText(text));
|
|
||||||
mSecondaryButtonText = text;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Set the visible on the primary button.
|
|
||||||
*
|
|
||||||
* @param visible {@code true} for visible
|
|
||||||
*/
|
|
||||||
public void setPrimaryButtonVisible(boolean visible) {
|
|
||||||
mPrimaryButton.ifPresent(
|
|
||||||
button -> button.setVisibility(visible ? View.VISIBLE : View.GONE));
|
|
||||||
mPrimaryButtonVisible = visible;
|
|
||||||
updateButtonGroupsVisibility();
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Set the visible on the secondary button.
|
|
||||||
*
|
|
||||||
* @param visible {@code true} for visible
|
|
||||||
*/
|
|
||||||
public void setSecondaryButtonVisible(boolean visible) {
|
|
||||||
mSecondaryButton.ifPresent(
|
|
||||||
button -> button.setVisibility(visible ? View.VISIBLE : View.GONE));
|
|
||||||
mSecondaryButtonVisible = visible;
|
|
||||||
updateButtonGroupsVisibility();
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Sets the text of content description on primary button.
|
|
||||||
*
|
|
||||||
* @param text text for the content description
|
|
||||||
*/
|
|
||||||
public void setPrimaryButtonContentDescription(String text) {
|
|
||||||
mPrimaryButton.ifPresent(button -> button.setContentDescription(text));
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Sets the text of content description on secondary button.
|
|
||||||
*
|
|
||||||
* @param text text for the content description
|
|
||||||
*/
|
|
||||||
public void setSecondaryButtonContentDescription(String text) {
|
|
||||||
mSecondaryButton.ifPresent(button -> button.setContentDescription(text));
|
|
||||||
}
|
|
||||||
|
|
||||||
private void updateButtonGroupsVisibility() {
|
|
||||||
int visibility =
|
|
||||||
(mPrimaryButtonVisible || mSecondaryButtonVisible) ? View.VISIBLE : View.GONE;
|
|
||||||
mButtonsGroup.ifPresent(group -> group.setVisibility(visibility));
|
|
||||||
}
|
|
||||||
}
|
|
@@ -27,7 +27,7 @@ import com.android.settingslib.spa.widget.card.CardModel
|
|||||||
import com.android.settingslib.spa.widget.card.SettingsCard
|
import com.android.settingslib.spa.widget.card.SettingsCard
|
||||||
|
|
||||||
/** A preference for settings banner tips card. */
|
/** A preference for settings banner tips card. */
|
||||||
class TipCardPreference
|
class CardPreference
|
||||||
@JvmOverloads
|
@JvmOverloads
|
||||||
constructor(
|
constructor(
|
||||||
context: Context,
|
context: Context,
|
@@ -33,7 +33,7 @@ import com.android.settings.SettingsActivity;
|
|||||||
import com.android.settings.core.BasePreferenceController;
|
import com.android.settings.core.BasePreferenceController;
|
||||||
import com.android.settings.core.InstrumentedPreferenceFragment;
|
import com.android.settings.core.InstrumentedPreferenceFragment;
|
||||||
import com.android.settings.fuelgauge.batterytip.tips.BatteryTip;
|
import com.android.settings.fuelgauge.batterytip.tips.BatteryTip;
|
||||||
import com.android.settings.widget.TipCardPreference;
|
import com.android.settings.widget.CardPreference;
|
||||||
|
|
||||||
import org.junit.Before;
|
import org.junit.Before;
|
||||||
import org.junit.Rule;
|
import org.junit.Rule;
|
||||||
@@ -61,7 +61,7 @@ public class BatteryTipPreferenceControllerTest {
|
|||||||
@Mock private InstrumentedPreferenceFragment mFragment;
|
@Mock private InstrumentedPreferenceFragment mFragment;
|
||||||
|
|
||||||
private Context mContext;
|
private Context mContext;
|
||||||
private TipCardPreference mCardPreference;
|
private CardPreference mCardPreference;
|
||||||
private BatteryTipPreferenceController mBatteryTipPreferenceController;
|
private BatteryTipPreferenceController mBatteryTipPreferenceController;
|
||||||
private List<BatteryTip> mNewBatteryTips;
|
private List<BatteryTip> mNewBatteryTips;
|
||||||
|
|
||||||
@@ -69,7 +69,7 @@ public class BatteryTipPreferenceControllerTest {
|
|||||||
public void setUp() {
|
public void setUp() {
|
||||||
mContext = ApplicationProvider.getApplicationContext();
|
mContext = ApplicationProvider.getApplicationContext();
|
||||||
|
|
||||||
mCardPreference = new TipCardPreference(mContext);
|
mCardPreference = new CardPreference(mContext);
|
||||||
when(mPreferenceScreen.getContext()).thenReturn(mContext);
|
when(mPreferenceScreen.getContext()).thenReturn(mContext);
|
||||||
doReturn(mCardPreference).when(mPreferenceScreen).findPreference(KEY_PREF);
|
doReturn(mCardPreference).when(mPreferenceScreen).findPreference(KEY_PREF);
|
||||||
|
|
||||||
|
@@ -29,7 +29,7 @@ import androidx.test.core.app.ApplicationProvider;
|
|||||||
|
|
||||||
import com.android.settings.R;
|
import com.android.settings.R;
|
||||||
import com.android.settings.testutils.FakeFeatureFactory;
|
import com.android.settings.testutils.FakeFeatureFactory;
|
||||||
import com.android.settings.widget.TipCardPreference;
|
import com.android.settings.widget.CardPreference;
|
||||||
import com.android.settingslib.core.instrumentation.MetricsFeatureProvider;
|
import com.android.settingslib.core.instrumentation.MetricsFeatureProvider;
|
||||||
|
|
||||||
import org.junit.Before;
|
import org.junit.Before;
|
||||||
@@ -49,7 +49,7 @@ public class BatteryDefenderTipTest {
|
|||||||
private FakeFeatureFactory mFeatureFactory;
|
private FakeFeatureFactory mFeatureFactory;
|
||||||
private BatteryDefenderTip mBatteryDefenderTip;
|
private BatteryDefenderTip mBatteryDefenderTip;
|
||||||
private MetricsFeatureProvider mMetricsFeatureProvider;
|
private MetricsFeatureProvider mMetricsFeatureProvider;
|
||||||
private TipCardPreference mCardPreference;
|
private CardPreference mCardPreference;
|
||||||
|
|
||||||
@Rule public MockitoRule mMockitoRule = MockitoJUnit.rule();
|
@Rule public MockitoRule mMockitoRule = MockitoJUnit.rule();
|
||||||
@Mock private BatteryTip mBatteryTip;
|
@Mock private BatteryTip mBatteryTip;
|
||||||
@@ -62,7 +62,7 @@ public class BatteryDefenderTipTest {
|
|||||||
mMetricsFeatureProvider = mFeatureFactory.metricsFeatureProvider;
|
mMetricsFeatureProvider = mFeatureFactory.metricsFeatureProvider;
|
||||||
mBatteryDefenderTip =
|
mBatteryDefenderTip =
|
||||||
new BatteryDefenderTip(BatteryTip.StateType.NEW, /* isPluggedIn= */ false);
|
new BatteryDefenderTip(BatteryTip.StateType.NEW, /* isPluggedIn= */ false);
|
||||||
mCardPreference = new TipCardPreference(mContext);
|
mCardPreference = new CardPreference(mContext);
|
||||||
|
|
||||||
when(mPreference.getContext()).thenReturn(mContext);
|
when(mPreference.getContext()).thenReturn(mContext);
|
||||||
}
|
}
|
||||||
@@ -98,7 +98,7 @@ public class BatteryDefenderTipTest {
|
|||||||
public void updatePreference_castFail_logErrorMessage() {
|
public void updatePreference_castFail_logErrorMessage() {
|
||||||
mBatteryDefenderTip.updatePreference(mPreference);
|
mBatteryDefenderTip.updatePreference(mPreference);
|
||||||
|
|
||||||
assertThat(getLastErrorLog()).isEqualTo("cast Preference to TipCardPreference failed");
|
assertThat(getLastErrorLog()).isEqualTo("cast Preference to CardPreference failed");
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
|
@@ -26,7 +26,7 @@ import androidx.preference.Preference;
|
|||||||
import androidx.test.core.app.ApplicationProvider;
|
import androidx.test.core.app.ApplicationProvider;
|
||||||
|
|
||||||
import com.android.settings.R;
|
import com.android.settings.R;
|
||||||
import com.android.settings.widget.TipCardPreference;
|
import com.android.settings.widget.CardPreference;
|
||||||
import com.android.settingslib.core.instrumentation.MetricsFeatureProvider;
|
import com.android.settingslib.core.instrumentation.MetricsFeatureProvider;
|
||||||
import com.android.settingslib.testutils.DrawableTestHelper;
|
import com.android.settingslib.testutils.DrawableTestHelper;
|
||||||
|
|
||||||
@@ -87,7 +87,7 @@ public class BatteryTipTest {
|
|||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void updatePreference_resetLayoutState() {
|
public void updatePreference_resetLayoutState() {
|
||||||
var cardPreference = new TipCardPreference(mContext);
|
CardPreference cardPreference = new CardPreference(mContext);
|
||||||
cardPreference.setPrimaryButtonVisibility(true);
|
cardPreference.setPrimaryButtonVisibility(true);
|
||||||
cardPreference.setSecondaryButtonVisibility(true);
|
cardPreference.setSecondaryButtonVisibility(true);
|
||||||
|
|
||||||
|
@@ -29,7 +29,7 @@ import androidx.test.core.app.ApplicationProvider;
|
|||||||
|
|
||||||
import com.android.settings.R;
|
import com.android.settings.R;
|
||||||
import com.android.settings.testutils.FakeFeatureFactory;
|
import com.android.settings.testutils.FakeFeatureFactory;
|
||||||
import com.android.settings.widget.TipCardPreference;
|
import com.android.settings.widget.CardPreference;
|
||||||
import com.android.settingslib.core.instrumentation.MetricsFeatureProvider;
|
import com.android.settingslib.core.instrumentation.MetricsFeatureProvider;
|
||||||
|
|
||||||
import org.junit.Before;
|
import org.junit.Before;
|
||||||
@@ -49,7 +49,7 @@ public final class IncompatibleChargerTipTest {
|
|||||||
private FakeFeatureFactory mFeatureFactory;
|
private FakeFeatureFactory mFeatureFactory;
|
||||||
private IncompatibleChargerTip mIncompatibleChargerTip;
|
private IncompatibleChargerTip mIncompatibleChargerTip;
|
||||||
private MetricsFeatureProvider mMetricsFeatureProvider;
|
private MetricsFeatureProvider mMetricsFeatureProvider;
|
||||||
private TipCardPreference mCardPreference;
|
private CardPreference mCardPreference;
|
||||||
|
|
||||||
@Rule public MockitoRule mMockitoRule = MockitoJUnit.rule();
|
@Rule public MockitoRule mMockitoRule = MockitoJUnit.rule();
|
||||||
@Mock private BatteryTip mBatteryTip;
|
@Mock private BatteryTip mBatteryTip;
|
||||||
@@ -61,7 +61,7 @@ public final class IncompatibleChargerTipTest {
|
|||||||
mMetricsFeatureProvider = mFeatureFactory.metricsFeatureProvider;
|
mMetricsFeatureProvider = mFeatureFactory.metricsFeatureProvider;
|
||||||
mContext = ApplicationProvider.getApplicationContext();
|
mContext = ApplicationProvider.getApplicationContext();
|
||||||
mIncompatibleChargerTip = new IncompatibleChargerTip(BatteryTip.StateType.NEW);
|
mIncompatibleChargerTip = new IncompatibleChargerTip(BatteryTip.StateType.NEW);
|
||||||
mCardPreference = new TipCardPreference(mContext);
|
mCardPreference = new CardPreference(mContext);
|
||||||
|
|
||||||
when(mPreference.getContext()).thenReturn(mContext);
|
when(mPreference.getContext()).thenReturn(mContext);
|
||||||
}
|
}
|
||||||
|
@@ -1,293 +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
|
|
||||||
*Visibility_setGoneForPrimaryButton_buttonGroupIsGone
|
|
||||||
* 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 android.view.View.GONE;
|
|
||||||
import static android.view.View.VISIBLE;
|
|
||||||
|
|
||||||
import static com.google.common.truth.Truth.assertThat;
|
|
||||||
import static com.google.common.truth.Truth.assertWithMessage;
|
|
||||||
|
|
||||||
import android.content.Context;
|
|
||||||
import android.view.View;
|
|
||||||
import android.widget.Button;
|
|
||||||
|
|
||||||
import androidx.preference.PreferenceViewHolder;
|
|
||||||
import androidx.test.core.app.ApplicationProvider;
|
|
||||||
|
|
||||||
import com.android.settings.R;
|
|
||||||
|
|
||||||
import org.junit.Before;
|
|
||||||
import org.junit.Test;
|
|
||||||
import org.junit.runner.RunWith;
|
|
||||||
import org.robolectric.RobolectricTestRunner;
|
|
||||||
|
|
||||||
@RunWith(RobolectricTestRunner.class)
|
|
||||||
public class CardPreferenceTest {
|
|
||||||
private CardPreference mCardPreference;
|
|
||||||
private PreferenceViewHolder mHolder;
|
|
||||||
|
|
||||||
@Before
|
|
||||||
public void setUp() {
|
|
||||||
Context context = ApplicationProvider.getApplicationContext();
|
|
||||||
context.setTheme(R.style.Theme_Settings);
|
|
||||||
mCardPreference = new CardPreference(context);
|
|
||||||
mHolder =
|
|
||||||
PreferenceViewHolder.createInstanceForTests(
|
|
||||||
View.inflate(context, R.layout.card_preference_layout, /* parent= */ null));
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void newACardPreference_layoutResourceShouldBeCardPreferenceLayout() {
|
|
||||||
Context context = ApplicationProvider.getApplicationContext();
|
|
||||||
context.setTheme(R.style.SettingsPreferenceTheme);
|
|
||||||
CardPreference cardPreference = new CardPreference(context);
|
|
||||||
assertThat(cardPreference.getLayoutResource()).isEqualTo(R.layout.card_preference_layout);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void onBindViewHolder_noButtonVisible_buttonsLayoutIsGone() {
|
|
||||||
mCardPreference.onBindViewHolder(mHolder);
|
|
||||||
assertThat(getCardPreferenceButtonsView().getVisibility()).isEqualTo(GONE);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void onBindViewHolder_setPrimaryButtonVisibility_buttonsLayoutIsVisible() {
|
|
||||||
mCardPreference.setPrimaryButtonVisible(true);
|
|
||||||
mCardPreference.onBindViewHolder(mHolder);
|
|
||||||
assertThat(getCardPreferenceButtonsView().getVisibility()).isEqualTo(VISIBLE);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void onBindViewHolder_setPrimaryButtonVisibilityToVisible() {
|
|
||||||
mCardPreference.setPrimaryButtonVisible(true);
|
|
||||||
mCardPreference.onBindViewHolder(mHolder);
|
|
||||||
assertThat(getPrimaryButton().getVisibility()).isEqualTo(VISIBLE);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void onBindViewHolder_setSecondaryButtonVisibility_buttonsLayoutIsVisible() {
|
|
||||||
mCardPreference.setSecondaryButtonVisible(true);
|
|
||||||
mCardPreference.onBindViewHolder(mHolder);
|
|
||||||
assertThat(getCardPreferenceButtonsView().getVisibility()).isEqualTo(VISIBLE);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void onBindViewHolder_setSecondaryButtonVisibilityToVisible() {
|
|
||||||
mCardPreference.setSecondaryButtonVisible(true);
|
|
||||||
mCardPreference.onBindViewHolder(mHolder);
|
|
||||||
assertThat(getSecondaryButton().getVisibility()).isEqualTo(VISIBLE);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void onBindViewHolder_setPrimaryButtonTextToExpectedText() {
|
|
||||||
String expectedText = "primary-button";
|
|
||||||
mCardPreference.setPrimaryButtonText(expectedText);
|
|
||||||
mCardPreference.onBindViewHolder(mHolder);
|
|
||||||
assertThat(getPrimaryButton().getText().toString()).isEqualTo(expectedText);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void onBindViewHolder_setSecondaryButtonTextToExpectedText() {
|
|
||||||
String expectedText = "secondary-button";
|
|
||||||
mCardPreference.setSecondaryButtonText(expectedText);
|
|
||||||
mCardPreference.onBindViewHolder(mHolder);
|
|
||||||
assertThat(getSecondaryButton().getText().toString()).isEqualTo(expectedText);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void onBindViewHolder_initialTextForPrimaryButtonShouldBeEmpty() {
|
|
||||||
mCardPreference.onBindViewHolder(mHolder);
|
|
||||||
assertThat(getPrimaryButton().getText().toString()).isEqualTo("");
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void onBindViewHolder_initialTextForSecondaryButtonShouldBeEmpty() {
|
|
||||||
mCardPreference.onBindViewHolder(mHolder);
|
|
||||||
assertThat(getSecondaryButton().getText().toString()).isEqualTo("");
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void performClickOnPrimaryButton_callClickListener() {
|
|
||||||
final boolean[] hasCalled = {false};
|
|
||||||
View.OnClickListener clickListener = v -> hasCalled[0] = true;
|
|
||||||
mCardPreference.setPrimaryButtonClickListener(clickListener);
|
|
||||||
mCardPreference.onBindViewHolder(mHolder);
|
|
||||||
getPrimaryButton().performClick();
|
|
||||||
assertThat(hasCalled[0]).isTrue();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void performClickOnSecondaryButton_callClickListener() {
|
|
||||||
final boolean[] hasCalled = {false};
|
|
||||||
View.OnClickListener clickListener = v -> hasCalled[0] = true;
|
|
||||||
mCardPreference.setSecondaryButtonClickListener(clickListener);
|
|
||||||
mCardPreference.onBindViewHolder(mHolder);
|
|
||||||
getSecondaryButton().performClick();
|
|
||||||
assertThat(hasCalled[0]).isTrue();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void onBindViewHolder_primaryButtonDefaultIsGone() {
|
|
||||||
mCardPreference.onBindViewHolder(mHolder);
|
|
||||||
assertThat(getPrimaryButton().getVisibility()).isEqualTo(GONE);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void onBindViewHolder_secondaryButtonDefaultIsGone() {
|
|
||||||
mCardPreference.onBindViewHolder(mHolder);
|
|
||||||
assertThat(getSecondaryButton().getVisibility()).isEqualTo(GONE);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void setPrimaryButtonVisibility_setTrueAfterBindViewHolder_isVisible() {
|
|
||||||
mCardPreference.setPrimaryButtonVisible(false);
|
|
||||||
mCardPreference.onBindViewHolder(mHolder);
|
|
||||||
mCardPreference.setPrimaryButtonVisible(true);
|
|
||||||
assertThat(getPrimaryButton().getVisibility()).isEqualTo(VISIBLE);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void setPrimaryButtonText_setAfterBindViewHolder_setOnUi() {
|
|
||||||
String expectedText = "123456";
|
|
||||||
mCardPreference.onBindViewHolder(mHolder);
|
|
||||||
mCardPreference.setPrimaryButtonText(expectedText);
|
|
||||||
assertThat(getPrimaryButton().getText().toString()).isEqualTo(expectedText);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void setPrimaryButtonText_setNull_isEmptyText() {
|
|
||||||
final String emptyString = "";
|
|
||||||
mCardPreference.setPrimaryButtonText("1234");
|
|
||||||
mCardPreference.onBindViewHolder(mHolder);
|
|
||||||
mCardPreference.setPrimaryButtonText(null);
|
|
||||||
assertThat(getPrimaryButton().getText().toString()).isEqualTo(emptyString);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void setPrimaryButtonClickListener_setAfterOnBindViewHolder() {
|
|
||||||
final String[] hasCalled = {""};
|
|
||||||
String expectedClickedResult = "was called";
|
|
||||||
View.OnClickListener clickListener = v -> hasCalled[0] = expectedClickedResult;
|
|
||||||
mCardPreference.onBindViewHolder(mHolder);
|
|
||||||
mCardPreference.setPrimaryButtonClickListener(clickListener);
|
|
||||||
getPrimaryButton().performClick();
|
|
||||||
assertThat(hasCalled[0]).isEqualTo(expectedClickedResult);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void setPrimaryButtonClickListener_setNull_clearTheOnClickListener() {
|
|
||||||
final String[] hasCalled = {"not called"};
|
|
||||||
View.OnClickListener clickListener = v -> hasCalled[0] = "called once";
|
|
||||||
mCardPreference.setPrimaryButtonClickListener(clickListener);
|
|
||||||
mCardPreference.onBindViewHolder(mHolder);
|
|
||||||
mCardPreference.setPrimaryButtonClickListener(null);
|
|
||||||
getPrimaryButton().performClick();
|
|
||||||
assertThat(hasCalled[0]).isEqualTo("not called");
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void setSecondaryButtonVisibility_setTrueAfterBindViewHolder_isVisible() {
|
|
||||||
mCardPreference.setSecondaryButtonVisible(false);
|
|
||||||
mCardPreference.onBindViewHolder(mHolder);
|
|
||||||
mCardPreference.setSecondaryButtonVisible(true);
|
|
||||||
assertThat(getSecondaryButton().getVisibility()).isEqualTo(VISIBLE);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void setSecondaryButtonText_setAfterBindViewHolder_setOnUi() {
|
|
||||||
String expectedText = "10101010";
|
|
||||||
mCardPreference.onBindViewHolder(mHolder);
|
|
||||||
mCardPreference.setSecondaryButtonText(expectedText);
|
|
||||||
assertThat(getSecondaryButton().getText().toString()).isEqualTo(expectedText);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void setSecondaryButtonText_setNull_isEmptyText() {
|
|
||||||
String emptyString = "";
|
|
||||||
mCardPreference.setSecondaryButtonText("1234");
|
|
||||||
mCardPreference.onBindViewHolder(mHolder);
|
|
||||||
mCardPreference.setSecondaryButtonText(null);
|
|
||||||
assertThat(getSecondaryButton().getText().toString()).isEqualTo(emptyString);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void setSecondaryButtonClickListener_setAfterOnBindViewHolder() {
|
|
||||||
final String[] hasCalled = {""};
|
|
||||||
String expectedClickedResult = "2nd was called";
|
|
||||||
View.OnClickListener clickListener = v -> hasCalled[0] = expectedClickedResult;
|
|
||||||
mCardPreference.onBindViewHolder(mHolder);
|
|
||||||
mCardPreference.setSecondaryButtonClickListener(clickListener);
|
|
||||||
getSecondaryButton().performClick();
|
|
||||||
assertThat(hasCalled[0]).isEqualTo(expectedClickedResult);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void setSecondaryButtonClickListener_setNull_clearTheOnClickListener() {
|
|
||||||
final String[] hasCalled = {"not called"};
|
|
||||||
View.OnClickListener clickListener = v -> hasCalled[0] = "called once";
|
|
||||||
mCardPreference.setSecondaryButtonClickListener(clickListener);
|
|
||||||
mCardPreference.onBindViewHolder(mHolder);
|
|
||||||
mCardPreference.setSecondaryButtonClickListener(null);
|
|
||||||
getSecondaryButton().performClick();
|
|
||||||
assertThat(hasCalled[0]).isEqualTo("not called");
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void setPrimaryButtonVisibility_setGoneForSecondaryButton_buttonGroupIsGone() {
|
|
||||||
mCardPreference.setPrimaryButtonVisible(true);
|
|
||||||
mCardPreference.setSecondaryButtonVisible(false);
|
|
||||||
mCardPreference.onBindViewHolder(mHolder);
|
|
||||||
assertWithMessage("PreCondition: buttonsView should be Visible")
|
|
||||||
.that(getCardPreferenceButtonsView().getVisibility())
|
|
||||||
.isEqualTo(VISIBLE);
|
|
||||||
mCardPreference.setPrimaryButtonVisible(false);
|
|
||||||
assertThat(getCardPreferenceButtonsView().getVisibility()).isEqualTo(GONE);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void setSecondaryButtonVisibility_setGoneForPrimaryButton_buttonGroupIsGone() {
|
|
||||||
mCardPreference.setPrimaryButtonVisible(false);
|
|
||||||
mCardPreference.setSecondaryButtonVisible(true);
|
|
||||||
mCardPreference.onBindViewHolder(mHolder);
|
|
||||||
assertWithMessage("PreCondition: buttonsView should be Visible")
|
|
||||||
.that(getCardPreferenceButtonsView().getVisibility())
|
|
||||||
.isEqualTo(VISIBLE);
|
|
||||||
mCardPreference.setSecondaryButtonVisible(false);
|
|
||||||
assertThat(getCardPreferenceButtonsView().getVisibility()).isEqualTo(GONE);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void resetLayoutState_buttonGroupIsGone() {
|
|
||||||
mCardPreference.setPrimaryButtonVisible(true);
|
|
||||||
mCardPreference.setSecondaryButtonVisible(true);
|
|
||||||
mCardPreference.onBindViewHolder(mHolder);
|
|
||||||
mCardPreference.resetLayoutState();
|
|
||||||
assertThat(getCardPreferenceButtonsView().getVisibility()).isEqualTo(GONE);
|
|
||||||
}
|
|
||||||
|
|
||||||
private View getCardPreferenceButtonsView() {
|
|
||||||
return mHolder.findViewById(R.id.card_preference_buttons);
|
|
||||||
}
|
|
||||||
|
|
||||||
private Button getPrimaryButton() {
|
|
||||||
return (Button) mHolder.findViewById(android.R.id.button1);
|
|
||||||
}
|
|
||||||
|
|
||||||
private Button getSecondaryButton() {
|
|
||||||
return (Button) mHolder.findViewById(android.R.id.button2);
|
|
||||||
}
|
|
||||||
}
|
|
@@ -35,7 +35,7 @@ import org.junit.Test
|
|||||||
import org.junit.runner.RunWith
|
import org.junit.runner.RunWith
|
||||||
|
|
||||||
@RunWith(AndroidJUnit4::class)
|
@RunWith(AndroidJUnit4::class)
|
||||||
class TipCardPreferenceTest {
|
class CardPreferenceTest {
|
||||||
|
|
||||||
@get:Rule val composeTestRule = createComposeRule()
|
@get:Rule val composeTestRule = createComposeRule()
|
||||||
private lateinit var context: Context
|
private lateinit var context: Context
|
||||||
@@ -179,7 +179,7 @@ class TipCardPreferenceTest {
|
|||||||
fun resetLayoutState_shouldRemoveThePrimaryButton() {
|
fun resetLayoutState_shouldRemoveThePrimaryButton() {
|
||||||
val buttonText = "9527"
|
val buttonText = "9527"
|
||||||
val cardPreference =
|
val cardPreference =
|
||||||
TipCardPreference(context)
|
CardPreference(context)
|
||||||
.apply {
|
.apply {
|
||||||
primaryButtonText = buttonText
|
primaryButtonText = buttonText
|
||||||
primaryButtonVisibility = true
|
primaryButtonVisibility = true
|
||||||
@@ -196,7 +196,7 @@ class TipCardPreferenceTest {
|
|||||||
fun resetLayoutState_shouldRemoveTheSecondaryButton() {
|
fun resetLayoutState_shouldRemoveTheSecondaryButton() {
|
||||||
val buttonText = "4567"
|
val buttonText = "4567"
|
||||||
val cardPreference =
|
val cardPreference =
|
||||||
TipCardPreference(context)
|
CardPreference(context)
|
||||||
.apply {
|
.apply {
|
||||||
secondaryButtonText = buttonText
|
secondaryButtonText = buttonText
|
||||||
secondaryButtonVisibility = true
|
secondaryButtonVisibility = true
|
||||||
@@ -222,7 +222,7 @@ class TipCardPreferenceTest {
|
|||||||
secondaryButtonVisibility: Boolean = false,
|
secondaryButtonVisibility: Boolean = false,
|
||||||
enableDismiss: Boolean = true,
|
enableDismiss: Boolean = true,
|
||||||
) =
|
) =
|
||||||
TipCardPreference(context)
|
CardPreference(context)
|
||||||
.apply {
|
.apply {
|
||||||
this.iconResId = iconResId
|
this.iconResId = iconResId
|
||||||
this.primaryButtonText = primaryButtonText
|
this.primaryButtonText = primaryButtonText
|
Reference in New Issue
Block a user