Merge "Allow NEW type battery early warning to show in homepage"

This commit is contained in:
TreeHugger Robot
2019-04-03 02:04:30 +00:00
committed by Android (Google) Code Review
2 changed files with 37 additions and 39 deletions

View File

@@ -26,6 +26,7 @@ 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.ArrayMap;
import androidx.annotation.VisibleForTesting; import androidx.annotation.VisibleForTesting;
import androidx.annotation.WorkerThread; import androidx.annotation.WorkerThread;
@@ -50,6 +51,7 @@ import com.android.settingslib.utils.ThreadUtils;
import java.util.Arrays; import java.util.Arrays;
import java.util.List; import java.util.List;
import java.util.Map;
public class BatteryFixSlice implements CustomSliceable { public class BatteryFixSlice implements CustomSliceable {
@@ -57,11 +59,18 @@ public class BatteryFixSlice implements CustomSliceable {
static final String PREFS = "battery_fix_prefs"; static final String PREFS = "battery_fix_prefs";
@VisibleForTesting @VisibleForTesting
static final String KEY_CURRENT_TIPS_TYPE = "current_tip_type"; static final String KEY_CURRENT_TIPS_TYPE = "current_tip_type";
static final String KEY_CURRENT_TIPS_STATE = "current_tip_state";
private static final List<Integer> UNIMPORTANT_BATTERY_TIPS = Arrays.asList( // A map tracking which BatteryTip and which state of that tip is not important.
BatteryTip.TipType.SUMMARY, private static final Map<Integer, List<Integer>> UNIMPORTANT_BATTERY_TIPS;
BatteryTip.TipType.BATTERY_SAVER
); static {
UNIMPORTANT_BATTERY_TIPS = new ArrayMap<>();
UNIMPORTANT_BATTERY_TIPS.put(BatteryTip.TipType.SUMMARY,
Arrays.asList(BatteryTip.StateType.NEW, BatteryTip.StateType.HANDLED));
UNIMPORTANT_BATTERY_TIPS.put(BatteryTip.TipType.BATTERY_SAVER,
Arrays.asList(BatteryTip.StateType.HANDLED));
}
private static final String TAG = "BatteryFixSlice"; private static final String TAG = "BatteryFixSlice";
@@ -82,9 +91,8 @@ public class BatteryFixSlice implements CustomSliceable {
new ListBuilder(mContext, BATTERY_FIX_SLICE_URI, ListBuilder.INFINITY) new ListBuilder(mContext, BATTERY_FIX_SLICE_URI, ListBuilder.INFINITY)
.setAccentColor(COLOR_NOT_TINTED); .setAccentColor(COLOR_NOT_TINTED);
// TipType.SUMMARY is battery good if (!isBatteryTipAvailableFromCache(mContext)) {
if (UNIMPORTANT_BATTERY_TIPS.contains(readBatteryTipAvailabilityCache(mContext))) { return buildBatteryGoodSlice(sliceBuilder, true /* isError */);
return buildBatteryGoodSlice(sliceBuilder, true);
} }
final SliceBackgroundWorker worker = SliceBackgroundWorker.getInstance(getUri()); final SliceBackgroundWorker worker = SliceBackgroundWorker.getInstance(getUri());
@@ -92,7 +100,7 @@ public class BatteryFixSlice implements CustomSliceable {
if (batteryTips == null) { if (batteryTips == null) {
// Because we need wait slice background worker return data // Because we need wait slice background worker return data
return buildBatteryGoodSlice(sliceBuilder, false); return buildBatteryGoodSlice(sliceBuilder, false /* isError */);
} }
for (BatteryTip batteryTip : batteryTips) { for (BatteryTip batteryTip : batteryTips) {
@@ -161,15 +169,23 @@ public class BatteryFixSlice implements CustomSliceable {
// TODO(b/114807643): we should find a better way to get current battery tip type quickly // TODO(b/114807643): we should find a better way to get current battery tip type quickly
// Now we save battery tip type to shared preference when battery level changes // Now we save battery tip type to shared preference when battery level changes
public static void updateBatteryTipAvailabilityCache(Context context) { public static void updateBatteryTipAvailabilityCache(Context context) {
ThreadUtils.postOnBackgroundThread(() -> { ThreadUtils.postOnBackgroundThread(() -> refreshBatteryTips(context));
refreshBatteryTips(context);
});
} }
@VisibleForTesting @VisibleForTesting
static int readBatteryTipAvailabilityCache(Context context) { static boolean isBatteryTipAvailableFromCache(Context context) {
final SharedPreferences prefs = context.getSharedPreferences(PREFS, MODE_PRIVATE); final SharedPreferences prefs = context.getSharedPreferences(PREFS, MODE_PRIVATE);
return prefs.getInt(KEY_CURRENT_TIPS_TYPE, BatteryTip.TipType.SUMMARY);
final int type = prefs.getInt(KEY_CURRENT_TIPS_TYPE, BatteryTip.TipType.SUMMARY);
final int state = prefs.getInt(KEY_CURRENT_TIPS_STATE, BatteryTip.StateType.INVISIBLE);
if (state == BatteryTip.StateType.INVISIBLE) {
// State is INVISIBLE, We should not show anything.
return false;
}
final boolean unimportant = UNIMPORTANT_BATTERY_TIPS.containsKey(type)
&& UNIMPORTANT_BATTERY_TIPS.get(type).contains(state);
return !unimportant;
} }
@WorkerThread @WorkerThread
@@ -180,10 +196,11 @@ public class BatteryFixSlice implements CustomSliceable {
final List<BatteryTip> batteryTips = loader.loadInBackground(); final List<BatteryTip> batteryTips = loader.loadInBackground();
for (BatteryTip batteryTip : batteryTips) { for (BatteryTip batteryTip : batteryTips) {
if (batteryTip.getState() != BatteryTip.StateType.INVISIBLE) { if (batteryTip.getState() != BatteryTip.StateType.INVISIBLE) {
SharedPreferences.Editor editor = context.getSharedPreferences(PREFS, context.getSharedPreferences(PREFS, MODE_PRIVATE)
MODE_PRIVATE).edit(); .edit()
editor.putInt(KEY_CURRENT_TIPS_TYPE, batteryTip.getType()); .putInt(KEY_CURRENT_TIPS_TYPE, batteryTip.getType())
editor.apply(); .putInt(KEY_CURRENT_TIPS_STATE, batteryTip.getState())
.apply();
break; break;
} }
} }

View File

@@ -16,15 +16,9 @@
package com.android.settings.homepage.contextualcards.slices; package com.android.settings.homepage.contextualcards.slices;
import static android.content.Context.MODE_PRIVATE;
import static com.android.settings.homepage.contextualcards.slices.BatteryFixSlice.KEY_CURRENT_TIPS_TYPE;
import static com.android.settings.homepage.contextualcards.slices.BatteryFixSlice.PREFS;
import static com.google.common.truth.Truth.assertThat; import static com.google.common.truth.Truth.assertThat;
import android.content.Context; import android.content.Context;
import android.content.SharedPreferences;
import androidx.slice.Slice; import androidx.slice.Slice;
import androidx.slice.SliceMetadata; import androidx.slice.SliceMetadata;
@@ -74,24 +68,12 @@ public class BatteryFixSliceTest {
ShadowBatteryTipLoader.reset(); ShadowBatteryTipLoader.reset();
} }
@Test
public void readBatteryTipFromPref_readCorrectValue() {
int target = 111;
final SharedPreferences.Editor editor = mContext.getSharedPreferences(PREFS,
MODE_PRIVATE).edit();
editor.putInt(KEY_CURRENT_TIPS_TYPE, target);
editor.commit();
assertThat(BatteryFixSlice.readBatteryTipAvailabilityCache(mContext)).isEqualTo(target);
}
@Test @Test
@Config(shadows = { @Config(shadows = {
ShadowBatteryStatsHelperLoader.class, ShadowBatteryStatsHelperLoader.class,
ShadowBatteryTipLoader.class ShadowBatteryTipLoader.class
}) })
public void updateBatteryTipAvailabilityCache_writeCorrectValue() { public void updateBatteryTipAvailabilityCache_hasImportantTip_shouldReturnTrue() {
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.NEW, false)); tips.add(new EarlyWarningTip(BatteryTip.StateType.NEW, false));
@@ -99,8 +81,7 @@ public class BatteryFixSliceTest {
BatteryFixSlice.updateBatteryTipAvailabilityCache(mContext); BatteryFixSlice.updateBatteryTipAvailabilityCache(mContext);
assertThat(BatteryFixSlice.readBatteryTipAvailabilityCache(mContext)).isEqualTo( assertThat(BatteryFixSlice.isBatteryTipAvailableFromCache(mContext)).isTrue();
BatteryTip.TipType.BATTERY_SAVER);
} }
@Test @Test
@@ -111,7 +92,7 @@ public class BatteryFixSliceTest {
public void getSlice_unimportantSlice_shouldSkip() { public void getSlice_unimportantSlice_shouldSkip() {
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.NEW, false)); tips.add(new EarlyWarningTip(BatteryTip.StateType.HANDLED, false));
ShadowBatteryTipLoader.setBatteryTips(tips); ShadowBatteryTipLoader.setBatteryTips(tips);
BatteryFixSlice.updateBatteryTipAvailabilityCache(mContext); BatteryFixSlice.updateBatteryTipAvailabilityCache(mContext);