Filter out unimportant battery tips from slice card.
Change-Id: I2d087f345e44a7dc643715f67c9f516f5541e05e Fixes: 121115306 Test: robotests
This commit is contained in:
@@ -25,7 +25,6 @@ import android.content.Context;
|
|||||||
import android.content.Intent;
|
import android.content.Intent;
|
||||||
import android.content.SharedPreferences;
|
import android.content.SharedPreferences;
|
||||||
import android.net.Uri;
|
import android.net.Uri;
|
||||||
import android.util.Log;
|
|
||||||
|
|
||||||
import androidx.annotation.VisibleForTesting;
|
import androidx.annotation.VisibleForTesting;
|
||||||
import androidx.annotation.WorkerThread;
|
import androidx.annotation.WorkerThread;
|
||||||
@@ -49,6 +48,7 @@ import com.android.settings.slices.SliceBackgroundWorker;
|
|||||||
import com.android.settings.slices.SliceBuilderUtils;
|
import com.android.settings.slices.SliceBuilderUtils;
|
||||||
import com.android.settingslib.utils.ThreadUtils;
|
import com.android.settingslib.utils.ThreadUtils;
|
||||||
|
|
||||||
|
import java.util.Arrays;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
public class BatteryFixSlice implements CustomSliceable {
|
public class BatteryFixSlice implements CustomSliceable {
|
||||||
@@ -58,6 +58,11 @@ public class BatteryFixSlice implements CustomSliceable {
|
|||||||
@VisibleForTesting
|
@VisibleForTesting
|
||||||
static final String KEY_CURRENT_TIPS_TYPE = "current_tip_type";
|
static final String KEY_CURRENT_TIPS_TYPE = "current_tip_type";
|
||||||
|
|
||||||
|
private static final List<Integer> UNIMPORTANT_BATTERY_TIPS = Arrays.asList(
|
||||||
|
BatteryTip.TipType.SUMMARY,
|
||||||
|
BatteryTip.TipType.BATTERY_SAVER
|
||||||
|
);
|
||||||
|
|
||||||
private static final String TAG = "BatteryFixSlice";
|
private static final String TAG = "BatteryFixSlice";
|
||||||
|
|
||||||
private final Context mContext;
|
private final Context mContext;
|
||||||
@@ -78,7 +83,7 @@ public class BatteryFixSlice implements CustomSliceable {
|
|||||||
.setAccentColor(-1);
|
.setAccentColor(-1);
|
||||||
|
|
||||||
// TipType.SUMMARY is battery good
|
// TipType.SUMMARY is battery good
|
||||||
if (readBatteryTipAvailabilityCache(mContext) == BatteryTip.TipType.SUMMARY) {
|
if (UNIMPORTANT_BATTERY_TIPS.contains(readBatteryTipAvailabilityCache(mContext))) {
|
||||||
return buildBatteryGoodSlice(sliceBuilder, true);
|
return buildBatteryGoodSlice(sliceBuilder, true);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -91,19 +96,21 @@ public class BatteryFixSlice implements CustomSliceable {
|
|||||||
}
|
}
|
||||||
|
|
||||||
for (BatteryTip batteryTip : batteryTips) {
|
for (BatteryTip batteryTip : batteryTips) {
|
||||||
if (batteryTip.getState() != BatteryTip.StateType.INVISIBLE) {
|
if (batteryTip.getState() == BatteryTip.StateType.INVISIBLE) {
|
||||||
final IconCompat icon = IconCompat.createWithResource(mContext, batteryTip.getIconId());
|
continue;
|
||||||
final SliceAction primaryAction = SliceAction.createDeeplink(getPrimaryAction(),
|
|
||||||
icon,
|
|
||||||
ListBuilder.ICON_IMAGE,
|
|
||||||
batteryTip.getTitle(mContext));
|
|
||||||
sliceBuilder.addRow(new RowBuilder()
|
|
||||||
.setTitleItem(icon, ListBuilder.ICON_IMAGE)
|
|
||||||
.setTitle(batteryTip.getTitle(mContext))
|
|
||||||
.setSubtitle(batteryTip.getSummary(mContext))
|
|
||||||
.setPrimaryAction(primaryAction));
|
|
||||||
break;
|
|
||||||
}
|
}
|
||||||
|
final IconCompat icon = IconCompat.createWithResource(mContext,
|
||||||
|
batteryTip.getIconId());
|
||||||
|
final SliceAction primaryAction = SliceAction.createDeeplink(getPrimaryAction(),
|
||||||
|
icon,
|
||||||
|
ListBuilder.ICON_IMAGE,
|
||||||
|
batteryTip.getTitle(mContext));
|
||||||
|
sliceBuilder.addRow(new RowBuilder()
|
||||||
|
.setTitleItem(icon, ListBuilder.ICON_IMAGE)
|
||||||
|
.setTitle(batteryTip.getTitle(mContext))
|
||||||
|
.setSubtitle(batteryTip.getSummary(mContext))
|
||||||
|
.setPrimaryAction(primaryAction));
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
return sliceBuilder.build();
|
return sliceBuilder.build();
|
||||||
}
|
}
|
||||||
|
@@ -26,6 +26,8 @@ import static com.google.common.truth.Truth.assertThat;
|
|||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.content.SharedPreferences;
|
import android.content.SharedPreferences;
|
||||||
|
|
||||||
|
import androidx.slice.Slice;
|
||||||
|
import androidx.slice.SliceMetadata;
|
||||||
import androidx.slice.SliceProvider;
|
import androidx.slice.SliceProvider;
|
||||||
import androidx.slice.widget.SliceLiveData;
|
import androidx.slice.widget.SliceLiveData;
|
||||||
|
|
||||||
@@ -55,11 +57,13 @@ import java.util.List;
|
|||||||
public class BatteryFixSliceTest {
|
public class BatteryFixSliceTest {
|
||||||
|
|
||||||
private Context mContext;
|
private Context mContext;
|
||||||
|
private BatteryFixSlice mSlice;
|
||||||
|
|
||||||
@Before
|
@Before
|
||||||
public void setUp() {
|
public void setUp() {
|
||||||
MockitoAnnotations.initMocks(this);
|
MockitoAnnotations.initMocks(this);
|
||||||
mContext = RuntimeEnvironment.application;
|
mContext = RuntimeEnvironment.application;
|
||||||
|
mSlice = new BatteryFixSlice(mContext);
|
||||||
|
|
||||||
// Set-up specs for SliceMetadata.
|
// Set-up specs for SliceMetadata.
|
||||||
SliceProvider.setSpecs(SliceLiveData.SUPPORTED_SPECS);
|
SliceProvider.setSpecs(SliceLiveData.SUPPORTED_SPECS);
|
||||||
@@ -71,7 +75,7 @@ public class BatteryFixSliceTest {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void readBatteryTipfromPref_readCorrectValue() {
|
public void readBatteryTipFromPref_readCorrectValue() {
|
||||||
int target = 111;
|
int target = 111;
|
||||||
final SharedPreferences.Editor editor = mContext.getSharedPreferences(PREFS,
|
final SharedPreferences.Editor editor = mContext.getSharedPreferences(PREFS,
|
||||||
MODE_PRIVATE).edit();
|
MODE_PRIVATE).edit();
|
||||||
@@ -90,7 +94,7 @@ public class BatteryFixSliceTest {
|
|||||||
public void updateBatteryTipAvailabilityCache_writeCorrectValue() {
|
public void updateBatteryTipAvailabilityCache_writeCorrectValue() {
|
||||||
final List<BatteryTip> tips = new ArrayList<>();
|
final List<BatteryTip> tips = new ArrayList<>();
|
||||||
tips.add(new LowBatteryTip(BatteryTip.StateType.INVISIBLE, false, ""));
|
tips.add(new LowBatteryTip(BatteryTip.StateType.INVISIBLE, false, ""));
|
||||||
tips.add(new EarlyWarningTip(BatteryTip.StateType.HANDLED, false));
|
tips.add(new EarlyWarningTip(BatteryTip.StateType.NEW, false));
|
||||||
ShadowBatteryTipLoader.setBatteryTips(tips);
|
ShadowBatteryTipLoader.setBatteryTips(tips);
|
||||||
|
|
||||||
BatteryFixSlice.updateBatteryTipAvailabilityCache(mContext);
|
BatteryFixSlice.updateBatteryTipAvailabilityCache(mContext);
|
||||||
@@ -99,6 +103,23 @@ public class BatteryFixSliceTest {
|
|||||||
BatteryTip.TipType.BATTERY_SAVER);
|
BatteryTip.TipType.BATTERY_SAVER);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
@Config(shadows = {
|
||||||
|
ShadowBatteryStatsHelperLoader.class,
|
||||||
|
ShadowBatteryTipLoader.class
|
||||||
|
})
|
||||||
|
public void getSlice_unimportantSlice_shouldSkip() {
|
||||||
|
final List<BatteryTip> tips = new ArrayList<>();
|
||||||
|
tips.add(new LowBatteryTip(BatteryTip.StateType.INVISIBLE, false, ""));
|
||||||
|
tips.add(new EarlyWarningTip(BatteryTip.StateType.NEW, false));
|
||||||
|
ShadowBatteryTipLoader.setBatteryTips(tips);
|
||||||
|
|
||||||
|
BatteryFixSlice.updateBatteryTipAvailabilityCache(mContext);
|
||||||
|
final Slice slice = mSlice.getSlice();
|
||||||
|
|
||||||
|
assertThat(SliceMetadata.from(mContext, slice).isErrorSlice()).isTrue();
|
||||||
|
}
|
||||||
|
|
||||||
@Implements(BatteryStatsHelperLoader.class)
|
@Implements(BatteryStatsHelperLoader.class)
|
||||||
public static class ShadowBatteryStatsHelperLoader {
|
public static class ShadowBatteryStatsHelperLoader {
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user