Begin transition from BatteryStatsHelper to BatteryUsageStats API.
For now, keep both BatteryStatsHelper and BatteryUsageStats in play. The plan is to transition from the former to the latter, one usage at a time. When all is said and done, all references to BatteryStatsHelper will be gone. Bug: 173745486 Test: atest --host SettingsRoboTests Change-Id: I37e1dfff0043b1845992f18d72067bb547bb69ff
This commit is contained in:
@@ -19,9 +19,12 @@ package com.android.settings.applications.appinfo;
|
|||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.content.pm.PackageInfo;
|
import android.content.pm.PackageInfo;
|
||||||
import android.os.BatteryStats;
|
import android.os.BatteryStats;
|
||||||
|
import android.os.BatteryUsageStats;
|
||||||
import android.os.Bundle;
|
import android.os.Bundle;
|
||||||
|
import android.os.UidBatteryConsumer;
|
||||||
import android.os.UserManager;
|
import android.os.UserManager;
|
||||||
|
|
||||||
|
import androidx.annotation.NonNull;
|
||||||
import androidx.annotation.VisibleForTesting;
|
import androidx.annotation.VisibleForTesting;
|
||||||
import androidx.loader.app.LoaderManager;
|
import androidx.loader.app.LoaderManager;
|
||||||
import androidx.loader.content.Loader;
|
import androidx.loader.content.Loader;
|
||||||
@@ -36,6 +39,7 @@ import com.android.settings.core.BasePreferenceController;
|
|||||||
import com.android.settings.fuelgauge.AdvancedPowerUsageDetail;
|
import com.android.settings.fuelgauge.AdvancedPowerUsageDetail;
|
||||||
import com.android.settings.fuelgauge.BatteryEntry;
|
import com.android.settings.fuelgauge.BatteryEntry;
|
||||||
import com.android.settings.fuelgauge.BatteryStatsHelperLoader;
|
import com.android.settings.fuelgauge.BatteryStatsHelperLoader;
|
||||||
|
import com.android.settings.fuelgauge.BatteryUsageStatsLoader;
|
||||||
import com.android.settings.fuelgauge.BatteryUtils;
|
import com.android.settings.fuelgauge.BatteryUtils;
|
||||||
import com.android.settingslib.core.lifecycle.Lifecycle;
|
import com.android.settingslib.core.lifecycle.Lifecycle;
|
||||||
import com.android.settingslib.core.lifecycle.LifecycleObserver;
|
import com.android.settingslib.core.lifecycle.LifecycleObserver;
|
||||||
@@ -46,11 +50,19 @@ import java.util.ArrayList;
|
|||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
public class AppBatteryPreferenceController extends BasePreferenceController
|
public class AppBatteryPreferenceController extends BasePreferenceController
|
||||||
implements LoaderManager.LoaderCallbacks<BatteryStatsHelper>,
|
implements LifecycleObserver, OnResume, OnPause {
|
||||||
LifecycleObserver, OnResume, OnPause {
|
|
||||||
|
|
||||||
private static final String KEY_BATTERY = "battery";
|
private static final String KEY_BATTERY = "battery";
|
||||||
|
|
||||||
|
// TODO(b/180630447): switch to BatteryUsageStatsLoader and remove all references to
|
||||||
|
// BatteryStatsHelper and BatterySipper
|
||||||
|
@VisibleForTesting
|
||||||
|
final BatteryStatsHelperLoaderCallbacks mBatteryStatsHelperLoaderCallbacks =
|
||||||
|
new BatteryStatsHelperLoaderCallbacks();
|
||||||
|
@VisibleForTesting
|
||||||
|
final BatteryUsageStatsLoaderCallbacks mBatteryUsageStatsLoaderCallbacks =
|
||||||
|
new BatteryUsageStatsLoaderCallbacks();
|
||||||
|
|
||||||
@VisibleForTesting
|
@VisibleForTesting
|
||||||
BatterySipper mSipper;
|
BatterySipper mSipper;
|
||||||
@VisibleForTesting
|
@VisibleForTesting
|
||||||
@@ -58,6 +70,11 @@ public class AppBatteryPreferenceController extends BasePreferenceController
|
|||||||
@VisibleForTesting
|
@VisibleForTesting
|
||||||
BatteryUtils mBatteryUtils;
|
BatteryUtils mBatteryUtils;
|
||||||
|
|
||||||
|
@VisibleForTesting
|
||||||
|
BatteryUsageStats mBatteryUsageStats;
|
||||||
|
@VisibleForTesting
|
||||||
|
UidBatteryConsumer mUidBatteryConsumer;
|
||||||
|
|
||||||
private Preference mPreference;
|
private Preference mPreference;
|
||||||
private final AppInfoDashboardFragment mParent;
|
private final AppInfoDashboardFragment mParent;
|
||||||
private String mBatteryPercent;
|
private String mBatteryPercent;
|
||||||
@@ -96,7 +113,8 @@ public class AppBatteryPreferenceController extends BasePreferenceController
|
|||||||
if (isBatteryStatsAvailable()) {
|
if (isBatteryStatsAvailable()) {
|
||||||
final UserManager userManager =
|
final UserManager userManager =
|
||||||
(UserManager) mContext.getSystemService(Context.USER_SERVICE);
|
(UserManager) mContext.getSystemService(Context.USER_SERVICE);
|
||||||
final BatteryEntry entry = new BatteryEntry(mContext, null, userManager, mSipper);
|
final BatteryEntry entry = new BatteryEntry(mContext, null, userManager, mSipper,
|
||||||
|
mUidBatteryConsumer);
|
||||||
entry.defaultPackageName = mPackageName;
|
entry.defaultPackageName = mPackageName;
|
||||||
AdvancedPowerUsageDetail.startBatteryDetailPage(mParent.getActivity(), mParent,
|
AdvancedPowerUsageDetail.startBatteryDetailPage(mParent.getActivity(), mParent,
|
||||||
mBatteryHelper, BatteryStats.STATS_SINCE_CHARGED, entry, mBatteryPercent);
|
mBatteryHelper, BatteryStats.STATS_SINCE_CHARGED, entry, mBatteryPercent);
|
||||||
@@ -110,48 +128,48 @@ public class AppBatteryPreferenceController extends BasePreferenceController
|
|||||||
@Override
|
@Override
|
||||||
public void onResume() {
|
public void onResume() {
|
||||||
mParent.getLoaderManager().restartLoader(
|
mParent.getLoaderManager().restartLoader(
|
||||||
mParent.LOADER_BATTERY, Bundle.EMPTY, this);
|
AppInfoDashboardFragment.LOADER_BATTERY, Bundle.EMPTY,
|
||||||
|
mBatteryStatsHelperLoaderCallbacks);
|
||||||
|
mParent.getLoaderManager().restartLoader(
|
||||||
|
AppInfoDashboardFragment.LOADER_BATTERY_USAGE_STATS, Bundle.EMPTY,
|
||||||
|
mBatteryUsageStatsLoaderCallbacks);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onPause() {
|
public void onPause() {
|
||||||
mParent.getLoaderManager().destroyLoader(mParent.LOADER_BATTERY);
|
mParent.getLoaderManager().destroyLoader(AppInfoDashboardFragment.LOADER_BATTERY);
|
||||||
|
mParent.getLoaderManager().destroyLoader(
|
||||||
|
AppInfoDashboardFragment.LOADER_BATTERY_USAGE_STATS);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
private void onLoadFinished() {
|
||||||
public Loader<BatteryStatsHelper> onCreateLoader(int id, Bundle args) {
|
// Wait for both loaders to finish before proceeding.
|
||||||
return new BatteryStatsHelperLoader(mContext);
|
if (mBatteryHelper == null || mBatteryUsageStats == null) {
|
||||||
}
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
|
||||||
public void onLoadFinished(Loader<BatteryStatsHelper> loader,
|
|
||||||
BatteryStatsHelper batteryHelper) {
|
|
||||||
mBatteryHelper = batteryHelper;
|
|
||||||
final PackageInfo packageInfo = mParent.getPackageInfo();
|
final PackageInfo packageInfo = mParent.getPackageInfo();
|
||||||
if (packageInfo != null) {
|
if (packageInfo != null) {
|
||||||
mSipper = findTargetSipper(batteryHelper, packageInfo.applicationInfo.uid);
|
mSipper = findTargetSipper(mBatteryHelper, packageInfo.applicationInfo.uid);
|
||||||
|
mUidBatteryConsumer = findTargetUidBatteryConsumer(mBatteryUsageStats,
|
||||||
|
packageInfo.applicationInfo.uid);
|
||||||
if (mParent.getActivity() != null) {
|
if (mParent.getActivity() != null) {
|
||||||
updateBattery();
|
updateBattery();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
|
||||||
public void onLoaderReset(Loader<BatteryStatsHelper> loader) {
|
|
||||||
}
|
|
||||||
|
|
||||||
@VisibleForTesting
|
@VisibleForTesting
|
||||||
void updateBattery() {
|
void updateBattery() {
|
||||||
mPreference.setEnabled(true);
|
mPreference.setEnabled(true);
|
||||||
if (isBatteryStatsAvailable()) {
|
if (isBatteryStatsAvailable()) {
|
||||||
final int dischargeAmount = mBatteryHelper.getStats().getDischargeAmount(
|
final int dischargePercentage = mBatteryUsageStats.getDischargePercentage();
|
||||||
BatteryStats.STATS_SINCE_CHARGED);
|
|
||||||
|
|
||||||
final List<BatterySipper> usageList = new ArrayList<>(mBatteryHelper.getUsageList());
|
final List<BatterySipper> usageList = new ArrayList<>(mBatteryHelper.getUsageList());
|
||||||
final double hiddenAmount = mBatteryUtils.removeHiddenBatterySippers(usageList);
|
final double hiddenAmount = mBatteryUtils.removeHiddenBatterySippers(usageList);
|
||||||
final int percentOfMax = (int) mBatteryUtils.calculateBatteryPercent(
|
final int percentOfMax = (int) mBatteryUtils.calculateBatteryPercent(
|
||||||
mSipper.totalPowerMah, mBatteryHelper.getTotalPower(), hiddenAmount,
|
mUidBatteryConsumer.getConsumedPower(), mBatteryUsageStats.getConsumedPower(),
|
||||||
dischargeAmount);
|
hiddenAmount, dischargePercentage);
|
||||||
mBatteryPercent = Utils.formatPercentage(percentOfMax);
|
mBatteryPercent = Utils.formatPercentage(percentOfMax);
|
||||||
mPreference.setSummary(mContext.getString(R.string.battery_summary, mBatteryPercent));
|
mPreference.setSummary(mContext.getString(R.string.battery_summary, mBatteryPercent));
|
||||||
} else {
|
} else {
|
||||||
@@ -161,7 +179,7 @@ public class AppBatteryPreferenceController extends BasePreferenceController
|
|||||||
|
|
||||||
@VisibleForTesting
|
@VisibleForTesting
|
||||||
boolean isBatteryStatsAvailable() {
|
boolean isBatteryStatsAvailable() {
|
||||||
return mBatteryHelper != null && mSipper != null;
|
return mBatteryHelper != null && mSipper != null && mUidBatteryConsumer != null;
|
||||||
}
|
}
|
||||||
|
|
||||||
@VisibleForTesting
|
@VisibleForTesting
|
||||||
@@ -176,4 +194,54 @@ public class AppBatteryPreferenceController extends BasePreferenceController
|
|||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@VisibleForTesting
|
||||||
|
UidBatteryConsumer findTargetUidBatteryConsumer(BatteryUsageStats batteryUsageStats, int uid) {
|
||||||
|
final List<UidBatteryConsumer> usageList = batteryUsageStats.getUidBatteryConsumers();
|
||||||
|
for (int i = 0, size = usageList.size(); i < size; i++) {
|
||||||
|
final UidBatteryConsumer consumer = usageList.get(i);
|
||||||
|
if (consumer.getUid() == uid) {
|
||||||
|
return consumer;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
private class BatteryStatsHelperLoaderCallbacks
|
||||||
|
implements LoaderManager.LoaderCallbacks<BatteryStatsHelper> {
|
||||||
|
@Override
|
||||||
|
public Loader<BatteryStatsHelper> onCreateLoader(int id, Bundle args) {
|
||||||
|
return new BatteryStatsHelperLoader(mContext);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onLoadFinished(Loader<BatteryStatsHelper> loader,
|
||||||
|
BatteryStatsHelper batteryHelper) {
|
||||||
|
mBatteryHelper = batteryHelper;
|
||||||
|
AppBatteryPreferenceController.this.onLoadFinished();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onLoaderReset(Loader<BatteryStatsHelper> loader) {
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private class BatteryUsageStatsLoaderCallbacks
|
||||||
|
implements LoaderManager.LoaderCallbacks<BatteryUsageStats> {
|
||||||
|
@Override
|
||||||
|
@NonNull
|
||||||
|
public Loader<BatteryUsageStats> onCreateLoader(int id, Bundle args) {
|
||||||
|
return new BatteryUsageStatsLoader(mContext);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onLoadFinished(Loader<BatteryUsageStats> loader,
|
||||||
|
BatteryUsageStats batteryUsageStats) {
|
||||||
|
mBatteryUsageStats = batteryUsageStats;
|
||||||
|
AppBatteryPreferenceController.this.onLoadFinished();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onLoaderReset(Loader<BatteryUsageStats> loader) {
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@@ -95,6 +95,7 @@ public class AppInfoDashboardFragment extends DashboardFragment
|
|||||||
static final int LOADER_CHART_DATA = 2;
|
static final int LOADER_CHART_DATA = 2;
|
||||||
static final int LOADER_STORAGE = 3;
|
static final int LOADER_STORAGE = 3;
|
||||||
static final int LOADER_BATTERY = 4;
|
static final int LOADER_BATTERY = 4;
|
||||||
|
static final int LOADER_BATTERY_USAGE_STATS = 5;
|
||||||
|
|
||||||
public static final String ARG_PACKAGE_NAME = "package";
|
public static final String ARG_PACKAGE_NAME = "package";
|
||||||
public static final String ARG_PACKAGE_UID = "uid";
|
public static final String ARG_PACKAGE_UID = "uid";
|
||||||
|
@@ -208,7 +208,7 @@ public class BatteryAppListPreferenceController extends AbstractPreferenceContro
|
|||||||
}
|
}
|
||||||
final UserHandle userHandle = new UserHandle(UserHandle.getUserId(sipper.getUid()));
|
final UserHandle userHandle = new UserHandle(UserHandle.getUserId(sipper.getUid()));
|
||||||
final BatteryEntry entry = new BatteryEntry(mActivity, mHandler, mUserManager,
|
final BatteryEntry entry = new BatteryEntry(mActivity, mHandler, mUserManager,
|
||||||
sipper);
|
sipper, null);
|
||||||
final Drawable badgedIcon = mUserManager.getBadgedIconForUser(entry.getIcon(),
|
final Drawable badgedIcon = mUserManager.getBadgedIconForUser(entry.getIcon(),
|
||||||
userHandle);
|
userHandle);
|
||||||
final CharSequence contentDescription = mUserManager.getBadgedLabelForUser(
|
final CharSequence contentDescription = mUserManager.getBadgedLabelForUser(
|
||||||
|
@@ -28,6 +28,7 @@ import android.graphics.drawable.Drawable;
|
|||||||
import android.os.Handler;
|
import android.os.Handler;
|
||||||
import android.os.Process;
|
import android.os.Process;
|
||||||
import android.os.RemoteException;
|
import android.os.RemoteException;
|
||||||
|
import android.os.UidBatteryConsumer;
|
||||||
import android.os.UserHandle;
|
import android.os.UserHandle;
|
||||||
import android.os.UserManager;
|
import android.os.UserManager;
|
||||||
import android.util.Log;
|
import android.util.Log;
|
||||||
@@ -122,6 +123,7 @@ public class BatteryEntry {
|
|||||||
|
|
||||||
public final Context context;
|
public final Context context;
|
||||||
public final BatterySipper sipper;
|
public final BatterySipper sipper;
|
||||||
|
public final UidBatteryConsumer uidBatteryConsumer;
|
||||||
|
|
||||||
public String name;
|
public String name;
|
||||||
public Drawable icon;
|
public Drawable icon;
|
||||||
@@ -134,10 +136,41 @@ public class BatteryEntry {
|
|||||||
Drawable icon;
|
Drawable icon;
|
||||||
}
|
}
|
||||||
|
|
||||||
public BatteryEntry(Context context, Handler handler, UserManager um, BatterySipper sipper) {
|
public BatteryEntry(Context context, Handler handler, UserManager um, BatterySipper sipper,
|
||||||
|
UidBatteryConsumer uidBatteryConsumer) {
|
||||||
sHandler = handler;
|
sHandler = handler;
|
||||||
this.context = context;
|
this.context = context;
|
||||||
this.sipper = sipper;
|
this.sipper = sipper;
|
||||||
|
this.uidBatteryConsumer = uidBatteryConsumer;
|
||||||
|
|
||||||
|
// This condition is met when BatteryEntry is initialized from BatteryUsageStats.
|
||||||
|
// Once the conversion from BatteryStatsHelper is completed, the condition will
|
||||||
|
// always be true and can be removed.
|
||||||
|
if (uidBatteryConsumer != null) {
|
||||||
|
PackageManager pm = context.getPackageManager();
|
||||||
|
int uid = uidBatteryConsumer.getUid();
|
||||||
|
String[] packages = pm.getPackagesForUid(uid);
|
||||||
|
// Apps should only have one package
|
||||||
|
if (packages == null || packages.length != 1) {
|
||||||
|
name = uidBatteryConsumer.getPackageWithHighestDrain();
|
||||||
|
} else {
|
||||||
|
defaultPackageName = packages[0];
|
||||||
|
try {
|
||||||
|
ApplicationInfo appInfo =
|
||||||
|
pm.getApplicationInfo(defaultPackageName, 0 /* no flags */);
|
||||||
|
name = pm.getApplicationLabel(appInfo).toString();
|
||||||
|
} catch (NameNotFoundException e) {
|
||||||
|
Log.d(TAG, "PackageManager failed to retrieve ApplicationInfo for: "
|
||||||
|
+ defaultPackageName);
|
||||||
|
name = defaultPackageName;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if ((name == null || iconId == 0) && uid != 0) {
|
||||||
|
getQuickNameIconForUid(uid);
|
||||||
|
}
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
switch (sipper.drainType) {
|
switch (sipper.drainType) {
|
||||||
case IDLE:
|
case IDLE:
|
||||||
name = context.getResources().getString(R.string.power_idle);
|
name = context.getResources().getString(R.string.power_idle);
|
||||||
|
@@ -0,0 +1,44 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (C) 2020 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.fuelgauge;
|
||||||
|
|
||||||
|
import android.content.Context;
|
||||||
|
import android.os.BatteryStatsManager;
|
||||||
|
import android.os.BatteryUsageStats;
|
||||||
|
|
||||||
|
import com.android.settingslib.utils.AsyncLoaderCompat;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Loader to get new {@link BatteryUsageStats} in the background
|
||||||
|
*/
|
||||||
|
public class BatteryUsageStatsLoader extends AsyncLoaderCompat<BatteryUsageStats> {
|
||||||
|
private final BatteryStatsManager mBatteryStatsManager;
|
||||||
|
|
||||||
|
public BatteryUsageStatsLoader(Context context) {
|
||||||
|
super(context);
|
||||||
|
mBatteryStatsManager = context.getSystemService(BatteryStatsManager.class);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public BatteryUsageStats loadInBackground() {
|
||||||
|
return mBatteryStatsManager.getBatteryUsageStats();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected void onDiscardResult(BatteryUsageStats result) {
|
||||||
|
}
|
||||||
|
}
|
@@ -31,7 +31,9 @@ import android.content.Context;
|
|||||||
import android.content.pm.PackageManager;
|
import android.content.pm.PackageManager;
|
||||||
import android.content.pm.PackageManager.NameNotFoundException;
|
import android.content.pm.PackageManager.NameNotFoundException;
|
||||||
import android.os.BatteryStats;
|
import android.os.BatteryStats;
|
||||||
|
import android.os.BatteryUsageStats;
|
||||||
import android.os.Bundle;
|
import android.os.Bundle;
|
||||||
|
import android.os.UidBatteryConsumer;
|
||||||
|
|
||||||
import androidx.loader.app.LoaderManager;
|
import androidx.loader.app.LoaderManager;
|
||||||
import androidx.preference.Preference;
|
import androidx.preference.Preference;
|
||||||
@@ -67,6 +69,10 @@ public class AppBatteryPreferenceControllerTest {
|
|||||||
@Mock
|
@Mock
|
||||||
private BatteryUtils mBatteryUtils;
|
private BatteryUtils mBatteryUtils;
|
||||||
@Mock
|
@Mock
|
||||||
|
private BatteryUsageStats mBatteryUsageStats;
|
||||||
|
@Mock
|
||||||
|
private UidBatteryConsumer mUidBatteryConsumer;
|
||||||
|
@Mock
|
||||||
private BatterySipper mBatterySipper;
|
private BatterySipper mBatterySipper;
|
||||||
@Mock
|
@Mock
|
||||||
private BatterySipper mOtherBatterySipper;
|
private BatterySipper mOtherBatterySipper;
|
||||||
@@ -143,6 +149,8 @@ public class AppBatteryPreferenceControllerTest {
|
|||||||
public void updateBattery_hasBatteryStats_summaryPercent() {
|
public void updateBattery_hasBatteryStats_summaryPercent() {
|
||||||
mController.mBatteryHelper = mBatteryStatsHelper;
|
mController.mBatteryHelper = mBatteryStatsHelper;
|
||||||
mController.mSipper = mBatterySipper;
|
mController.mSipper = mBatterySipper;
|
||||||
|
mController.mBatteryUsageStats = mBatteryUsageStats;
|
||||||
|
mController.mUidBatteryConsumer = mUidBatteryConsumer;
|
||||||
doReturn(BATTERY_LEVEL).when(mBatteryUtils).calculateBatteryPercent(anyDouble(),
|
doReturn(BATTERY_LEVEL).when(mBatteryUtils).calculateBatteryPercent(anyDouble(),
|
||||||
anyDouble(), anyDouble(), anyInt());
|
anyDouble(), anyDouble(), anyInt());
|
||||||
doReturn(new ArrayList<>()).when(mBatteryStatsHelper).getUsageList();
|
doReturn(new ArrayList<>()).when(mBatteryStatsHelper).getUsageList();
|
||||||
@@ -157,6 +165,8 @@ public class AppBatteryPreferenceControllerTest {
|
|||||||
public void isBatteryStatsAvailable_hasBatteryStatsHelperAndSipper_returnTrue() {
|
public void isBatteryStatsAvailable_hasBatteryStatsHelperAndSipper_returnTrue() {
|
||||||
mController.mBatteryHelper = mBatteryStatsHelper;
|
mController.mBatteryHelper = mBatteryStatsHelper;
|
||||||
mController.mSipper = mBatterySipper;
|
mController.mSipper = mBatterySipper;
|
||||||
|
mController.mBatteryUsageStats = mBatteryUsageStats;
|
||||||
|
mController.mUidBatteryConsumer = mUidBatteryConsumer;
|
||||||
|
|
||||||
assertThat(mController.isBatteryStatsAvailable()).isTrue();
|
assertThat(mController.isBatteryStatsAvailable()).isTrue();
|
||||||
}
|
}
|
||||||
@@ -175,6 +185,8 @@ public class AppBatteryPreferenceControllerTest {
|
|||||||
when(mBatteryPreference.getKey()).thenReturn(key);
|
when(mBatteryPreference.getKey()).thenReturn(key);
|
||||||
mController.mSipper = mBatterySipper;
|
mController.mSipper = mBatterySipper;
|
||||||
mController.mBatteryHelper = mBatteryStatsHelper;
|
mController.mBatteryHelper = mBatteryStatsHelper;
|
||||||
|
mController.mBatteryUsageStats = mBatteryUsageStats;
|
||||||
|
mController.mUidBatteryConsumer = mUidBatteryConsumer;
|
||||||
|
|
||||||
// Should not crash
|
// Should not crash
|
||||||
mController.handlePreferenceTreeClick(mBatteryPreference);
|
mController.handlePreferenceTreeClick(mBatteryPreference);
|
||||||
@@ -187,7 +199,8 @@ public class AppBatteryPreferenceControllerTest {
|
|||||||
mController.onResume();
|
mController.onResume();
|
||||||
|
|
||||||
verify(mLoaderManager)
|
verify(mLoaderManager)
|
||||||
.restartLoader(AppInfoDashboardFragment.LOADER_BATTERY, Bundle.EMPTY, mController);
|
.restartLoader(AppInfoDashboardFragment.LOADER_BATTERY, Bundle.EMPTY,
|
||||||
|
mController.mBatteryStatsHelperLoaderCallbacks);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
|
@@ -79,7 +79,8 @@ public class BatteryEntryTest {
|
|||||||
}
|
}
|
||||||
|
|
||||||
private BatteryEntry createBatteryEntryForApp() {
|
private BatteryEntry createBatteryEntryForApp() {
|
||||||
return new BatteryEntry(mockContext, mockHandler, mockUserManager, createSipperForApp());
|
return new BatteryEntry(mockContext, mockHandler, mockUserManager, createSipperForApp(),
|
||||||
|
null);
|
||||||
}
|
}
|
||||||
|
|
||||||
private BatterySipper createSipperForApp() {
|
private BatterySipper createSipperForApp() {
|
||||||
@@ -90,7 +91,8 @@ public class BatteryEntryTest {
|
|||||||
}
|
}
|
||||||
|
|
||||||
private BatteryEntry createBatteryEntryForSystem() {
|
private BatteryEntry createBatteryEntryForSystem() {
|
||||||
return new BatteryEntry(mockContext, mockHandler, mockUserManager, createSipperForSystem());
|
return new BatteryEntry(mockContext, mockHandler, mockUserManager, createSipperForSystem(),
|
||||||
|
null);
|
||||||
}
|
}
|
||||||
|
|
||||||
private BatterySipper createSipperForSystem() {
|
private BatterySipper createSipperForSystem() {
|
||||||
@@ -144,7 +146,7 @@ public class BatteryEntryTest {
|
|||||||
final BatterySipper batterySipper = mock(BatterySipper.class);
|
final BatterySipper batterySipper = mock(BatterySipper.class);
|
||||||
batterySipper.drainType = DrainType.AMBIENT_DISPLAY;
|
batterySipper.drainType = DrainType.AMBIENT_DISPLAY;
|
||||||
final BatteryEntry entry = new BatteryEntry(RuntimeEnvironment.application, mockHandler,
|
final BatteryEntry entry = new BatteryEntry(RuntimeEnvironment.application, mockHandler,
|
||||||
mockUserManager, batterySipper);
|
mockUserManager, batterySipper, null);
|
||||||
|
|
||||||
assertThat(entry.iconId).isEqualTo(R.drawable.ic_settings_aod);
|
assertThat(entry.iconId).isEqualTo(R.drawable.ic_settings_aod);
|
||||||
assertThat(entry.name).isEqualTo("Ambient display");
|
assertThat(entry.name).isEqualTo("Ambient display");
|
||||||
|
Reference in New Issue
Block a user