Database restructure: use protobuf to save battery information fields.
This patch only updates the existing fields. There will be 2 following patches to: 1. Expose the new fields (foreground / foreground service / background x usage time / power consumption) to UI. 2. Get the full charge cycle start time from Database and remove the SharedPreference. Test: make RunSettingsRoboTests + manual Bug: 253553141 Change-Id: Iee02dc7e671f97899cb1495323acfa0173e31df2
This commit is contained in:
@@ -679,8 +679,19 @@ public final class BatteryChartPreferenceControllerTest {
|
||||
final Map<Long, Map<String, BatteryHistEntry>> batteryHistoryMap = new HashMap<>();
|
||||
for (int index = 0; index < numOfHours; index++) {
|
||||
final ContentValues values = new ContentValues();
|
||||
values.put("batteryLevel", Integer.valueOf(100 - index));
|
||||
values.put("consumePower", Integer.valueOf(100 - index));
|
||||
final DeviceBatteryState deviceBatteryState =
|
||||
DeviceBatteryState
|
||||
.newBuilder()
|
||||
.setBatteryLevel(100 - index)
|
||||
.build();
|
||||
final BatteryInformation batteryInformation =
|
||||
BatteryInformation
|
||||
.newBuilder()
|
||||
.setDeviceBatteryState(deviceBatteryState)
|
||||
.setConsumePower(100 - index)
|
||||
.build();
|
||||
values.put(BatteryHistEntry.KEY_BATTERY_INFORMATION,
|
||||
ConvertUtils.convertBatteryInformationToString(batteryInformation));
|
||||
final BatteryHistEntry entry = new BatteryHistEntry(values);
|
||||
final Map<String, BatteryHistEntry> entryMap = new HashMap<>();
|
||||
entryMap.put("fake_entry_key" + index, entry);
|
||||
|
@@ -138,8 +138,13 @@ public final class BatteryDiffEntryTest {
|
||||
// Generates fake testing data.
|
||||
final ContentValues values = getContentValuesWithType(
|
||||
ConvertUtils.CONSUMER_TYPE_SYSTEM_BATTERY);
|
||||
values.put(BatteryHistEntry.KEY_DRAIN_TYPE,
|
||||
Integer.valueOf(BatteryConsumer.POWER_COMPONENT_AMBIENT_DISPLAY));
|
||||
final BatteryInformation batteryInformation =
|
||||
BatteryInformation
|
||||
.newBuilder()
|
||||
.setDrainType(BatteryConsumer.POWER_COMPONENT_AMBIENT_DISPLAY)
|
||||
.build();
|
||||
values.put(BatteryHistEntry.KEY_BATTERY_INFORMATION,
|
||||
ConvertUtils.convertBatteryInformationToString(batteryInformation));
|
||||
final BatteryHistEntry batteryHistEntry = new BatteryHistEntry(values);
|
||||
|
||||
final BatteryDiffEntry entry = createBatteryDiffEntry(10, batteryHistEntry);
|
||||
@@ -233,7 +238,13 @@ public final class BatteryDiffEntryTest {
|
||||
final String expectedAppLabel = "fake app label";
|
||||
final ContentValues values = getContentValuesWithType(
|
||||
ConvertUtils.CONSUMER_TYPE_UID_BATTERY);
|
||||
values.put(BatteryHistEntry.KEY_APP_LABEL, expectedAppLabel);
|
||||
final BatteryInformation batteryInformation =
|
||||
BatteryInformation
|
||||
.newBuilder()
|
||||
.setAppLabel(expectedAppLabel)
|
||||
.build();
|
||||
values.put(BatteryHistEntry.KEY_BATTERY_INFORMATION,
|
||||
ConvertUtils.convertBatteryInformationToString(batteryInformation));
|
||||
final BatteryHistEntry batteryHistEntry = new BatteryHistEntry(values);
|
||||
|
||||
final BatteryDiffEntry entry = createBatteryDiffEntry(10, batteryHistEntry);
|
||||
@@ -461,7 +472,13 @@ public final class BatteryDiffEntryTest {
|
||||
private BatteryDiffEntry createBatteryDiffEntry(
|
||||
int consumerType, long uid, boolean isHidden) {
|
||||
final ContentValues values = getContentValuesWithType(consumerType);
|
||||
values.put(BatteryHistEntry.KEY_IS_HIDDEN, isHidden);
|
||||
final BatteryInformation batteryInformation =
|
||||
BatteryInformation
|
||||
.newBuilder()
|
||||
.setIsHidden(isHidden)
|
||||
.build();
|
||||
values.put(BatteryHistEntry.KEY_BATTERY_INFORMATION,
|
||||
ConvertUtils.convertBatteryInformationToString(batteryInformation));
|
||||
values.put(BatteryHistEntry.KEY_UID, uid);
|
||||
return new BatteryDiffEntry(
|
||||
mContext,
|
||||
|
@@ -124,7 +124,13 @@ public final class BatteryHistEntryTest {
|
||||
public void testGetKey_consumerSystemType_returnExpectedString() {
|
||||
final ContentValues values = getContentValuesWithType(
|
||||
ConvertUtils.CONSUMER_TYPE_SYSTEM_BATTERY);
|
||||
values.put(BatteryHistEntry.KEY_DRAIN_TYPE, 1);
|
||||
final BatteryInformation batteryInformation =
|
||||
BatteryInformation
|
||||
.newBuilder()
|
||||
.setDrainType(1)
|
||||
.build();
|
||||
values.put(BatteryHistEntry.KEY_BATTERY_INFORMATION,
|
||||
ConvertUtils.convertBatteryInformationToString(batteryInformation));
|
||||
final BatteryHistEntry batteryHistEntry = new BatteryHistEntry(values);
|
||||
|
||||
assertThat(batteryHistEntry.getKey()).isEqualTo("S|1");
|
||||
@@ -308,42 +314,40 @@ public final class BatteryHistEntryTest {
|
||||
new String[]{
|
||||
BatteryHistEntry.KEY_UID,
|
||||
BatteryHistEntry.KEY_USER_ID,
|
||||
BatteryHistEntry.KEY_APP_LABEL,
|
||||
BatteryHistEntry.KEY_PACKAGE_NAME,
|
||||
BatteryHistEntry.KEY_IS_HIDDEN,
|
||||
BatteryHistEntry.KEY_BOOT_TIMESTAMP,
|
||||
BatteryHistEntry.KEY_TIMESTAMP,
|
||||
BatteryHistEntry.KEY_ZONE_ID,
|
||||
BatteryHistEntry.KEY_TOTAL_POWER,
|
||||
BatteryHistEntry.KEY_CONSUME_POWER,
|
||||
BatteryHistEntry.KEY_PERCENT_OF_TOTAL,
|
||||
BatteryHistEntry.KEY_FOREGROUND_USAGE_TIME,
|
||||
BatteryHistEntry.KEY_BACKGROUND_USAGE_TIME,
|
||||
BatteryHistEntry.KEY_DRAIN_TYPE,
|
||||
BatteryHistEntry.KEY_CONSUMER_TYPE,
|
||||
BatteryHistEntry.KEY_BATTERY_LEVEL,
|
||||
BatteryHistEntry.KEY_BATTERY_STATUS,
|
||||
BatteryHistEntry.KEY_BATTERY_HEALTH});
|
||||
BatteryHistEntry.KEY_BATTERY_INFORMATION});
|
||||
DeviceBatteryState deviceBatteryState =
|
||||
DeviceBatteryState
|
||||
.newBuilder()
|
||||
.setBatteryLevel(batteryLevel)
|
||||
.setBatteryStatus(BatteryManager.BATTERY_STATUS_FULL)
|
||||
.setBatteryHealth(BatteryManager.BATTERY_HEALTH_COLD)
|
||||
.build();
|
||||
BatteryInformation batteryInformation =
|
||||
BatteryInformation
|
||||
.newBuilder()
|
||||
.setDeviceBatteryState(deviceBatteryState)
|
||||
.setIsHidden(true)
|
||||
.setBootTimestamp(bootTimestamp)
|
||||
.setZoneId(TimeZone.getDefault().getID())
|
||||
.setAppLabel("Settings")
|
||||
.setTotalPower(totalPower)
|
||||
.setConsumePower(consumePower)
|
||||
.setPercentOfTotal(0.3)
|
||||
.setDrainType(3)
|
||||
.setForegroundUsageTimeInMs(foregroundUsageTimeInMs)
|
||||
.setBackgroundUsageTimeInMs(backgroundUsageTimeInMs)
|
||||
.build();
|
||||
cursor.addRow(
|
||||
new Object[]{
|
||||
Long.valueOf(1001),
|
||||
Long.valueOf(UserHandle.getUserId(1001)),
|
||||
"Settings",
|
||||
"com.google.android.settings.battery",
|
||||
Integer.valueOf(1),
|
||||
Long.valueOf(bootTimestamp),
|
||||
Long.valueOf(timestamp),
|
||||
TimeZone.getDefault().getID(),
|
||||
Double.valueOf(totalPower),
|
||||
Double.valueOf(consumePower),
|
||||
Double.valueOf(0.3),
|
||||
Long.valueOf(foregroundUsageTimeInMs),
|
||||
Long.valueOf(backgroundUsageTimeInMs),
|
||||
Integer.valueOf(3),
|
||||
Integer.valueOf(ConvertUtils.CONSUMER_TYPE_SYSTEM_BATTERY),
|
||||
Integer.valueOf(batteryLevel),
|
||||
Integer.valueOf(BatteryManager.BATTERY_STATUS_FULL),
|
||||
Integer.valueOf(BatteryManager.BATTERY_HEALTH_COLD)});
|
||||
ConvertUtils.convertBatteryInformationToString(batteryInformation)});
|
||||
cursor.moveToFirst();
|
||||
return new BatteryHistEntry(cursor);
|
||||
}
|
||||
|
@@ -148,23 +148,37 @@ public final class BatteryUsageContentProviderTest {
|
||||
@Test
|
||||
public void insert_batteryState_returnsExpectedResult() {
|
||||
mProvider.onCreate();
|
||||
final DeviceBatteryState deviceBatteryState =
|
||||
DeviceBatteryState
|
||||
.newBuilder()
|
||||
.setBatteryLevel(51)
|
||||
.setBatteryStatus(2)
|
||||
.setBatteryHealth(3)
|
||||
.build();
|
||||
final BatteryInformation batteryInformation =
|
||||
BatteryInformation
|
||||
.newBuilder()
|
||||
.setDeviceBatteryState(deviceBatteryState)
|
||||
.setAppLabel("Settings")
|
||||
.setIsHidden(true)
|
||||
.setBootTimestamp(101L)
|
||||
.setTotalPower(99)
|
||||
.setConsumePower(9)
|
||||
.setPercentOfTotal(0.9)
|
||||
.setForegroundUsageTimeInMs(1000)
|
||||
.setBackgroundUsageTimeInMs(2000)
|
||||
.setDrainType(1)
|
||||
.build();
|
||||
final String expectedBatteryInformationString =
|
||||
ConvertUtils.convertBatteryInformationToString(batteryInformation);
|
||||
ContentValues values = new ContentValues();
|
||||
values.put("uid", Long.valueOf(101L));
|
||||
values.put("userId", Long.valueOf(1001L));
|
||||
values.put("appLabel", new String("Settings"));
|
||||
values.put("packageName", new String("com.android.settings"));
|
||||
values.put("timestamp", Long.valueOf(2100021L));
|
||||
values.put("isHidden", Boolean.valueOf(true));
|
||||
values.put("totalPower", Double.valueOf(99.0));
|
||||
values.put("consumePower", Double.valueOf(9.0));
|
||||
values.put("percentOfTotal", Double.valueOf(0.9));
|
||||
values.put("foregroundUsageTimeInMs", Long.valueOf(1000));
|
||||
values.put("backgroundUsageTimeInMs", Long.valueOf(2000));
|
||||
values.put("drainType", Integer.valueOf(1));
|
||||
values.put("consumerType", Integer.valueOf(2));
|
||||
values.put("batteryLevel", Integer.valueOf(51));
|
||||
values.put("batteryStatus", Integer.valueOf(2));
|
||||
values.put("batteryHealth", Integer.valueOf(3));
|
||||
values.put(BatteryHistEntry.KEY_UID, Long.valueOf(101L));
|
||||
values.put(BatteryHistEntry.KEY_USER_ID, Long.valueOf(1001L));
|
||||
values.put(BatteryHistEntry.KEY_PACKAGE_NAME, new String("com.android.settings"));
|
||||
values.put(BatteryHistEntry.KEY_TIMESTAMP, Long.valueOf(2100021L));
|
||||
values.put(BatteryHistEntry.KEY_CONSUMER_TYPE, Integer.valueOf(2));
|
||||
values.put(BatteryHistEntry.KEY_IS_FULL_CHARGE_CYCLE_START, true);
|
||||
values.put(BatteryHistEntry.KEY_BATTERY_INFORMATION, expectedBatteryInformationString);
|
||||
|
||||
final Uri uri = mProvider.insert(VALID_BATTERY_STATE_CONTENT_URI, values);
|
||||
|
||||
@@ -175,31 +189,34 @@ public final class BatteryUsageContentProviderTest {
|
||||
assertThat(states).hasSize(1);
|
||||
assertThat(states.get(0).uid).isEqualTo(101L);
|
||||
assertThat(states.get(0).userId).isEqualTo(1001L);
|
||||
assertThat(states.get(0).appLabel).isEqualTo("Settings");
|
||||
assertThat(states.get(0).packageName).isEqualTo("com.android.settings");
|
||||
assertThat(states.get(0).isHidden).isTrue();
|
||||
assertThat(states.get(0).timestamp).isEqualTo(2100021L);
|
||||
assertThat(states.get(0).totalPower).isEqualTo(99.0);
|
||||
assertThat(states.get(0).consumePower).isEqualTo(9.0);
|
||||
assertThat(states.get(0).percentOfTotal).isEqualTo(0.9);
|
||||
assertThat(states.get(0).foregroundUsageTimeInMs).isEqualTo(1000);
|
||||
assertThat(states.get(0).backgroundUsageTimeInMs).isEqualTo(2000);
|
||||
assertThat(states.get(0).drainType).isEqualTo(1);
|
||||
assertThat(states.get(0).consumerType).isEqualTo(2);
|
||||
assertThat(states.get(0).batteryLevel).isEqualTo(51);
|
||||
assertThat(states.get(0).batteryStatus).isEqualTo(2);
|
||||
assertThat(states.get(0).batteryHealth).isEqualTo(3);
|
||||
assertThat(states.get(0).isFullChargeCycleStart).isTrue();
|
||||
assertThat(states.get(0).batteryInformation).isEqualTo(expectedBatteryInformationString);
|
||||
}
|
||||
|
||||
@Test
|
||||
public void insert_partialFieldsContentValues_returnsExpectedResult() {
|
||||
mProvider.onCreate();
|
||||
final DeviceBatteryState deviceBatteryState =
|
||||
DeviceBatteryState
|
||||
.newBuilder()
|
||||
.setBatteryLevel(52)
|
||||
.setBatteryStatus(3)
|
||||
.setBatteryHealth(2)
|
||||
.build();
|
||||
final BatteryInformation batteryInformation =
|
||||
BatteryInformation
|
||||
.newBuilder()
|
||||
.setDeviceBatteryState(deviceBatteryState)
|
||||
.build();
|
||||
final String expectedBatteryInformationString =
|
||||
ConvertUtils.convertBatteryInformationToString(batteryInformation);
|
||||
final ContentValues values = new ContentValues();
|
||||
values.put("packageName", new String("fake_data"));
|
||||
values.put("timestamp", Long.valueOf(2100022L));
|
||||
values.put("batteryLevel", Integer.valueOf(52));
|
||||
values.put("batteryStatus", Integer.valueOf(3));
|
||||
values.put("batteryHealth", Integer.valueOf(2));
|
||||
values.put(BatteryHistEntry.KEY_PACKAGE_NAME, new String("fake_data"));
|
||||
values.put(BatteryHistEntry.KEY_TIMESTAMP, Long.valueOf(2100022L));
|
||||
values.put(BatteryHistEntry.KEY_BATTERY_INFORMATION, expectedBatteryInformationString);
|
||||
|
||||
final Uri uri = mProvider.insert(VALID_BATTERY_STATE_CONTENT_URI, values);
|
||||
|
||||
@@ -210,9 +227,7 @@ public final class BatteryUsageContentProviderTest {
|
||||
assertThat(states).hasSize(1);
|
||||
assertThat(states.get(0).packageName).isEqualTo("fake_data");
|
||||
assertThat(states.get(0).timestamp).isEqualTo(2100022L);
|
||||
assertThat(states.get(0).batteryLevel).isEqualTo(52);
|
||||
assertThat(states.get(0).batteryStatus).isEqualTo(3);
|
||||
assertThat(states.get(0).batteryHealth).isEqualTo(2);
|
||||
assertThat(states.get(0).batteryInformation).isEqualTo(expectedBatteryInformationString);
|
||||
}
|
||||
|
||||
@Test
|
||||
|
@@ -96,34 +96,33 @@ public final class ConvertUtilsTest {
|
||||
/*batteryHealth=*/ BatteryManager.BATTERY_HEALTH_COLD,
|
||||
/*bootTimestamp=*/ 101L,
|
||||
/*timestamp=*/ 10001L);
|
||||
final BatteryInformation batteryInformation =
|
||||
ConvertUtils.getBatteryInformation(
|
||||
values, BatteryHistEntry.KEY_BATTERY_INFORMATION);
|
||||
final DeviceBatteryState deviceBatteryState = batteryInformation.getDeviceBatteryState();
|
||||
|
||||
assertThat(values.getAsLong(BatteryHistEntry.KEY_UID)).isEqualTo(1001L);
|
||||
assertThat(values.getAsLong(BatteryHistEntry.KEY_USER_ID))
|
||||
.isEqualTo(UserHandle.getUserId(1001));
|
||||
assertThat(values.getAsString(BatteryHistEntry.KEY_APP_LABEL))
|
||||
.isEqualTo("Settings");
|
||||
assertThat(values.getAsString(BatteryHistEntry.KEY_PACKAGE_NAME))
|
||||
.isEqualTo("com.google.android.settings.battery");
|
||||
assertThat(values.getAsBoolean(BatteryHistEntry.KEY_IS_HIDDEN)).isTrue();
|
||||
assertThat(values.getAsLong(BatteryHistEntry.KEY_BOOT_TIMESTAMP))
|
||||
.isEqualTo(101L);
|
||||
assertThat(values.getAsLong(BatteryHistEntry.KEY_TIMESTAMP)).isEqualTo(10001L);
|
||||
assertThat(values.getAsString(BatteryHistEntry.KEY_ZONE_ID))
|
||||
.isEqualTo(TimeZone.getDefault().getID());
|
||||
assertThat(values.getAsDouble(BatteryHistEntry.KEY_TOTAL_POWER)).isEqualTo(5.1);
|
||||
assertThat(values.getAsDouble(BatteryHistEntry.KEY_CONSUME_POWER)).isEqualTo(1.1);
|
||||
assertThat(values.getAsDouble(BatteryHistEntry.KEY_PERCENT_OF_TOTAL)).isEqualTo(0.3);
|
||||
assertThat(values.getAsLong(BatteryHistEntry.KEY_FOREGROUND_USAGE_TIME))
|
||||
.isEqualTo(1234L);
|
||||
assertThat(values.getAsLong(BatteryHistEntry.KEY_BACKGROUND_USAGE_TIME))
|
||||
.isEqualTo(5689L);
|
||||
assertThat(values.getAsInteger(BatteryHistEntry.KEY_DRAIN_TYPE)).isEqualTo(expectedType);
|
||||
assertThat(values.getAsInteger(BatteryHistEntry.KEY_CONSUMER_TYPE))
|
||||
.isEqualTo(ConvertUtils.CONSUMER_TYPE_SYSTEM_BATTERY);
|
||||
assertThat(values.getAsInteger(BatteryHistEntry.KEY_BATTERY_LEVEL)).isEqualTo(12);
|
||||
assertThat(values.getAsInteger(BatteryHistEntry.KEY_BATTERY_STATUS))
|
||||
assertThat(batteryInformation.getAppLabel()).isEqualTo("Settings");
|
||||
assertThat(batteryInformation.getIsHidden()).isTrue();
|
||||
assertThat(batteryInformation.getBootTimestamp()).isEqualTo(101L);
|
||||
assertThat(batteryInformation.getZoneId()).isEqualTo(TimeZone.getDefault().getID());
|
||||
assertThat(batteryInformation.getTotalPower()).isEqualTo(5.1);
|
||||
assertThat(batteryInformation.getConsumePower()).isEqualTo(1.1);
|
||||
assertThat(batteryInformation.getPercentOfTotal()).isEqualTo(0.3);
|
||||
assertThat(batteryInformation.getForegroundUsageTimeInMs()).isEqualTo(1234L);
|
||||
assertThat(batteryInformation.getBackgroundUsageTimeInMs()).isEqualTo(5689L);
|
||||
assertThat(batteryInformation.getDrainType()).isEqualTo(expectedType);
|
||||
assertThat(deviceBatteryState.getBatteryLevel()).isEqualTo(12);
|
||||
assertThat(deviceBatteryState.getBatteryStatus())
|
||||
.isEqualTo(BatteryManager.BATTERY_STATUS_FULL);
|
||||
assertThat(values.getAsInteger(BatteryHistEntry.KEY_BATTERY_HEALTH))
|
||||
assertThat(deviceBatteryState.getBatteryHealth())
|
||||
.isEqualTo(BatteryManager.BATTERY_HEALTH_COLD);
|
||||
}
|
||||
|
||||
@@ -139,17 +138,19 @@ public final class ConvertUtilsTest {
|
||||
/*bootTimestamp=*/ 101L,
|
||||
/*timestamp=*/ 10001L);
|
||||
|
||||
assertThat(values.getAsLong(BatteryHistEntry.KEY_BOOT_TIMESTAMP))
|
||||
.isEqualTo(101L);
|
||||
final BatteryInformation batteryInformation =
|
||||
ConvertUtils.getBatteryInformation(
|
||||
values, BatteryHistEntry.KEY_BATTERY_INFORMATION);
|
||||
final DeviceBatteryState deviceBatteryState = batteryInformation.getDeviceBatteryState();
|
||||
assertThat(batteryInformation.getBootTimestamp()).isEqualTo(101L);
|
||||
assertThat(batteryInformation.getZoneId()).isEqualTo(TimeZone.getDefault().getID());
|
||||
assertThat(deviceBatteryState.getBatteryLevel()).isEqualTo(12);
|
||||
assertThat(deviceBatteryState.getBatteryStatus())
|
||||
.isEqualTo(BatteryManager.BATTERY_STATUS_FULL);
|
||||
assertThat(deviceBatteryState.getBatteryHealth())
|
||||
.isEqualTo(BatteryManager.BATTERY_HEALTH_COLD);
|
||||
assertThat(values.getAsLong(BatteryHistEntry.KEY_TIMESTAMP))
|
||||
.isEqualTo(10001L);
|
||||
assertThat(values.getAsString(BatteryHistEntry.KEY_ZONE_ID))
|
||||
.isEqualTo(TimeZone.getDefault().getID());
|
||||
assertThat(values.getAsInteger(BatteryHistEntry.KEY_BATTERY_LEVEL)).isEqualTo(12);
|
||||
assertThat(values.getAsInteger(BatteryHistEntry.KEY_BATTERY_STATUS))
|
||||
.isEqualTo(BatteryManager.BATTERY_STATUS_FULL);
|
||||
assertThat(values.getAsInteger(BatteryHistEntry.KEY_BATTERY_HEALTH))
|
||||
.isEqualTo(BatteryManager.BATTERY_HEALTH_COLD);
|
||||
assertThat(values.getAsString(BatteryHistEntry.KEY_PACKAGE_NAME))
|
||||
.isEqualTo(ConvertUtils.FAKE_PACKAGE_NAME);
|
||||
}
|
||||
@@ -499,17 +500,21 @@ public final class ConvertUtilsTest {
|
||||
String packageName, String appLabel, double consumePower,
|
||||
long uid, long foregroundUsageTimeInMs, long backgroundUsageTimeInMs) {
|
||||
// Only insert required fields.
|
||||
final BatteryInformation batteryInformation =
|
||||
BatteryInformation
|
||||
.newBuilder()
|
||||
.setAppLabel(appLabel)
|
||||
.setConsumePower(consumePower)
|
||||
.setForegroundUsageTimeInMs(foregroundUsageTimeInMs)
|
||||
.setBackgroundUsageTimeInMs(backgroundUsageTimeInMs)
|
||||
.build();
|
||||
final ContentValues values = new ContentValues();
|
||||
values.put(BatteryHistEntry.KEY_PACKAGE_NAME, packageName);
|
||||
values.put(BatteryHistEntry.KEY_APP_LABEL, appLabel);
|
||||
values.put(BatteryHistEntry.KEY_UID, Long.valueOf(uid));
|
||||
values.put(BatteryHistEntry.KEY_CONSUMER_TYPE,
|
||||
Integer.valueOf(ConvertUtils.CONSUMER_TYPE_UID_BATTERY));
|
||||
values.put(BatteryHistEntry.KEY_CONSUME_POWER, consumePower);
|
||||
values.put(BatteryHistEntry.KEY_FOREGROUND_USAGE_TIME,
|
||||
Long.valueOf(foregroundUsageTimeInMs));
|
||||
values.put(BatteryHistEntry.KEY_BACKGROUND_USAGE_TIME,
|
||||
Long.valueOf(backgroundUsageTimeInMs));
|
||||
values.put(BatteryHistEntry.KEY_BATTERY_INFORMATION,
|
||||
ConvertUtils.convertBatteryInformationToString(batteryInformation));
|
||||
return new BatteryHistEntry(values);
|
||||
}
|
||||
|
||||
|
@@ -458,8 +458,7 @@ public class DataProcessorTest {
|
||||
@Test
|
||||
public void isFromFullCharge_chargedData_returnTrue() {
|
||||
final Map<String, BatteryHistEntry> entryMap = new HashMap<>();
|
||||
final ContentValues values = new ContentValues();
|
||||
values.put("batteryLevel", 100);
|
||||
final ContentValues values = getContentValuesWithBatteryLevel(100);
|
||||
final BatteryHistEntry entry = new BatteryHistEntry(values);
|
||||
entryMap.put(FAKE_ENTRY_KEY, entry);
|
||||
|
||||
@@ -1042,8 +1041,7 @@ public class DataProcessorTest {
|
||||
final Map<Long, Map<String, BatteryHistEntry>> batteryHistoryMap = new HashMap<>();
|
||||
for (int index = 0; index < timestamps.length; index++) {
|
||||
final Map<String, BatteryHistEntry> entryMap = new HashMap<>();
|
||||
final ContentValues values = new ContentValues();
|
||||
values.put(BatteryHistEntry.KEY_BATTERY_LEVEL, levels[index]);
|
||||
final ContentValues values = getContentValuesWithBatteryLevel(levels[index]);
|
||||
final BatteryHistEntry entry = new BatteryHistEntry(values);
|
||||
entryMap.put(FAKE_ENTRY_KEY, entry);
|
||||
batteryHistoryMap.put(timestamps[index], entryMap);
|
||||
@@ -1051,20 +1049,43 @@ public class DataProcessorTest {
|
||||
return batteryHistoryMap;
|
||||
}
|
||||
|
||||
private static ContentValues getContentValuesWithBatteryLevel(final int level) {
|
||||
final ContentValues values = new ContentValues();
|
||||
final DeviceBatteryState deviceBatteryState =
|
||||
DeviceBatteryState
|
||||
.newBuilder()
|
||||
.setBatteryLevel(level)
|
||||
.build();
|
||||
final BatteryInformation batteryInformation =
|
||||
BatteryInformation
|
||||
.newBuilder()
|
||||
.setDeviceBatteryState(deviceBatteryState)
|
||||
.build();
|
||||
values.put(BatteryHistEntry.KEY_BATTERY_INFORMATION,
|
||||
ConvertUtils.convertBatteryInformationToString(batteryInformation));
|
||||
return values;
|
||||
}
|
||||
|
||||
private static BatteryHistEntry createBatteryHistEntry(
|
||||
final String packageName, final String appLabel, final double consumePower,
|
||||
final long uid, final long userId, final int consumerType,
|
||||
final long foregroundUsageTimeInMs, final long backgroundUsageTimeInMs) {
|
||||
// Only insert required fields.
|
||||
final BatteryInformation batteryInformation =
|
||||
BatteryInformation
|
||||
.newBuilder()
|
||||
.setAppLabel(appLabel)
|
||||
.setConsumePower(consumePower)
|
||||
.setForegroundUsageTimeInMs(foregroundUsageTimeInMs)
|
||||
.setBackgroundUsageTimeInMs(backgroundUsageTimeInMs)
|
||||
.build();
|
||||
final ContentValues values = new ContentValues();
|
||||
values.put(BatteryHistEntry.KEY_PACKAGE_NAME, packageName);
|
||||
values.put(BatteryHistEntry.KEY_APP_LABEL, appLabel);
|
||||
values.put(BatteryHistEntry.KEY_UID, uid);
|
||||
values.put(BatteryHistEntry.KEY_USER_ID, userId);
|
||||
values.put(BatteryHistEntry.KEY_CONSUMER_TYPE, consumerType);
|
||||
values.put(BatteryHistEntry.KEY_CONSUME_POWER, consumePower);
|
||||
values.put(BatteryHistEntry.KEY_FOREGROUND_USAGE_TIME, foregroundUsageTimeInMs);
|
||||
values.put(BatteryHistEntry.KEY_BACKGROUND_USAGE_TIME, backgroundUsageTimeInMs);
|
||||
values.put(BatteryHistEntry.KEY_BATTERY_INFORMATION,
|
||||
ConvertUtils.convertBatteryInformationToString(batteryInformation));
|
||||
return new BatteryHistEntry(values);
|
||||
}
|
||||
|
||||
|
@@ -231,13 +231,13 @@ public final class DatabaseUtilsTest {
|
||||
// Verifies the BatteryHistEntry data for timestamp1.
|
||||
Map<String, BatteryHistEntry> batteryMap = batteryHistMap.get(timestamp1);
|
||||
assertThat(batteryMap).hasSize(1);
|
||||
assertThat(batteryMap.get("1").mAppLabel).isEqualTo("app name1");
|
||||
assertThat(batteryMap.get("1").mPackageName).isEqualTo("app name1");
|
||||
// Verifies the BatteryHistEntry data for timestamp2.
|
||||
batteryMap = batteryHistMap.get(timestamp2);
|
||||
assertThat(batteryMap).hasSize(3);
|
||||
assertThat(batteryMap.get("2").mAppLabel).isEqualTo("app name2");
|
||||
assertThat(batteryMap.get("3").mAppLabel).isEqualTo("app name3");
|
||||
assertThat(batteryMap.get("4").mAppLabel).isEqualTo("app name4");
|
||||
assertThat(batteryMap.get("2").mPackageName).isEqualTo("app name2");
|
||||
assertThat(batteryMap.get("3").mPackageName).isEqualTo("app name3");
|
||||
assertThat(batteryMap.get("4").mPackageName).isEqualTo("app name4");
|
||||
}
|
||||
|
||||
@Test
|
||||
@@ -341,20 +341,27 @@ public final class DatabaseUtilsTest {
|
||||
}
|
||||
|
||||
private static void verifyContentValues(double consumedPower, ContentValues values) {
|
||||
assertThat(values.getAsDouble(BatteryHistEntry.KEY_CONSUME_POWER))
|
||||
.isEqualTo(consumedPower);
|
||||
assertThat(values.getAsInteger(BatteryHistEntry.KEY_BATTERY_LEVEL)).isEqualTo(20);
|
||||
assertThat(values.getAsInteger(BatteryHistEntry.KEY_BATTERY_STATUS))
|
||||
final BatteryInformation batteryInformation =
|
||||
ConvertUtils.getBatteryInformation(
|
||||
values, BatteryHistEntry.KEY_BATTERY_INFORMATION);
|
||||
final DeviceBatteryState deviceBatteryState = batteryInformation.getDeviceBatteryState();
|
||||
assertThat(batteryInformation.getConsumePower()).isEqualTo(consumedPower);
|
||||
assertThat(deviceBatteryState.getBatteryLevel()).isEqualTo(20);
|
||||
assertThat(deviceBatteryState.getBatteryStatus())
|
||||
.isEqualTo(BatteryManager.BATTERY_STATUS_FULL);
|
||||
assertThat(values.getAsInteger(BatteryHistEntry.KEY_BATTERY_HEALTH))
|
||||
assertThat(deviceBatteryState.getBatteryHealth())
|
||||
.isEqualTo(BatteryManager.BATTERY_HEALTH_COLD);
|
||||
}
|
||||
|
||||
private static void verifyFakeContentValues(ContentValues values) {
|
||||
assertThat(values.getAsInteger("batteryLevel")).isEqualTo(20);
|
||||
assertThat(values.getAsInteger("batteryStatus"))
|
||||
final BatteryInformation batteryInformation =
|
||||
ConvertUtils.getBatteryInformation(
|
||||
values, BatteryHistEntry.KEY_BATTERY_INFORMATION);
|
||||
final DeviceBatteryState deviceBatteryState = batteryInformation.getDeviceBatteryState();
|
||||
assertThat(deviceBatteryState.getBatteryLevel()).isEqualTo(20);
|
||||
assertThat(deviceBatteryState.getBatteryStatus())
|
||||
.isEqualTo(BatteryManager.BATTERY_STATUS_FULL);
|
||||
assertThat(values.getAsInteger("batteryHealth"))
|
||||
assertThat(deviceBatteryState.getBatteryHealth())
|
||||
.isEqualTo(BatteryManager.BATTERY_HEALTH_COLD);
|
||||
assertThat(values.getAsString("packageName"))
|
||||
.isEqualTo(ConvertUtils.FAKE_PACKAGE_NAME);
|
||||
@@ -372,7 +379,7 @@ public final class DatabaseUtilsTest {
|
||||
private static MatrixCursor getMatrixCursor() {
|
||||
return new MatrixCursor(
|
||||
new String[] {
|
||||
BatteryHistEntry.KEY_APP_LABEL,
|
||||
BatteryHistEntry.KEY_PACKAGE_NAME,
|
||||
BatteryHistEntry.KEY_TIMESTAMP,
|
||||
BatteryHistEntry.KEY_UID,
|
||||
BatteryHistEntry.KEY_CONSUMER_TYPE});
|
||||
|
@@ -36,7 +36,7 @@ import java.util.List;
|
||||
/** Tests for {@link BatteryStateDao}. */
|
||||
@RunWith(RobolectricTestRunner.class)
|
||||
public final class BatteryStateDaoTest {
|
||||
private static final int CURSOR_COLUMN_SIZE = 19;
|
||||
private static final int CURSOR_COLUMN_SIZE = 9;
|
||||
private static final long TIMESTAMP1 = System.currentTimeMillis();
|
||||
private static final long TIMESTAMP2 = System.currentTimeMillis() + 2;
|
||||
private static final long TIMESTAMP3 = System.currentTimeMillis() + 4;
|
||||
@@ -81,10 +81,10 @@ public final class BatteryStateDaoTest {
|
||||
assertThat(cursor.getColumnCount()).isEqualTo(CURSOR_COLUMN_SIZE);
|
||||
// Verifies the queried first battery state.
|
||||
cursor.moveToFirst();
|
||||
assertThat(cursor.getString(4 /*packageName*/)).isEqualTo(PACKAGE_NAME3);
|
||||
assertThat(cursor.getString(3 /*packageName*/)).isEqualTo(PACKAGE_NAME3);
|
||||
// Verifies the queried second battery state.
|
||||
cursor.moveToNext();
|
||||
assertThat(cursor.getString(4 /*packageName*/)).isEqualTo(PACKAGE_NAME2);
|
||||
assertThat(cursor.getString(3 /*packageName*/)).isEqualTo(PACKAGE_NAME2);
|
||||
}
|
||||
|
||||
@Test
|
||||
|
@@ -18,9 +18,12 @@ package com.android.settings.fuelgauge.batteryusage.db;
|
||||
|
||||
import static com.google.common.truth.Truth.assertThat;
|
||||
|
||||
import android.content.Intent;
|
||||
import android.os.BatteryManager;
|
||||
|
||||
import com.android.settings.fuelgauge.batteryusage.BatteryInformation;
|
||||
import com.android.settings.fuelgauge.batteryusage.ConvertUtils;
|
||||
import com.android.settings.fuelgauge.batteryusage.DeviceBatteryState;
|
||||
|
||||
import org.junit.Before;
|
||||
import org.junit.Test;
|
||||
import org.junit.runner.RunWith;
|
||||
@@ -33,66 +36,58 @@ public final class BatteryStateTest {
|
||||
private static final int BATTERY_STATUS = BatteryManager.BATTERY_STATUS_FULL;
|
||||
private static final int BATTERY_HEALTH = BatteryManager.BATTERY_HEALTH_COLD;
|
||||
|
||||
private Intent mBatteryIntent;
|
||||
private BatteryInformation mBatteryInformation;
|
||||
|
||||
@Before
|
||||
public void setUp() {
|
||||
mBatteryIntent = new Intent(Intent.ACTION_BATTERY_CHANGED);
|
||||
// Inserts the battery states into intent.
|
||||
mBatteryIntent.putExtra(BatteryManager.EXTRA_LEVEL, BATTERY_LEVEL);
|
||||
mBatteryIntent.putExtra(BatteryManager.EXTRA_STATUS, BATTERY_STATUS);
|
||||
mBatteryIntent.putExtra(BatteryManager.EXTRA_HEALTH, BATTERY_HEALTH);
|
||||
final DeviceBatteryState deviceBatteryState =
|
||||
DeviceBatteryState
|
||||
.newBuilder()
|
||||
.setBatteryLevel(BATTERY_LEVEL)
|
||||
.setBatteryStatus(BATTERY_STATUS)
|
||||
.setBatteryHealth(BATTERY_HEALTH)
|
||||
.build();
|
||||
mBatteryInformation =
|
||||
BatteryInformation
|
||||
.newBuilder()
|
||||
.setDeviceBatteryState(deviceBatteryState)
|
||||
.setBootTimestamp(101L)
|
||||
.setIsHidden(true)
|
||||
.setAppLabel("Settings")
|
||||
.setTotalPower(100)
|
||||
.setConsumePower(3)
|
||||
.setPercentOfTotal(10)
|
||||
.setDrainType(1)
|
||||
.setForegroundUsageTimeInMs(60000)
|
||||
.setBackgroundUsageTimeInMs(10000)
|
||||
.build();
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testBuilder_returnsExpectedResult() {
|
||||
mBatteryIntent.putExtra(BatteryManager.EXTRA_SCALE, 100);
|
||||
BatteryState state = create(mBatteryIntent);
|
||||
BatteryState state = create(mBatteryInformation);
|
||||
|
||||
// Verifies the app relative information.
|
||||
assertThat(state.uid).isEqualTo(1001L);
|
||||
assertThat(state.userId).isEqualTo(100L);
|
||||
assertThat(state.appLabel).isEqualTo("Settings");
|
||||
assertThat(state.packageName).isEqualTo("com.android.settings");
|
||||
assertThat(state.isHidden).isTrue();
|
||||
assertThat(state.bootTimestamp).isEqualTo(101L);
|
||||
assertThat(state.timestamp).isEqualTo(100001L);
|
||||
// Verifies the battery relative information.
|
||||
assertThat(state.totalPower).isEqualTo(100);
|
||||
assertThat(state.consumePower).isEqualTo(3);
|
||||
assertThat(state.percentOfTotal).isEqualTo(10);
|
||||
assertThat(state.foregroundUsageTimeInMs).isEqualTo(60000);
|
||||
assertThat(state.backgroundUsageTimeInMs).isEqualTo(10000);
|
||||
assertThat(state.drainType).isEqualTo(1);
|
||||
assertThat(state.consumerType).isEqualTo(2);
|
||||
assertThat(state.batteryLevel).isEqualTo(BATTERY_LEVEL);
|
||||
assertThat(state.batteryStatus).isEqualTo(BATTERY_STATUS);
|
||||
assertThat(state.batteryHealth).isEqualTo(BATTERY_HEALTH);
|
||||
assertThat(state.isFullChargeCycleStart).isTrue();
|
||||
assertThat(state.batteryInformation).isEqualTo(
|
||||
ConvertUtils.convertBatteryInformationToString(mBatteryInformation));
|
||||
}
|
||||
|
||||
@Test
|
||||
public void create_withoutBatteryScale_returnsStateWithInvalidLevel() {
|
||||
BatteryState state = create(mBatteryIntent);
|
||||
assertThat(state.batteryLevel).isEqualTo(-1);
|
||||
}
|
||||
|
||||
private static BatteryState create(Intent intent) {
|
||||
private static BatteryState create(BatteryInformation batteryInformation) {
|
||||
return BatteryState.newBuilder()
|
||||
.setUid(1001L)
|
||||
.setUserId(100L)
|
||||
.setAppLabel("Settings")
|
||||
.setPackageName("com.android.settings")
|
||||
.setIsHidden(true)
|
||||
.setBootTimestamp(101L)
|
||||
.setTimestamp(100001L)
|
||||
.setTotalPower(100f)
|
||||
.setConsumePower(3f)
|
||||
.setPercentOfTotal(10f)
|
||||
.setForegroundUsageTimeInMs(60000)
|
||||
.setBackgroundUsageTimeInMs(10000)
|
||||
.setDrainType(1)
|
||||
.setConsumerType(2)
|
||||
.setBatteryIntent(intent)
|
||||
.setIsFullChargeCycleStart(true)
|
||||
.setBatteryInformation(
|
||||
ConvertUtils.convertBatteryInformationToString(batteryInformation))
|
||||
.build();
|
||||
}
|
||||
}
|
||||
|
@@ -23,6 +23,9 @@ import android.os.UserManager;
|
||||
|
||||
import androidx.room.Room;
|
||||
|
||||
import com.android.settings.fuelgauge.batteryusage.BatteryInformation;
|
||||
import com.android.settings.fuelgauge.batteryusage.ConvertUtils;
|
||||
import com.android.settings.fuelgauge.batteryusage.DeviceBatteryState;
|
||||
import com.android.settings.fuelgauge.batteryusage.db.BatteryState;
|
||||
import com.android.settings.fuelgauge.batteryusage.db.BatteryStateDao;
|
||||
import com.android.settings.fuelgauge.batteryusage.db.BatteryStateDatabase;
|
||||
@@ -75,26 +78,44 @@ public class BatteryTestUtils {
|
||||
/** Inserts a fake data into the database for testing. */
|
||||
public static void insertDataToBatteryStateDatabase(
|
||||
Context context, long timestamp, String packageName, boolean multiple) {
|
||||
DeviceBatteryState deviceBatteryState =
|
||||
DeviceBatteryState
|
||||
.newBuilder()
|
||||
.setBatteryLevel(31)
|
||||
.setBatteryStatus(0)
|
||||
.setBatteryHealth(0)
|
||||
.build();
|
||||
BatteryInformation batteryInformation =
|
||||
BatteryInformation
|
||||
.newBuilder()
|
||||
.setDeviceBatteryState(deviceBatteryState)
|
||||
.setIsHidden(true)
|
||||
.setBootTimestamp(timestamp - 1)
|
||||
.setZoneId("Europe/Paris")
|
||||
.setAppLabel("Settings")
|
||||
.setTotalPower(100f)
|
||||
.setConsumePower(0.3f)
|
||||
.setPercentOfTotal(10f)
|
||||
.setDrainType(1)
|
||||
.setForegroundUsageTimeInMs(60000)
|
||||
.setForegroundServiceUsageTimeInMs(30000)
|
||||
.setBackgroundUsageTimeInMs(10000)
|
||||
.setForegroundUsageConsumePower(0.1f)
|
||||
.setForegroundServiceUsageConsumePower(0.05f)
|
||||
.setBackgroundUsageConsumePower(0.1f)
|
||||
.setCachedUsageConsumePower(0.05f)
|
||||
.build();
|
||||
|
||||
final BatteryState state =
|
||||
new BatteryState(
|
||||
/*uid=*/ 1001L,
|
||||
/*userId=*/ 100L,
|
||||
/*appLabel=*/ "Settings",
|
||||
packageName,
|
||||
/*isHidden=*/ true,
|
||||
/*bootTimestamp=*/ timestamp - 1,
|
||||
timestamp,
|
||||
/*zoneId=*/ "Europe/Paris",
|
||||
/*totalPower=*/ 100f,
|
||||
/*consumePower=*/ 0.3f,
|
||||
/*percentOfTotal=*/ 10f,
|
||||
/*foregroundUsageTimeInMs=*/ 60000,
|
||||
/*backgroundUsageTimeInMs=*/ 10000,
|
||||
/*drainType=*/ 1,
|
||||
/*consumerType=*/ 2,
|
||||
/*batteryLevel=*/ 31,
|
||||
/*batteryStatus=*/ 0,
|
||||
/*batteryHealth=*/ 0);
|
||||
/*isFullChargeCycleStart=*/ false,
|
||||
ConvertUtils.convertBatteryInformationToString(batteryInformation),
|
||||
"");
|
||||
BatteryStateDao dao =
|
||||
BatteryStateDatabase.getInstance(context).batteryStateDao();
|
||||
if (multiple) {
|
||||
|
Reference in New Issue
Block a user