Show app list in Battery Usage page when there is no battery level data.
https://drive.google.com/file/d/1iQxKmEp_weNYdT4JnsiZgYy9mCdn7SRv/view?usp=sharing Bug: 246233366 Test: make RunSettingsRoboTests + manually Change-Id: If536c93652506c8009f5cabf3d0ae373b6825bfc Merged-In: If536c93652506c8009f5cabf3d0ae373b6825bfc
This commit is contained in:
@@ -64,7 +64,7 @@ public final class BatteryHistEntryTest {
|
||||
when(mMockBatteryEntry.getConsumerType())
|
||||
.thenReturn(ConvertUtils.CONSUMER_TYPE_SYSTEM_BATTERY);
|
||||
final ContentValues values =
|
||||
ConvertUtils.convert(
|
||||
ConvertUtils.convertToContentValues(
|
||||
mMockBatteryEntry,
|
||||
mBatteryUsageStats,
|
||||
/*batteryLevel=*/ 12,
|
||||
|
@@ -71,7 +71,7 @@ public final class ConvertUtilsTest {
|
||||
}
|
||||
|
||||
@Test
|
||||
public void convert_returnsExpectedContentValues() {
|
||||
public void convertToContentValues_returnsExpectedContentValues() {
|
||||
final int expectedType = 3;
|
||||
when(mMockBatteryEntry.getUid()).thenReturn(1001);
|
||||
when(mMockBatteryEntry.getLabel()).thenReturn("Settings");
|
||||
@@ -88,7 +88,7 @@ public final class ConvertUtilsTest {
|
||||
.thenReturn(ConvertUtils.CONSUMER_TYPE_SYSTEM_BATTERY);
|
||||
|
||||
final ContentValues values =
|
||||
ConvertUtils.convert(
|
||||
ConvertUtils.convertToContentValues(
|
||||
mMockBatteryEntry,
|
||||
mBatteryUsageStats,
|
||||
/*batteryLevel=*/ 12,
|
||||
@@ -128,9 +128,9 @@ public final class ConvertUtilsTest {
|
||||
}
|
||||
|
||||
@Test
|
||||
public void convert_nullBatteryEntry_returnsExpectedContentValues() {
|
||||
public void convertToContentValues_nullBatteryEntry_returnsExpectedContentValues() {
|
||||
final ContentValues values =
|
||||
ConvertUtils.convert(
|
||||
ConvertUtils.convertToContentValues(
|
||||
/*entry=*/ null,
|
||||
/*batteryUsageStats=*/ null,
|
||||
/*batteryLevel=*/ 12,
|
||||
@@ -154,6 +154,76 @@ public final class ConvertUtilsTest {
|
||||
.isEqualTo(ConvertUtils.FAKE_PACKAGE_NAME);
|
||||
}
|
||||
|
||||
@Test
|
||||
public void convertToBatteryHistEntry_returnsExpectedResult() {
|
||||
final int expectedType = 3;
|
||||
when(mMockBatteryEntry.getUid()).thenReturn(1001);
|
||||
when(mMockBatteryEntry.getLabel()).thenReturn("Settings");
|
||||
when(mMockBatteryEntry.getDefaultPackageName())
|
||||
.thenReturn("com.android.settings.battery");
|
||||
when(mMockBatteryEntry.isHidden()).thenReturn(true);
|
||||
when(mBatteryUsageStats.getConsumedPower()).thenReturn(5.1);
|
||||
when(mMockBatteryEntry.getConsumedPower()).thenReturn(1.1);
|
||||
mMockBatteryEntry.mPercent = 0.3;
|
||||
when(mMockBatteryEntry.getTimeInForegroundMs()).thenReturn(1234L);
|
||||
when(mMockBatteryEntry.getTimeInBackgroundMs()).thenReturn(5689L);
|
||||
when(mMockBatteryEntry.getPowerComponentId()).thenReturn(expectedType);
|
||||
when(mMockBatteryEntry.getConsumerType())
|
||||
.thenReturn(ConvertUtils.CONSUMER_TYPE_SYSTEM_BATTERY);
|
||||
|
||||
final BatteryHistEntry batteryHistEntry =
|
||||
ConvertUtils.convertToBatteryHistEntry(
|
||||
mMockBatteryEntry,
|
||||
mBatteryUsageStats);
|
||||
|
||||
assertThat(batteryHistEntry.mUid).isEqualTo(1001L);
|
||||
assertThat(batteryHistEntry.mUserId)
|
||||
.isEqualTo(UserHandle.getUserId(1001));
|
||||
assertThat(batteryHistEntry.mAppLabel)
|
||||
.isEqualTo("Settings");
|
||||
assertThat(batteryHistEntry.mPackageName)
|
||||
.isEqualTo("com.android.settings.battery");
|
||||
assertThat(batteryHistEntry.mIsHidden).isTrue();
|
||||
assertThat(batteryHistEntry.mBootTimestamp)
|
||||
.isEqualTo(0L);
|
||||
assertThat(batteryHistEntry.mTimestamp).isEqualTo(0L);
|
||||
assertThat(batteryHistEntry.mZoneId)
|
||||
.isEqualTo(TimeZone.getDefault().getID());
|
||||
assertThat(batteryHistEntry.mTotalPower).isEqualTo(5.1);
|
||||
assertThat(batteryHistEntry.mConsumePower).isEqualTo(1.1);
|
||||
assertThat(batteryHistEntry.mPercentOfTotal).isEqualTo(0.3);
|
||||
assertThat(batteryHistEntry.mForegroundUsageTimeInMs)
|
||||
.isEqualTo(1234L);
|
||||
assertThat(batteryHistEntry.mBackgroundUsageTimeInMs)
|
||||
.isEqualTo(5689L);
|
||||
assertThat(batteryHistEntry.mDrainType).isEqualTo(expectedType);
|
||||
assertThat(batteryHistEntry.mConsumerType)
|
||||
.isEqualTo(ConvertUtils.CONSUMER_TYPE_SYSTEM_BATTERY);
|
||||
assertThat(batteryHistEntry.mBatteryLevel).isEqualTo(0);
|
||||
assertThat(batteryHistEntry.mBatteryStatus).isEqualTo(0);
|
||||
assertThat(batteryHistEntry.mBatteryHealth).isEqualTo(0);
|
||||
}
|
||||
|
||||
@Test
|
||||
public void convertToBatteryHistEntry_nullBatteryEntry_returnsExpectedResult() {
|
||||
final BatteryHistEntry batteryHistEntry =
|
||||
ConvertUtils.convertToBatteryHistEntry(
|
||||
/*entry=*/ null,
|
||||
/*batteryUsageStats=*/ null);
|
||||
|
||||
assertThat(batteryHistEntry.mBootTimestamp)
|
||||
.isEqualTo(0L);
|
||||
assertThat(batteryHistEntry.mTimestamp)
|
||||
.isEqualTo(0);
|
||||
assertThat(batteryHistEntry.mZoneId)
|
||||
.isEqualTo(TimeZone.getDefault().getID());
|
||||
assertThat(batteryHistEntry.mBatteryLevel).isEqualTo(0);
|
||||
assertThat(batteryHistEntry.mBatteryStatus).isEqualTo(0);
|
||||
assertThat(batteryHistEntry.mBatteryHealth).isEqualTo(0);
|
||||
assertThat(batteryHistEntry.mPackageName)
|
||||
.isEqualTo(ConvertUtils.FAKE_PACKAGE_NAME);
|
||||
}
|
||||
|
||||
@Test
|
||||
public void getIndexedUsageMap_nullOrEmptyHistoryMap_returnEmptyCollection() {
|
||||
final int timeSlotSize = 2;
|
||||
|
@@ -18,6 +18,7 @@ package com.android.settings.fuelgauge.batteryusage;
|
||||
|
||||
import static com.google.common.truth.Truth.assertThat;
|
||||
|
||||
import static org.mockito.Mockito.doReturn;
|
||||
import static org.mockito.Mockito.never;
|
||||
import static org.mockito.Mockito.spy;
|
||||
import static org.mockito.Mockito.verify;
|
||||
@@ -26,6 +27,8 @@ import static org.mockito.Mockito.when;
|
||||
import android.app.settings.SettingsEnums;
|
||||
import android.content.ContentValues;
|
||||
import android.content.Context;
|
||||
import android.os.BatteryConsumer;
|
||||
import android.os.BatteryUsageStats;
|
||||
import android.text.format.DateUtils;
|
||||
|
||||
import com.android.settings.fuelgauge.BatteryUtils;
|
||||
@@ -36,6 +39,7 @@ import com.android.settingslib.core.instrumentation.MetricsFeatureProvider;
|
||||
import org.junit.Before;
|
||||
import org.junit.Test;
|
||||
import org.junit.runner.RunWith;
|
||||
import org.mockito.Mock;
|
||||
import org.mockito.MockitoAnnotations;
|
||||
import org.robolectric.RobolectricTestRunner;
|
||||
import org.robolectric.RuntimeEnvironment;
|
||||
@@ -59,6 +63,13 @@ public class DataProcessorTest {
|
||||
private MetricsFeatureProvider mMetricsFeatureProvider;
|
||||
private PowerUsageFeatureProvider mPowerUsageFeatureProvider;
|
||||
|
||||
@Mock private BatteryUsageStats mBatteryUsageStats;
|
||||
@Mock private BatteryEntry mMockBatteryEntry1;
|
||||
@Mock private BatteryEntry mMockBatteryEntry2;
|
||||
@Mock private BatteryEntry mMockBatteryEntry3;
|
||||
@Mock private BatteryEntry mMockBatteryEntry4;
|
||||
|
||||
|
||||
@Before
|
||||
public void setUp() {
|
||||
MockitoAnnotations.initMocks(this);
|
||||
@@ -883,6 +894,60 @@ public class DataProcessorTest {
|
||||
.action(mContext, SettingsEnums.ACTION_BATTERY_USAGE_HIDDEN_APP_COUNT, 0);
|
||||
}
|
||||
|
||||
@Test
|
||||
public void generateBatteryDiffData_emptyBatteryEntryList_returnNull() {
|
||||
assertThat(DataProcessor.generateBatteryDiffData(
|
||||
mContext, null, mBatteryUsageStats)).isNull();
|
||||
}
|
||||
|
||||
@Test
|
||||
public void generateBatteryDiffData_returnsExpectedResult() {
|
||||
final List<BatteryEntry> batteryEntryList = new ArrayList<>();
|
||||
batteryEntryList.add(mMockBatteryEntry1);
|
||||
batteryEntryList.add(mMockBatteryEntry2);
|
||||
batteryEntryList.add(mMockBatteryEntry3);
|
||||
batteryEntryList.add(mMockBatteryEntry4);
|
||||
doReturn(0.0).when(mMockBatteryEntry1).getConsumedPower();
|
||||
doReturn(30L).when(mMockBatteryEntry1).getTimeInForegroundMs();
|
||||
doReturn(40L).when(mMockBatteryEntry1).getTimeInBackgroundMs();
|
||||
doReturn(1).when(mMockBatteryEntry1).getUid();
|
||||
doReturn(ConvertUtils.CONSUMER_TYPE_UID_BATTERY).when(mMockBatteryEntry1).getConsumerType();
|
||||
doReturn(0.5).when(mMockBatteryEntry2).getConsumedPower();
|
||||
doReturn(20L).when(mMockBatteryEntry2).getTimeInForegroundMs();
|
||||
doReturn(20L).when(mMockBatteryEntry2).getTimeInBackgroundMs();
|
||||
doReturn(2).when(mMockBatteryEntry2).getUid();
|
||||
doReturn(ConvertUtils.CONSUMER_TYPE_UID_BATTERY).when(mMockBatteryEntry2).getConsumerType();
|
||||
doReturn(0.0).when(mMockBatteryEntry3).getConsumedPower();
|
||||
doReturn(0L).when(mMockBatteryEntry3).getTimeInForegroundMs();
|
||||
doReturn(0L).when(mMockBatteryEntry3).getTimeInBackgroundMs();
|
||||
doReturn(3).when(mMockBatteryEntry3).getUid();
|
||||
doReturn(ConvertUtils.CONSUMER_TYPE_UID_BATTERY).when(mMockBatteryEntry3).getConsumerType();
|
||||
doReturn(1.5).when(mMockBatteryEntry4).getConsumedPower();
|
||||
doReturn(10L).when(mMockBatteryEntry4).getTimeInForegroundMs();
|
||||
doReturn(10L).when(mMockBatteryEntry4).getTimeInBackgroundMs();
|
||||
doReturn(4).when(mMockBatteryEntry4).getUid();
|
||||
doReturn(ConvertUtils.CONSUMER_TYPE_SYSTEM_BATTERY)
|
||||
.when(mMockBatteryEntry4).getConsumerType();
|
||||
doReturn(BatteryConsumer.POWER_COMPONENT_CAMERA)
|
||||
.when(mMockBatteryEntry4).getPowerComponentId();
|
||||
|
||||
final BatteryDiffData batteryDiffData = DataProcessor.generateBatteryDiffData(
|
||||
mContext, batteryEntryList, mBatteryUsageStats);
|
||||
|
||||
assertBatteryDiffEntry(
|
||||
batteryDiffData.getAppDiffEntryList().get(0), 0, /*uid=*/ 2L,
|
||||
ConvertUtils.CONSUMER_TYPE_UID_BATTERY, /*consumePercentage=*/ 25.0,
|
||||
/*foregroundUsageTimeInMs=*/ 20, /*backgroundUsageTimeInMs=*/ 20);
|
||||
assertBatteryDiffEntry(
|
||||
batteryDiffData.getAppDiffEntryList().get(1), 0, /*uid=*/ 1L,
|
||||
ConvertUtils.CONSUMER_TYPE_UID_BATTERY, /*consumePercentage=*/ 0.0,
|
||||
/*foregroundUsageTimeInMs=*/ 30, /*backgroundUsageTimeInMs=*/ 40);
|
||||
assertBatteryDiffEntry(
|
||||
batteryDiffData.getSystemDiffEntryList().get(0), 0, /*uid=*/ 4L,
|
||||
ConvertUtils.CONSUMER_TYPE_SYSTEM_BATTERY, /*consumePercentage=*/ 75.0,
|
||||
/*foregroundUsageTimeInMs=*/ 10, /*backgroundUsageTimeInMs=*/ 10);
|
||||
}
|
||||
|
||||
private static Map<Long, Map<String, BatteryHistEntry>> createHistoryMap(
|
||||
final long[] timestamps, final int[] levels) {
|
||||
final Map<Long, Map<String, BatteryHistEntry>> batteryHistoryMap = new HashMap<>();
|
||||
|
Reference in New Issue
Block a user