Encapsulate BatterySipper and BatteryConsumer in BatteryEntry
Bug: 173745486 Test: make RunSettingsRoboTests ROBOTEST_FILTER=com.android.settings.fuelgauge.BatteryEntryTest Test: make RunSettingsRoboTests ROBOTEST_FILTER=com.android.settings.fuelgauge.AdvancedPowerUsageDetailTest Change-Id: I67ab825c25b85012b5713736db62e0beb4d98a16
This commit is contained in:
@@ -114,8 +114,7 @@ public class AppBatteryPreferenceController extends BasePreferenceController
|
|||||||
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);
|
mUidBatteryConsumer, 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);
|
||||||
} else {
|
} else {
|
||||||
|
@@ -23,7 +23,6 @@ import android.app.settings.SettingsEnums;
|
|||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.content.Intent;
|
import android.content.Intent;
|
||||||
import android.content.pm.PackageManager;
|
import android.content.pm.PackageManager;
|
||||||
import android.os.BatteryStats;
|
|
||||||
import android.os.Bundle;
|
import android.os.Bundle;
|
||||||
import android.os.UserHandle;
|
import android.os.UserHandle;
|
||||||
import android.text.TextUtils;
|
import android.text.TextUtils;
|
||||||
@@ -33,9 +32,7 @@ import android.view.View;
|
|||||||
import androidx.annotation.VisibleForTesting;
|
import androidx.annotation.VisibleForTesting;
|
||||||
import androidx.preference.Preference;
|
import androidx.preference.Preference;
|
||||||
|
|
||||||
import com.android.internal.os.BatterySipper;
|
|
||||||
import com.android.internal.os.BatteryStatsHelper;
|
import com.android.internal.os.BatteryStatsHelper;
|
||||||
import com.android.internal.util.ArrayUtils;
|
|
||||||
import com.android.settings.R;
|
import com.android.settings.R;
|
||||||
import com.android.settings.SettingsActivity;
|
import com.android.settings.SettingsActivity;
|
||||||
import com.android.settings.Utils;
|
import com.android.settings.Utils;
|
||||||
@@ -109,48 +106,40 @@ public class AdvancedPowerUsageDetail extends DashboardFragment implements
|
|||||||
helper.getStats();
|
helper.getStats();
|
||||||
|
|
||||||
final Bundle args = new Bundle();
|
final Bundle args = new Bundle();
|
||||||
final BatterySipper sipper = entry.sipper;
|
final long foregroundTimeMs = entry.getTimeInForegroundMs(batteryUtils);
|
||||||
final BatteryStats.Uid uid = sipper.uidObj;
|
final long backgroundTimeMs = entry.getTimeInBackgroundMs(batteryUtils);
|
||||||
final boolean isTypeApp = sipper.drainType == BatterySipper.DrainType.APP;
|
final String packageName = entry.getDefaultPackageName();
|
||||||
|
if (packageName == null) {
|
||||||
final long foregroundTimeMs = isTypeApp ? batteryUtils.getProcessTimeMs(
|
|
||||||
BatteryUtils.StatusType.FOREGROUND, uid, which) : sipper.usageTimeMs;
|
|
||||||
final long backgroundTimeMs = isTypeApp ? batteryUtils.getProcessTimeMs(
|
|
||||||
BatteryUtils.StatusType.BACKGROUND, uid, which) : 0;
|
|
||||||
|
|
||||||
if (ArrayUtils.isEmpty(sipper.mPackages)) {
|
|
||||||
// populate data for system app
|
// populate data for system app
|
||||||
args.putString(EXTRA_LABEL, entry.getLabel());
|
args.putString(EXTRA_LABEL, entry.getLabel());
|
||||||
args.putInt(EXTRA_ICON_ID, entry.iconId);
|
args.putInt(EXTRA_ICON_ID, entry.iconId);
|
||||||
args.putString(EXTRA_PACKAGE_NAME, null);
|
args.putString(EXTRA_PACKAGE_NAME, null);
|
||||||
} else {
|
} else {
|
||||||
// populate data for normal app
|
// populate data for normal app
|
||||||
args.putString(EXTRA_PACKAGE_NAME, entry.defaultPackageName != null
|
args.putString(EXTRA_PACKAGE_NAME, packageName);
|
||||||
? entry.defaultPackageName
|
|
||||||
: sipper.mPackages[0]);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
args.putInt(EXTRA_UID, sipper.getUid());
|
args.putInt(EXTRA_UID, entry.getUid());
|
||||||
args.putLong(EXTRA_BACKGROUND_TIME, backgroundTimeMs);
|
args.putLong(EXTRA_BACKGROUND_TIME, backgroundTimeMs);
|
||||||
args.putLong(EXTRA_FOREGROUND_TIME, foregroundTimeMs);
|
args.putLong(EXTRA_FOREGROUND_TIME, foregroundTimeMs);
|
||||||
args.putString(EXTRA_POWER_USAGE_PERCENT, usagePercent);
|
args.putString(EXTRA_POWER_USAGE_PERCENT, usagePercent);
|
||||||
args.putInt(EXTRA_POWER_USAGE_AMOUNT, (int) sipper.totalPowerMah);
|
args.putInt(EXTRA_POWER_USAGE_AMOUNT, (int) entry.getConsumedPower());
|
||||||
|
|
||||||
new SubSettingLauncher(caller)
|
new SubSettingLauncher(caller)
|
||||||
.setDestination(AdvancedPowerUsageDetail.class.getName())
|
.setDestination(AdvancedPowerUsageDetail.class.getName())
|
||||||
.setTitleRes(R.string.battery_details_title)
|
.setTitleRes(R.string.battery_details_title)
|
||||||
.setArguments(args)
|
.setArguments(args)
|
||||||
.setSourceMetricsCategory(fragment.getMetricsCategory())
|
.setSourceMetricsCategory(fragment.getMetricsCategory())
|
||||||
.setUserHandle(new UserHandle(getUserIdToLaunchAdvancePowerUsageDetail(sipper)))
|
.setUserHandle(new UserHandle(getUserIdToLaunchAdvancePowerUsageDetail(entry)))
|
||||||
.launch();
|
.launch();
|
||||||
}
|
}
|
||||||
|
|
||||||
private static @UserIdInt
|
private static @UserIdInt int getUserIdToLaunchAdvancePowerUsageDetail(
|
||||||
int getUserIdToLaunchAdvancePowerUsageDetail(BatterySipper bs) {
|
BatteryEntry batteryEntry) {
|
||||||
if (bs.drainType == BatterySipper.DrainType.USER) {
|
if (batteryEntry.isUserEntry()) {
|
||||||
return ActivityManager.getCurrentUser();
|
return ActivityManager.getCurrentUser();
|
||||||
}
|
}
|
||||||
return UserHandle.getUserId(bs.getUid());
|
return UserHandle.getUserId(batteryEntry.getUid());
|
||||||
}
|
}
|
||||||
|
|
||||||
public static void startBatteryDetailPage(Activity caller,
|
public static void startBatteryDetailPage(Activity caller,
|
||||||
|
@@ -85,15 +85,16 @@ public class BatteryAppListPreferenceController extends AbstractPreferenceContro
|
|||||||
switch (msg.what) {
|
switch (msg.what) {
|
||||||
case BatteryEntry.MSG_UPDATE_NAME_ICON:
|
case BatteryEntry.MSG_UPDATE_NAME_ICON:
|
||||||
BatteryEntry entry = (BatteryEntry) msg.obj;
|
BatteryEntry entry = (BatteryEntry) msg.obj;
|
||||||
|
int uid = entry.getUid();
|
||||||
PowerGaugePreference pgp =
|
PowerGaugePreference pgp =
|
||||||
(PowerGaugePreference) mAppListGroup.findPreference(
|
(PowerGaugePreference) mAppListGroup.findPreference(
|
||||||
Integer.toString(entry.sipper.uidObj.getUid()));
|
Integer.toString(uid));
|
||||||
if (pgp != null) {
|
if (pgp != null) {
|
||||||
final int userId = UserHandle.getUserId(entry.sipper.getUid());
|
final int userId = UserHandle.getUserId(uid);
|
||||||
final UserHandle userHandle = new UserHandle(userId);
|
final UserHandle userHandle = new UserHandle(userId);
|
||||||
pgp.setIcon(mUserManager.getBadgedIconForUser(entry.getIcon(), userHandle));
|
pgp.setIcon(mUserManager.getBadgedIconForUser(entry.getIcon(), userHandle));
|
||||||
pgp.setTitle(entry.name);
|
pgp.setTitle(entry.name);
|
||||||
if (entry.sipper.drainType == DrainType.APP) {
|
if (entry.isAppEntry()) {
|
||||||
pgp.setContentDescription(entry.name);
|
pgp.setContentDescription(entry.name);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -208,7 +209,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, null);
|
sipper, null, 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(
|
||||||
|
@@ -25,15 +25,19 @@ import android.content.pm.PackageManager;
|
|||||||
import android.content.pm.PackageManager.NameNotFoundException;
|
import android.content.pm.PackageManager.NameNotFoundException;
|
||||||
import android.content.pm.UserInfo;
|
import android.content.pm.UserInfo;
|
||||||
import android.graphics.drawable.Drawable;
|
import android.graphics.drawable.Drawable;
|
||||||
|
import android.os.BatteryConsumer;
|
||||||
|
import android.os.BatteryStats;
|
||||||
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.UidBatteryConsumer;
|
||||||
|
import android.os.UserBatteryConsumer;
|
||||||
import android.os.UserHandle;
|
import android.os.UserHandle;
|
||||||
import android.os.UserManager;
|
import android.os.UserManager;
|
||||||
import android.util.Log;
|
import android.util.Log;
|
||||||
|
|
||||||
import com.android.internal.os.BatterySipper;
|
import com.android.internal.os.BatterySipper;
|
||||||
|
import com.android.internal.util.ArrayUtils;
|
||||||
import com.android.settings.R;
|
import com.android.settings.R;
|
||||||
import com.android.settingslib.Utils;
|
import com.android.settingslib.Utils;
|
||||||
|
|
||||||
@@ -122,13 +126,13 @@ public class BatteryEntry {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public final Context context;
|
public final Context context;
|
||||||
public final BatterySipper sipper;
|
private final BatterySipper mSipper;
|
||||||
public final UidBatteryConsumer uidBatteryConsumer;
|
private final BatteryConsumer mBatteryConsumer;
|
||||||
|
|
||||||
public String name;
|
public String name;
|
||||||
public Drawable icon;
|
public Drawable icon;
|
||||||
public int iconId; // For passing to the detail screen.
|
public int iconId; // For passing to the detail screen.
|
||||||
public String defaultPackageName;
|
private String mDefaultPackageName;
|
||||||
|
|
||||||
static class UidToDetail {
|
static class UidToDetail {
|
||||||
String name;
|
String name;
|
||||||
@@ -137,37 +141,38 @@ public class BatteryEntry {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public BatteryEntry(Context context, Handler handler, UserManager um, BatterySipper sipper,
|
public BatteryEntry(Context context, Handler handler, UserManager um, BatterySipper sipper,
|
||||||
UidBatteryConsumer uidBatteryConsumer) {
|
BatteryConsumer batteryConsumer, String packageName) {
|
||||||
sHandler = handler;
|
sHandler = handler;
|
||||||
this.context = context;
|
this.context = context;
|
||||||
this.sipper = sipper;
|
this.mSipper = sipper;
|
||||||
this.uidBatteryConsumer = uidBatteryConsumer;
|
this.mBatteryConsumer = batteryConsumer;
|
||||||
|
this.mDefaultPackageName = packageName;
|
||||||
|
|
||||||
// This condition is met when BatteryEntry is initialized from BatteryUsageStats.
|
if (batteryConsumer instanceof UidBatteryConsumer) {
|
||||||
// Once the conversion from BatteryStatsHelper is completed, the condition will
|
UidBatteryConsumer uidBatteryConsumer = (UidBatteryConsumer) batteryConsumer;
|
||||||
// always be true and can be removed.
|
|
||||||
if (uidBatteryConsumer != null) {
|
|
||||||
PackageManager pm = context.getPackageManager();
|
|
||||||
int uid = uidBatteryConsumer.getUid();
|
int uid = uidBatteryConsumer.getUid();
|
||||||
String[] packages = pm.getPackagesForUid(uid);
|
PackageManager pm = context.getPackageManager();
|
||||||
// Apps should only have one package
|
if (mDefaultPackageName == null) {
|
||||||
if (packages == null || packages.length != 1) {
|
String[] packages = pm.getPackagesForUid(uid);
|
||||||
name = uidBatteryConsumer.getPackageWithHighestDrain();
|
// Apps should only have one package
|
||||||
} else {
|
if (packages != null && packages.length == 1) {
|
||||||
defaultPackageName = packages[0];
|
mDefaultPackageName = packages[0];
|
||||||
|
} else {
|
||||||
|
mDefaultPackageName = uidBatteryConsumer.getPackageWithHighestDrain();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (mDefaultPackageName != null) {
|
||||||
try {
|
try {
|
||||||
ApplicationInfo appInfo =
|
ApplicationInfo appInfo =
|
||||||
pm.getApplicationInfo(defaultPackageName, 0 /* no flags */);
|
pm.getApplicationInfo(mDefaultPackageName, 0 /* no flags */);
|
||||||
name = pm.getApplicationLabel(appInfo).toString();
|
name = pm.getApplicationLabel(appInfo).toString();
|
||||||
} catch (NameNotFoundException e) {
|
} catch (NameNotFoundException e) {
|
||||||
Log.d(TAG, "PackageManager failed to retrieve ApplicationInfo for: "
|
Log.d(TAG, "PackageManager failed to retrieve ApplicationInfo for: "
|
||||||
+ defaultPackageName);
|
+ mDefaultPackageName);
|
||||||
name = defaultPackageName;
|
name = mDefaultPackageName;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if ((name == null || iconId == 0) && uid != 0) {
|
getQuickNameIconForUid(uid);
|
||||||
getQuickNameIconForUid(uid);
|
|
||||||
}
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -207,15 +212,15 @@ public class BatteryEntry {
|
|||||||
if (sipper.mPackages == null || sipper.mPackages.length != 1) {
|
if (sipper.mPackages == null || sipper.mPackages.length != 1) {
|
||||||
name = sipper.packageWithHighestDrain;
|
name = sipper.packageWithHighestDrain;
|
||||||
} else {
|
} else {
|
||||||
defaultPackageName = pm.getPackagesForUid(sipper.uidObj.getUid())[0];
|
mDefaultPackageName = pm.getPackagesForUid(sipper.uidObj.getUid())[0];
|
||||||
try {
|
try {
|
||||||
ApplicationInfo appInfo =
|
ApplicationInfo appInfo =
|
||||||
pm.getApplicationInfo(defaultPackageName, 0 /* no flags */);
|
pm.getApplicationInfo(mDefaultPackageName, 0 /* no flags */);
|
||||||
name = pm.getApplicationLabel(appInfo).toString();
|
name = pm.getApplicationLabel(appInfo).toString();
|
||||||
} catch (NameNotFoundException e) {
|
} catch (NameNotFoundException e) {
|
||||||
Log.d(TAG, "PackageManager failed to retrieve ApplicationInfo for: "
|
Log.d(TAG, "PackageManager failed to retrieve ApplicationInfo for: "
|
||||||
+ defaultPackageName);
|
+ mDefaultPackageName);
|
||||||
name = defaultPackageName;
|
name = mDefaultPackageName;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
@@ -250,8 +255,8 @@ public class BatteryEntry {
|
|||||||
if (iconId > 0) {
|
if (iconId > 0) {
|
||||||
icon = context.getDrawable(iconId);
|
icon = context.getDrawable(iconId);
|
||||||
}
|
}
|
||||||
if ((name == null || iconId == 0) && this.sipper.uidObj != null) {
|
if ((name == null || iconId == 0) && sipper.uidObj != null) {
|
||||||
getQuickNameIconForUid(this.sipper.uidObj.getUid());
|
getQuickNameIconForUid(sipper.uidObj.getUid());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -277,7 +282,7 @@ public class BatteryEntry {
|
|||||||
final String uidString = Integer.toString(uid);
|
final String uidString = Integer.toString(uid);
|
||||||
if (sUidCache.containsKey(uidString)) {
|
if (sUidCache.containsKey(uidString)) {
|
||||||
UidToDetail utd = sUidCache.get(uidString);
|
UidToDetail utd = sUidCache.get(uidString);
|
||||||
defaultPackageName = utd.packageName;
|
mDefaultPackageName = utd.packageName;
|
||||||
name = utd.name;
|
name = utd.name;
|
||||||
icon = utd.icon;
|
icon = utd.icon;
|
||||||
return;
|
return;
|
||||||
@@ -308,17 +313,17 @@ public class BatteryEntry {
|
|||||||
*/
|
*/
|
||||||
public void loadNameAndIcon() {
|
public void loadNameAndIcon() {
|
||||||
// Bail out if the current sipper is not an App sipper.
|
// Bail out if the current sipper is not an App sipper.
|
||||||
if (sipper.uidObj == null) {
|
if (mSipper.uidObj == null) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
PackageManager pm = context.getPackageManager();
|
PackageManager pm = context.getPackageManager();
|
||||||
final int uid = sipper.uidObj.getUid();
|
final int uid = mSipper.uidObj.getUid();
|
||||||
if (sipper.mPackages == null) {
|
if (mSipper.mPackages == null) {
|
||||||
sipper.mPackages = pm.getPackagesForUid(uid);
|
mSipper.mPackages = pm.getPackagesForUid(uid);
|
||||||
}
|
}
|
||||||
|
|
||||||
final String[] packages = extractPackagesFromSipper(sipper);
|
final String[] packages = extractPackagesFromSipper(mSipper);
|
||||||
if (packages != null) {
|
if (packages != null) {
|
||||||
String[] packageLabels = new String[packages.length];
|
String[] packageLabels = new String[packages.length];
|
||||||
System.arraycopy(packages, 0, packageLabels, 0, packages.length);
|
System.arraycopy(packages, 0, packageLabels, 0, packages.length);
|
||||||
@@ -340,7 +345,7 @@ public class BatteryEntry {
|
|||||||
packageLabels[i] = label.toString();
|
packageLabels[i] = label.toString();
|
||||||
}
|
}
|
||||||
if (ai.icon != 0) {
|
if (ai.icon != 0) {
|
||||||
defaultPackageName = packages[i];
|
mDefaultPackageName = packages[i];
|
||||||
icon = ai.loadIcon(pm);
|
icon = ai.loadIcon(pm);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@@ -368,7 +373,7 @@ public class BatteryEntry {
|
|||||||
if (nm != null) {
|
if (nm != null) {
|
||||||
name = nm.toString();
|
name = nm.toString();
|
||||||
if (pi.applicationInfo.icon != 0) {
|
if (pi.applicationInfo.icon != 0) {
|
||||||
defaultPackageName = pkgName;
|
mDefaultPackageName = pkgName;
|
||||||
icon = pi.applicationInfo.loadIcon(pm);
|
icon = pi.applicationInfo.loadIcon(pm);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
@@ -394,17 +399,113 @@ public class BatteryEntry {
|
|||||||
UidToDetail utd = new UidToDetail();
|
UidToDetail utd = new UidToDetail();
|
||||||
utd.name = name;
|
utd.name = name;
|
||||||
utd.icon = icon;
|
utd.icon = icon;
|
||||||
utd.packageName = defaultPackageName;
|
utd.packageName = mDefaultPackageName;
|
||||||
sUidCache.put(uidString, utd);
|
sUidCache.put(uidString, utd);
|
||||||
if (sHandler != null) {
|
if (sHandler != null) {
|
||||||
sHandler.sendMessage(sHandler.obtainMessage(MSG_UPDATE_NAME_ICON, this));
|
sHandler.sendMessage(sHandler.obtainMessage(MSG_UPDATE_NAME_ICON, this));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
String[] extractPackagesFromSipper(BatterySipper sipper) {
|
static String[] extractPackagesFromSipper(BatterySipper sipper) {
|
||||||
// Only use system package if uid is system uid, so it could find a consistent name and icon
|
// Only use system package if uid is system uid, so it could find a consistent name and icon
|
||||||
return sipper.getUid() == Process.SYSTEM_UID
|
return sipper.getUid() == Process.SYSTEM_UID
|
||||||
? new String[]{PACKAGE_SYSTEM}
|
? new String[]{PACKAGE_SYSTEM}
|
||||||
: sipper.mPackages;
|
: sipper.mPackages;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns true if this entry describes an app (UID)
|
||||||
|
*/
|
||||||
|
public boolean isAppEntry() {
|
||||||
|
if (mBatteryConsumer instanceof UidBatteryConsumer) {
|
||||||
|
return true;
|
||||||
|
} else {
|
||||||
|
return mSipper.drainType == BatterySipper.DrainType.APP;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns true if this entry describes a User.
|
||||||
|
*/
|
||||||
|
public boolean isUserEntry() {
|
||||||
|
if (mBatteryConsumer instanceof UserBatteryConsumer) {
|
||||||
|
return true;
|
||||||
|
} else {
|
||||||
|
return mSipper.drainType == BatterySipper.DrainType.USER;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns the package name that should be used to represent the UID described
|
||||||
|
* by this entry.
|
||||||
|
*/
|
||||||
|
public String getDefaultPackageName() {
|
||||||
|
if (mDefaultPackageName != null) {
|
||||||
|
return mDefaultPackageName;
|
||||||
|
}
|
||||||
|
if (ArrayUtils.isEmpty(mSipper.mPackages)) {
|
||||||
|
return null;
|
||||||
|
} else {
|
||||||
|
return mSipper.mPackages[0];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns the UID of the app described by this entry.
|
||||||
|
*/
|
||||||
|
public int getUid() {
|
||||||
|
if (mBatteryConsumer instanceof UidBatteryConsumer) {
|
||||||
|
return ((UidBatteryConsumer) mBatteryConsumer).getUid();
|
||||||
|
} else if (mBatteryConsumer != null) {
|
||||||
|
return Process.INVALID_UID;
|
||||||
|
} else {
|
||||||
|
return mSipper.getUid();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns foreground foreground time (in milliseconds) that is attributed to this entry.
|
||||||
|
*/
|
||||||
|
public long getTimeInForegroundMs(BatteryUtils batteryUtils) {
|
||||||
|
if (mBatteryConsumer instanceof UidBatteryConsumer) {
|
||||||
|
return ((UidBatteryConsumer) mBatteryConsumer).getTimeInStateMs(
|
||||||
|
UidBatteryConsumer.STATE_FOREGROUND);
|
||||||
|
} else if (mBatteryConsumer != null) {
|
||||||
|
return mBatteryConsumer.getUsageDurationMillis(BatteryConsumer.TIME_COMPONENT_USAGE);
|
||||||
|
} else if (mSipper.drainType == BatterySipper.DrainType.APP) {
|
||||||
|
return batteryUtils.getProcessTimeMs(
|
||||||
|
BatteryUtils.StatusType.FOREGROUND, mSipper.uidObj,
|
||||||
|
BatteryStats.STATS_SINCE_CHARGED);
|
||||||
|
} else {
|
||||||
|
return mSipper.usageTimeMs;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns background activity time (in milliseconds) that is attributed to this entry.
|
||||||
|
*/
|
||||||
|
public long getTimeInBackgroundMs(BatteryUtils batteryUtils) {
|
||||||
|
if (mBatteryConsumer instanceof UidBatteryConsumer) {
|
||||||
|
return ((UidBatteryConsumer) mBatteryConsumer).getTimeInStateMs(
|
||||||
|
UidBatteryConsumer.STATE_BACKGROUND);
|
||||||
|
} else if (mBatteryConsumer != null) {
|
||||||
|
return 0;
|
||||||
|
} else if (mSipper.drainType == BatterySipper.DrainType.APP) {
|
||||||
|
return batteryUtils.getProcessTimeMs(
|
||||||
|
BatteryUtils.StatusType.BACKGROUND, mSipper.uidObj,
|
||||||
|
BatteryStats.STATS_SINCE_CHARGED);
|
||||||
|
} else {
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns total amount of power (in milli-amp-hours) that is attributed to this entry.
|
||||||
|
*/
|
||||||
|
public double getConsumedPower() {
|
||||||
|
if (mBatteryConsumer != null) {
|
||||||
|
return mBatteryConsumer.getConsumedPower();
|
||||||
|
}
|
||||||
|
return (int) mSipper.totalPowerMah;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@@ -47,7 +47,6 @@ import androidx.loader.app.LoaderManager;
|
|||||||
import androidx.preference.Preference;
|
import androidx.preference.Preference;
|
||||||
import androidx.recyclerview.widget.RecyclerView;
|
import androidx.recyclerview.widget.RecyclerView;
|
||||||
|
|
||||||
import com.android.internal.os.BatterySipper;
|
|
||||||
import com.android.internal.os.BatteryStatsHelper;
|
import com.android.internal.os.BatteryStatsHelper;
|
||||||
import com.android.settings.R;
|
import com.android.settings.R;
|
||||||
import com.android.settings.SettingsActivity;
|
import com.android.settings.SettingsActivity;
|
||||||
@@ -114,12 +113,8 @@ public class AdvancedPowerUsageDetailTest {
|
|||||||
@Mock
|
@Mock
|
||||||
private BatteryEntry mBatteryEntry;
|
private BatteryEntry mBatteryEntry;
|
||||||
@Mock
|
@Mock
|
||||||
private BatterySipper mBatterySipper;
|
|
||||||
@Mock
|
|
||||||
private BatteryStatsHelper mBatteryStatsHelper;
|
private BatteryStatsHelper mBatteryStatsHelper;
|
||||||
@Mock
|
@Mock
|
||||||
private BatteryStats.Uid mUid;
|
|
||||||
@Mock
|
|
||||||
private PackageManager mPackageManager;
|
private PackageManager mPackageManager;
|
||||||
@Mock
|
@Mock
|
||||||
private AppOpsManager mAppOpsManager;
|
private AppOpsManager mAppOpsManager;
|
||||||
@@ -140,6 +135,7 @@ public class AdvancedPowerUsageDetailTest {
|
|||||||
MockitoAnnotations.initMocks(this);
|
MockitoAnnotations.initMocks(this);
|
||||||
|
|
||||||
mContext = spy(RuntimeEnvironment.application);
|
mContext = spy(RuntimeEnvironment.application);
|
||||||
|
when(mContext.getPackageName()).thenReturn("foo");
|
||||||
FakeFeatureFactory.setupForTest();
|
FakeFeatureFactory.setupForTest();
|
||||||
|
|
||||||
mFragment = spy(new AdvancedPowerUsageDetail());
|
mFragment = spy(new AdvancedPowerUsageDetail());
|
||||||
@@ -168,19 +164,13 @@ public class AdvancedPowerUsageDetailTest {
|
|||||||
doReturn(mEntityHeaderController).when(mEntityHeaderController)
|
doReturn(mEntityHeaderController).when(mEntityHeaderController)
|
||||||
.setSummary(nullable(String.class));
|
.setSummary(nullable(String.class));
|
||||||
|
|
||||||
doReturn(UID).when(mBatterySipper).getUid();
|
when(mBatteryEntry.getUid()).thenReturn(UID);
|
||||||
when(mBatteryEntry.getLabel()).thenReturn(APP_LABEL);
|
when(mBatteryEntry.getLabel()).thenReturn(APP_LABEL);
|
||||||
doReturn(BACKGROUND_TIME_US).when(mUid).getProcessStateTime(
|
when(mBatteryEntry.getTimeInBackgroundMs(any(BatteryUtils.class)))
|
||||||
eq(BatteryStats.Uid.PROCESS_STATE_BACKGROUND), anyLong(), anyInt());
|
.thenReturn(BACKGROUND_TIME_MS);
|
||||||
doReturn(PROCSTATE_TOP_TIME_US).when(mUid).getProcessStateTime(
|
when(mBatteryEntry.getTimeInForegroundMs(any(BatteryUtils.class)))
|
||||||
eq(BatteryStats.Uid.PROCESS_STATE_TOP), anyLong(), anyInt());
|
.thenReturn(FOREGROUND_TIME_MS);
|
||||||
doReturn(mForegroundActivityTimer).when(mUid).getForegroundActivityTimer();
|
|
||||||
doReturn(FOREGROUND_ACTIVITY_TIME_US).when(mForegroundActivityTimer)
|
|
||||||
.getTotalTimeLocked(anyLong(), anyInt());
|
|
||||||
ReflectionHelpers.setField(mBatteryEntry, "sipper", mBatterySipper);
|
|
||||||
mBatteryEntry.iconId = ICON_ID;
|
mBatteryEntry.iconId = ICON_ID;
|
||||||
mBatterySipper.uidObj = mUid;
|
|
||||||
mBatterySipper.drainType = BatterySipper.DrainType.APP;
|
|
||||||
|
|
||||||
mFragment.mHeaderPreference = mHeaderPreference;
|
mFragment.mHeaderPreference = mHeaderPreference;
|
||||||
mFragment.mState = mState;
|
mFragment.mState = mState;
|
||||||
@@ -200,6 +190,7 @@ public class AdvancedPowerUsageDetailTest {
|
|||||||
|
|
||||||
Answer<Void> callable = invocation -> {
|
Answer<Void> callable = invocation -> {
|
||||||
mBundle = captor.getValue().getBundleExtra(EXTRA_SHOW_FRAGMENT_ARGUMENTS);
|
mBundle = captor.getValue().getBundleExtra(EXTRA_SHOW_FRAGMENT_ARGUMENTS);
|
||||||
|
System.out.println("mBundle = " + mBundle);
|
||||||
return null;
|
return null;
|
||||||
};
|
};
|
||||||
doAnswer(callable).when(mActivity).startActivityAsUser(captor.capture(),
|
doAnswer(callable).when(mActivity).startActivityAsUser(captor.capture(),
|
||||||
@@ -274,27 +265,10 @@ public class AdvancedPowerUsageDetailTest {
|
|||||||
.isEqualTo(USAGE_PERCENT);
|
.isEqualTo(USAGE_PERCENT);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
|
||||||
public void testStartBatteryDetailPage_typeNotApp_hasBasicData() {
|
|
||||||
mBatterySipper.drainType = BatterySipper.DrainType.PHONE;
|
|
||||||
mBatterySipper.usageTimeMs = PHONE_FOREGROUND_TIME_MS;
|
|
||||||
|
|
||||||
AdvancedPowerUsageDetail.startBatteryDetailPage(mActivity, mBatteryUtils, mFragment,
|
|
||||||
mBatteryStatsHelper, 0, mBatteryEntry, USAGE_PERCENT);
|
|
||||||
|
|
||||||
assertThat(mBundle.getInt(AdvancedPowerUsageDetail.EXTRA_UID)).isEqualTo(UID);
|
|
||||||
assertThat(mBundle.getLong(AdvancedPowerUsageDetail.EXTRA_FOREGROUND_TIME))
|
|
||||||
.isEqualTo(PHONE_FOREGROUND_TIME_MS);
|
|
||||||
assertThat(mBundle.getLong(AdvancedPowerUsageDetail.EXTRA_BACKGROUND_TIME))
|
|
||||||
.isEqualTo(PHONE_BACKGROUND_TIME_MS);
|
|
||||||
assertThat(mBundle.getString(AdvancedPowerUsageDetail.EXTRA_POWER_USAGE_PERCENT))
|
|
||||||
.isEqualTo(USAGE_PERCENT);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testStartBatteryDetailPage_NormalApp() {
|
public void testStartBatteryDetailPage_NormalApp() {
|
||||||
mBatterySipper.mPackages = PACKAGE_NAME;
|
when(mBatteryEntry.getDefaultPackageName()).thenReturn(PACKAGE_NAME[0]);
|
||||||
mBatteryEntry.defaultPackageName = PACKAGE_NAME[0];
|
|
||||||
AdvancedPowerUsageDetail.startBatteryDetailPage(mActivity, mBatteryUtils, mFragment,
|
AdvancedPowerUsageDetail.startBatteryDetailPage(mActivity, mBatteryUtils, mFragment,
|
||||||
mBatteryStatsHelper, 0, mBatteryEntry, USAGE_PERCENT);
|
mBatteryStatsHelper, 0, mBatteryEntry, USAGE_PERCENT);
|
||||||
|
|
||||||
@@ -304,7 +278,8 @@ public class AdvancedPowerUsageDetailTest {
|
|||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testStartBatteryDetailPage_SystemApp() {
|
public void testStartBatteryDetailPage_SystemApp() {
|
||||||
mBatterySipper.mPackages = null;
|
when(mBatteryEntry.getDefaultPackageName()).thenReturn(null);
|
||||||
|
|
||||||
AdvancedPowerUsageDetail.startBatteryDetailPage(mActivity, mBatteryUtils, mFragment,
|
AdvancedPowerUsageDetail.startBatteryDetailPage(mActivity, mBatteryUtils, mFragment,
|
||||||
mBatteryStatsHelper, 0, mBatteryEntry, USAGE_PERCENT);
|
mBatteryStatsHelper, 0, mBatteryEntry, USAGE_PERCENT);
|
||||||
|
|
||||||
@@ -316,8 +291,8 @@ public class AdvancedPowerUsageDetailTest {
|
|||||||
@Test
|
@Test
|
||||||
public void testStartBatteryDetailPage_WorkApp() {
|
public void testStartBatteryDetailPage_WorkApp() {
|
||||||
final int appUid = 1010019;
|
final int appUid = 1010019;
|
||||||
mBatterySipper.mPackages = PACKAGE_NAME;
|
doReturn(appUid).when(mBatteryEntry).getUid();
|
||||||
doReturn(appUid).when(mBatterySipper).getUid();
|
|
||||||
AdvancedPowerUsageDetail.startBatteryDetailPage(mActivity, mBatteryUtils, mFragment,
|
AdvancedPowerUsageDetail.startBatteryDetailPage(mActivity, mBatteryUtils, mFragment,
|
||||||
mBatteryStatsHelper, 0, mBatteryEntry, USAGE_PERCENT);
|
mBatteryStatsHelper, 0, mBatteryEntry, USAGE_PERCENT);
|
||||||
|
|
||||||
@@ -326,8 +301,7 @@ public class AdvancedPowerUsageDetailTest {
|
|||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testStartBatteryDetailPage_typeUser_startByCurrentUser() {
|
public void testStartBatteryDetailPage_typeUser_startByCurrentUser() {
|
||||||
mBatterySipper.drainType = BatterySipper.DrainType.USER;
|
when(mBatteryEntry.isUserEntry()).thenReturn(true);
|
||||||
mBatterySipper.userId = 10;
|
|
||||||
|
|
||||||
final int currentUser = 20;
|
final int currentUser = 20;
|
||||||
ShadowActivityManager.setCurrentUser(currentUser);
|
ShadowActivityManager.setCurrentUser(currentUser);
|
||||||
@@ -364,18 +338,6 @@ public class AdvancedPowerUsageDetailTest {
|
|||||||
assertThat(mBundle.getInt(AdvancedPowerUsageDetail.EXTRA_UID)).isEqualTo(UID);
|
assertThat(mBundle.getInt(AdvancedPowerUsageDetail.EXTRA_UID)).isEqualTo(UID);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
|
||||||
public void testStartBatteryDetailPage_defaultPackageNull_chooseFromBatterySipper() {
|
|
||||||
mBatteryEntry.defaultPackageName = null;
|
|
||||||
mBatteryEntry.sipper.mPackages = PACKAGE_NAME;
|
|
||||||
|
|
||||||
AdvancedPowerUsageDetail.startBatteryDetailPage(mActivity, mBatteryUtils, mFragment,
|
|
||||||
mBatteryStatsHelper, 0, mBatteryEntry, USAGE_PERCENT);
|
|
||||||
|
|
||||||
assertThat(mBundle.getString(AdvancedPowerUsageDetail.EXTRA_PACKAGE_NAME))
|
|
||||||
.isEqualTo(PACKAGE_NAME[0]);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testInitPreference_hasCorrectSummary() {
|
public void testInitPreference_hasCorrectSummary() {
|
||||||
Bundle bundle = new Bundle(4);
|
Bundle bundle = new Bundle(4);
|
||||||
|
@@ -17,6 +17,8 @@ package com.android.settings.fuelgauge;
|
|||||||
|
|
||||||
import static com.google.common.truth.Truth.assertThat;
|
import static com.google.common.truth.Truth.assertThat;
|
||||||
|
|
||||||
|
import static org.mockito.ArgumentMatchers.any;
|
||||||
|
import static org.mockito.ArgumentMatchers.eq;
|
||||||
import static org.mockito.Mockito.mock;
|
import static org.mockito.Mockito.mock;
|
||||||
import static org.mockito.Mockito.when;
|
import static org.mockito.Mockito.when;
|
||||||
|
|
||||||
@@ -24,8 +26,12 @@ import android.content.Context;
|
|||||||
import android.content.pm.ApplicationInfo;
|
import android.content.pm.ApplicationInfo;
|
||||||
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.BatteryConsumer;
|
||||||
|
import android.os.BatteryStats;
|
||||||
import android.os.Handler;
|
import android.os.Handler;
|
||||||
import android.os.Process;
|
import android.os.Process;
|
||||||
|
import android.os.SystemBatteryConsumer;
|
||||||
|
import android.os.UidBatteryConsumer;
|
||||||
import android.os.UserManager;
|
import android.os.UserManager;
|
||||||
|
|
||||||
import com.android.internal.os.BatterySipper;
|
import com.android.internal.os.BatterySipper;
|
||||||
@@ -61,6 +67,9 @@ public class BatteryEntryTest {
|
|||||||
@Mock private Handler mockHandler;
|
@Mock private Handler mockHandler;
|
||||||
@Mock private PackageManager mockPackageManager;
|
@Mock private PackageManager mockPackageManager;
|
||||||
@Mock private UserManager mockUserManager;
|
@Mock private UserManager mockUserManager;
|
||||||
|
@Mock private UidBatteryConsumer mUidBatteryConsumer;
|
||||||
|
@Mock private SystemBatteryConsumer mSystemBatteryConsumer;
|
||||||
|
@Mock BatteryUtils mBatteryUtils;
|
||||||
|
|
||||||
@Before
|
@Before
|
||||||
public void stubContextToReturnMockPackageManager() {
|
public void stubContextToReturnMockPackageManager() {
|
||||||
@@ -80,7 +89,7 @@ public class BatteryEntryTest {
|
|||||||
|
|
||||||
private BatteryEntry createBatteryEntryForApp() {
|
private BatteryEntry createBatteryEntryForApp() {
|
||||||
return new BatteryEntry(mockContext, mockHandler, mockUserManager, createSipperForApp(),
|
return new BatteryEntry(mockContext, mockHandler, mockUserManager, createSipperForApp(),
|
||||||
null);
|
null, null);
|
||||||
}
|
}
|
||||||
|
|
||||||
private BatterySipper createSipperForApp() {
|
private BatterySipper createSipperForApp() {
|
||||||
@@ -90,11 +99,6 @@ public class BatteryEntryTest {
|
|||||||
return sipper;
|
return sipper;
|
||||||
}
|
}
|
||||||
|
|
||||||
private BatteryEntry createBatteryEntryForSystem() {
|
|
||||||
return new BatteryEntry(mockContext, mockHandler, mockUserManager, createSipperForSystem(),
|
|
||||||
null);
|
|
||||||
}
|
|
||||||
|
|
||||||
private BatterySipper createSipperForSystem() {
|
private BatterySipper createSipperForSystem() {
|
||||||
BatterySipper sipper =
|
BatterySipper sipper =
|
||||||
new BatterySipper(DrainType.APP, new FakeUid(SYSTEM_UID), 0 /* power use */);
|
new BatterySipper(DrainType.APP, new FakeUid(SYSTEM_UID), 0 /* power use */);
|
||||||
@@ -103,11 +107,15 @@ public class BatteryEntryTest {
|
|||||||
return sipper;
|
return sipper;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private BatterySipper createNonAppSipper() {
|
||||||
|
return new BatterySipper(DrainType.IDLE, null, 0 /* power use */);
|
||||||
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void batteryEntryForApp_shouldSetDefaultPackageNameAndLabel() throws Exception {
|
public void batteryEntryForApp_shouldSetDefaultPackageNameAndLabel() throws Exception {
|
||||||
BatteryEntry entry = createBatteryEntryForApp();
|
BatteryEntry entry = createBatteryEntryForApp();
|
||||||
|
|
||||||
assertThat(entry.defaultPackageName).isEqualTo(APP_DEFAULT_PACKAGE_NAME);
|
assertThat(entry.getDefaultPackageName()).isEqualTo(APP_DEFAULT_PACKAGE_NAME);
|
||||||
assertThat(entry.getLabel()).isEqualTo(APP_LABEL);
|
assertThat(entry.getLabel()).isEqualTo(APP_LABEL);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -146,7 +154,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, null);
|
mockUserManager, batterySipper, null, 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");
|
||||||
@@ -154,17 +162,82 @@ public class BatteryEntryTest {
|
|||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void extractPackageFromSipper_systemSipper_returnSystemPackage() {
|
public void extractPackageFromSipper_systemSipper_returnSystemPackage() {
|
||||||
BatteryEntry entry = createBatteryEntryForSystem();
|
assertThat(BatteryEntry.extractPackagesFromSipper(createSipperForSystem()))
|
||||||
|
|
||||||
assertThat(entry.extractPackagesFromSipper(entry.sipper))
|
|
||||||
.isEqualTo(new String[] {ANDROID_PACKAGE});
|
.isEqualTo(new String[] {ANDROID_PACKAGE});
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void extractPackageFromSipper_normalSipper_returnDefaultPackage() {
|
public void extractPackageFromSipper_normalSipper_returnDefaultPackage() {
|
||||||
BatteryEntry entry = createBatteryEntryForApp();
|
BatterySipper sipper = createSipperForApp();
|
||||||
|
assertThat(BatteryEntry.extractPackagesFromSipper(sipper)).isEqualTo(sipper.mPackages);
|
||||||
|
}
|
||||||
|
|
||||||
assertThat(entry.extractPackagesFromSipper(entry.sipper)).isEqualTo(entry.sipper.mPackages);
|
@Test
|
||||||
|
public void getTimeInForegroundMs_app() {
|
||||||
|
final BatteryEntry entry = new BatteryEntry(RuntimeEnvironment.application, mockHandler,
|
||||||
|
mockUserManager, null, mUidBatteryConsumer, null);
|
||||||
|
|
||||||
|
when(mUidBatteryConsumer.getTimeInStateMs(UidBatteryConsumer.STATE_FOREGROUND))
|
||||||
|
.thenReturn(100L);
|
||||||
|
|
||||||
|
assertThat(entry.getTimeInForegroundMs(mBatteryUtils)).isEqualTo(100L);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void getTimeInForegroundMs_systemConsumer() {
|
||||||
|
final BatteryEntry entry = new BatteryEntry(RuntimeEnvironment.application, mockHandler,
|
||||||
|
mockUserManager, createNonAppSipper(), mSystemBatteryConsumer, null);
|
||||||
|
|
||||||
|
when(mSystemBatteryConsumer.getUsageDurationMillis(BatteryConsumer.TIME_COMPONENT_USAGE))
|
||||||
|
.thenReturn(100L);
|
||||||
|
|
||||||
|
assertThat(entry.getTimeInForegroundMs(mBatteryUtils)).isEqualTo(100L);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void getTimeInForegroundMs_useSipper() {
|
||||||
|
final BatterySipper batterySipper = createSipperForApp();
|
||||||
|
final BatteryEntry entry = new BatteryEntry(RuntimeEnvironment.application, mockHandler,
|
||||||
|
mockUserManager, batterySipper, null, null);
|
||||||
|
|
||||||
|
when(mBatteryUtils.getProcessTimeMs(eq(BatteryUtils.StatusType.FOREGROUND),
|
||||||
|
any(BatteryStats.Uid.class), eq(BatteryStats.STATS_SINCE_CHARGED)))
|
||||||
|
.thenReturn(100L);
|
||||||
|
assertThat(entry.getTimeInForegroundMs(mBatteryUtils)).isEqualTo(100L);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void getTimeInBackgroundMs_app() {
|
||||||
|
final BatteryEntry entry = new BatteryEntry(RuntimeEnvironment.application, mockHandler,
|
||||||
|
mockUserManager, null, mUidBatteryConsumer, null);
|
||||||
|
|
||||||
|
when(mUidBatteryConsumer.getTimeInStateMs(UidBatteryConsumer.STATE_BACKGROUND))
|
||||||
|
.thenReturn(100L);
|
||||||
|
|
||||||
|
assertThat(entry.getTimeInBackgroundMs(mBatteryUtils)).isEqualTo(100L);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void getTimeInBackgroundMs_systemConsumer() {
|
||||||
|
final BatteryEntry entry = new BatteryEntry(RuntimeEnvironment.application, mockHandler,
|
||||||
|
mockUserManager, createNonAppSipper(), mSystemBatteryConsumer, null);
|
||||||
|
|
||||||
|
when(mSystemBatteryConsumer.getUsageDurationMillis(BatteryConsumer.TIME_COMPONENT_USAGE))
|
||||||
|
.thenReturn(100L);
|
||||||
|
|
||||||
|
assertThat(entry.getTimeInBackgroundMs(mBatteryUtils)).isEqualTo(0);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void getTimeInBackgroundMs_useSipper() {
|
||||||
|
final BatterySipper batterySipper = createSipperForApp();
|
||||||
|
final BatteryEntry entry = new BatteryEntry(RuntimeEnvironment.application, mockHandler,
|
||||||
|
mockUserManager, batterySipper, null, null);
|
||||||
|
|
||||||
|
when(mBatteryUtils.getProcessTimeMs(eq(BatteryUtils.StatusType.BACKGROUND),
|
||||||
|
any(BatteryStats.Uid.class), eq(BatteryStats.STATS_SINCE_CHARGED)))
|
||||||
|
.thenReturn(100L);
|
||||||
|
assertThat(entry.getTimeInBackgroundMs(mBatteryUtils)).isEqualTo(100L);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
|
Reference in New Issue
Block a user