Merge "Update the flow of charging optimization strings." into main
This commit is contained in:
committed by
Android (Google) Code Review
commit
a71f46ecc6
@@ -86,13 +86,14 @@ public class BatteryHeaderPreferenceController extends BasePreferenceController
|
|||||||
return mContext.getString(
|
return mContext.getString(
|
||||||
com.android.settingslib.R.string.battery_info_status_charging_on_hold);
|
com.android.settingslib.R.string.battery_info_status_charging_on_hold);
|
||||||
}
|
}
|
||||||
|
if (info.remainingLabel != null
|
||||||
|
&& mBatterySettingsFeatureProvider.isChargingOptimizationMode(mContext)) {
|
||||||
|
return info.remainingLabel;
|
||||||
|
}
|
||||||
if (info.remainingLabel == null
|
if (info.remainingLabel == null
|
||||||
|| info.batteryStatus == BatteryManager.BATTERY_STATUS_NOT_CHARGING) {
|
|| info.batteryStatus == BatteryManager.BATTERY_STATUS_NOT_CHARGING) {
|
||||||
return info.statusLabel;
|
return info.statusLabel;
|
||||||
}
|
}
|
||||||
if (mBatterySettingsFeatureProvider.isChargingOptimizationMode(mContext)) {
|
|
||||||
return info.remainingLabel;
|
|
||||||
}
|
|
||||||
if (info.pluggedStatus == BatteryManager.BATTERY_PLUGGED_WIRELESS) {
|
if (info.pluggedStatus == BatteryManager.BATTERY_PLUGGED_WIRELESS) {
|
||||||
final CharSequence wirelessChargingLabel =
|
final CharSequence wirelessChargingLabel =
|
||||||
mBatterySettingsFeatureProvider.getWirelessChargingLabel(mContext, info);
|
mBatterySettingsFeatureProvider.getWirelessChargingLabel(mContext, info);
|
||||||
|
@@ -390,12 +390,37 @@ public class BatteryInfo {
|
|||||||
info.remainingLabel = null;
|
info.remainingLabel = null;
|
||||||
int chargingLimitedResId = R.string.power_charging_limited;
|
int chargingLimitedResId = R.string.power_charging_limited;
|
||||||
info.chargeLabel = context.getString(chargingLimitedResId, info.batteryPercentString);
|
info.chargeLabel = context.getString(chargingLimitedResId, info.batteryPercentString);
|
||||||
} else if ((chargeTimeMs > 0
|
return;
|
||||||
|
}
|
||||||
|
final BatterySettingsFeatureProvider featureProvider =
|
||||||
|
FeatureFactory.getFeatureFactory().getBatterySettingsFeatureProvider();
|
||||||
|
if (featureProvider.isChargingOptimizationMode(context)) {
|
||||||
|
final CharSequence chargeLabel =
|
||||||
|
featureProvider.getChargingOptimizationChargeLabel(
|
||||||
|
context,
|
||||||
|
info.batteryLevel,
|
||||||
|
info.batteryPercentString,
|
||||||
|
chargeTimeMs,
|
||||||
|
currentTimeMs);
|
||||||
|
if (chargeLabel != null) {
|
||||||
|
final CharSequence remainingLabel =
|
||||||
|
featureProvider.getChargingOptimizationRemainingLabel(
|
||||||
|
context,
|
||||||
|
info.batteryLevel,
|
||||||
|
info.pluggedStatus,
|
||||||
|
chargeTimeMs,
|
||||||
|
currentTimeMs);
|
||||||
|
if (remainingLabel != null) {
|
||||||
|
info.chargeLabel = chargeLabel;
|
||||||
|
info.remainingLabel = remainingLabel;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if ((chargeTimeMs > 0
|
||||||
&& status != BatteryManager.BATTERY_STATUS_FULL
|
&& status != BatteryManager.BATTERY_STATUS_FULL
|
||||||
&& dockDefenderMode == BatteryUtils.DockDefenderMode.DISABLED)
|
&& dockDefenderMode == BatteryUtils.DockDefenderMode.DISABLED)
|
||||||
|| dockDefenderMode == BatteryUtils.DockDefenderMode.TEMPORARILY_BYPASSED) {
|
|| dockDefenderMode == BatteryUtils.DockDefenderMode.TEMPORARILY_BYPASSED) {
|
||||||
final BatterySettingsFeatureProvider featureProvider =
|
|
||||||
FeatureFactory.getFeatureFactory().getBatterySettingsFeatureProvider();
|
|
||||||
// Battery is charging to full
|
// Battery is charging to full
|
||||||
info.remainingTimeUs = PowerUtil.convertMsToUs(chargeTimeMs);
|
info.remainingTimeUs = PowerUtil.convertMsToUs(chargeTimeMs);
|
||||||
int resId = getChargingDurationResId(info.isFastCharging);
|
int resId = getChargingDurationResId(info.isFastCharging);
|
||||||
@@ -419,8 +444,7 @@ public class BatteryInfo {
|
|||||||
info.batteryPercentString,
|
info.batteryPercentString,
|
||||||
chargeTimeMs,
|
chargeTimeMs,
|
||||||
info.isFastCharging,
|
info.isFastCharging,
|
||||||
currentTimeMs,
|
currentTimeMs);
|
||||||
featureProvider);
|
|
||||||
} else if (dockDefenderMode == BatteryUtils.DockDefenderMode.FUTURE_BYPASS) {
|
} else if (dockDefenderMode == BatteryUtils.DockDefenderMode.FUTURE_BYPASS) {
|
||||||
// Dock defender will be triggered in the future, charging will be optimized.
|
// Dock defender will be triggered in the future, charging will be optimized.
|
||||||
info.chargeLabel =
|
info.chargeLabel =
|
||||||
@@ -447,14 +471,6 @@ public class BatteryInfo {
|
|||||||
int pluggedStatus,
|
int pluggedStatus,
|
||||||
long currentTimeMs,
|
long currentTimeMs,
|
||||||
BatterySettingsFeatureProvider featureProvider) {
|
BatterySettingsFeatureProvider featureProvider) {
|
||||||
if (featureProvider.isChargingOptimizationMode(context)) {
|
|
||||||
final CharSequence chargingOptimizationRemainingLabel =
|
|
||||||
featureProvider.getChargingOptimizationRemainingLabel(
|
|
||||||
context, chargeRemainingTimeMs, currentTimeMs);
|
|
||||||
if (chargingOptimizationRemainingLabel != null) {
|
|
||||||
return chargingOptimizationRemainingLabel;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (pluggedStatus == BatteryManager.BATTERY_PLUGGED_WIRELESS) {
|
if (pluggedStatus == BatteryManager.BATTERY_PLUGGED_WIRELESS) {
|
||||||
final CharSequence wirelessChargingRemainingLabel =
|
final CharSequence wirelessChargingRemainingLabel =
|
||||||
featureProvider.getWirelessChargingRemainingLabel(
|
featureProvider.getWirelessChargingRemainingLabel(
|
||||||
@@ -488,16 +504,7 @@ public class BatteryInfo {
|
|||||||
String batteryPercentString,
|
String batteryPercentString,
|
||||||
long chargeTimeMs,
|
long chargeTimeMs,
|
||||||
boolean isFastCharging,
|
boolean isFastCharging,
|
||||||
long currentTimeMs,
|
long currentTimeMs) {
|
||||||
BatterySettingsFeatureProvider featureProvider) {
|
|
||||||
if (featureProvider.isChargingOptimizationMode(context)) {
|
|
||||||
final CharSequence chargingOptimizationChargeLabel =
|
|
||||||
featureProvider.getChargingOptimizationChargeLabel(
|
|
||||||
context, batteryPercentString, chargeTimeMs, currentTimeMs);
|
|
||||||
if (chargingOptimizationChargeLabel != null) {
|
|
||||||
return chargingOptimizationChargeLabel;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (com.android.settingslib.fuelgauge.BatteryUtils.isChargingStringV2Enabled()) {
|
if (com.android.settingslib.fuelgauge.BatteryUtils.isChargingStringV2Enabled()) {
|
||||||
var timeString =
|
var timeString =
|
||||||
PowerUtil.getTargetTimeShortString(context, chargeTimeMs, currentTimeMs);
|
PowerUtil.getTargetTimeShortString(context, chargeTimeMs, currentTimeMs);
|
||||||
|
@@ -60,13 +60,18 @@ public interface BatterySettingsFeatureProvider {
|
|||||||
/** Return a charging remaining time label for charging optimization mode. */
|
/** Return a charging remaining time label for charging optimization mode. */
|
||||||
@Nullable
|
@Nullable
|
||||||
CharSequence getChargingOptimizationRemainingLabel(
|
CharSequence getChargingOptimizationRemainingLabel(
|
||||||
@NonNull Context context, long chargeRemainingTimeMs, long currentTimeMs);
|
@NonNull Context context,
|
||||||
|
int batteryLevel,
|
||||||
|
int pluggedStatus,
|
||||||
|
long chargeRemainingTimeMs,
|
||||||
|
long currentTimeMs);
|
||||||
|
|
||||||
/** Return a charge label for charging optimization mode. */
|
/** Return a charge label for charging optimization mode. */
|
||||||
@Nullable
|
@Nullable
|
||||||
CharSequence getChargingOptimizationChargeLabel(
|
CharSequence getChargingOptimizationChargeLabel(
|
||||||
@NonNull Context context,
|
@NonNull Context context,
|
||||||
@NonNull String batteryPercentageString,
|
int batteryLevel,
|
||||||
|
String batteryPercentageString,
|
||||||
long chargeRemainingTimeMs,
|
long chargeRemainingTimeMs,
|
||||||
long currentTimeMs);
|
long currentTimeMs);
|
||||||
}
|
}
|
||||||
|
@@ -76,7 +76,11 @@ public class BatterySettingsFeatureProviderImpl implements BatterySettingsFeatur
|
|||||||
@Nullable
|
@Nullable
|
||||||
@Override
|
@Override
|
||||||
public CharSequence getChargingOptimizationRemainingLabel(
|
public CharSequence getChargingOptimizationRemainingLabel(
|
||||||
@NonNull Context context, long chargeRemainingTimeMs, long currentTimeMs) {
|
@NonNull Context context,
|
||||||
|
int batteryLevel,
|
||||||
|
int pluggedStatus,
|
||||||
|
long chargeRemainingTimeMs,
|
||||||
|
long currentTimeMs) {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -84,7 +88,8 @@ public class BatterySettingsFeatureProviderImpl implements BatterySettingsFeatur
|
|||||||
@Override
|
@Override
|
||||||
public CharSequence getChargingOptimizationChargeLabel(
|
public CharSequence getChargingOptimizationChargeLabel(
|
||||||
@NonNull Context context,
|
@NonNull Context context,
|
||||||
@NonNull String batteryPercentageString,
|
int batteryLevel,
|
||||||
|
String batteryPercentageString,
|
||||||
long chargeRemainingTimeMs,
|
long chargeRemainingTimeMs,
|
||||||
long currentTimeMs) {
|
long currentTimeMs) {
|
||||||
return null;
|
return null;
|
||||||
|
@@ -159,6 +159,11 @@ public class TopLevelBatteryPreferenceController extends BasePreferenceControlle
|
|||||||
com.android.settingslib.R.string.power_charging_on_hold_settings_home_page,
|
com.android.settingslib.R.string.power_charging_on_hold_settings_home_page,
|
||||||
info.batteryPercentString);
|
info.batteryPercentString);
|
||||||
}
|
}
|
||||||
|
final BatterySettingsFeatureProvider featureProvider =
|
||||||
|
FeatureFactory.getFeatureFactory().getBatterySettingsFeatureProvider();
|
||||||
|
if (info.chargeLabel != null && featureProvider.isChargingOptimizationMode(mContext)) {
|
||||||
|
return info.chargeLabel;
|
||||||
|
}
|
||||||
if (info.batteryStatus == BatteryManager.BATTERY_STATUS_NOT_CHARGING) {
|
if (info.batteryStatus == BatteryManager.BATTERY_STATUS_NOT_CHARGING) {
|
||||||
// Present status only if no remaining time or status anomalous
|
// Present status only if no remaining time or status anomalous
|
||||||
return info.statusLabel;
|
return info.statusLabel;
|
||||||
|
@@ -286,8 +286,9 @@ public class BatteryHeaderPreferenceControllerTest {
|
|||||||
/* isFastCharging= */ true,
|
/* isFastCharging= */ true,
|
||||||
/* isChargingStringV2= */ true);
|
/* isChargingStringV2= */ true);
|
||||||
batteryInfo.pluggedStatus = BatteryManager.BATTERY_PLUGGED_WIRELESS;
|
batteryInfo.pluggedStatus = BatteryManager.BATTERY_PLUGGED_WIRELESS;
|
||||||
when(mFactory.batterySettingsFeatureProvider.getWirelessChargingLabel(eq(mContext),
|
when(mFactory.batterySettingsFeatureProvider.getWirelessChargingLabel(
|
||||||
any(BatteryInfo.class))).thenReturn(label);
|
eq(mContext), any(BatteryInfo.class)))
|
||||||
|
.thenReturn(label);
|
||||||
|
|
||||||
mController.updateBatteryStatus(/* label= */ null, batteryInfo);
|
mController.updateBatteryStatus(/* label= */ null, batteryInfo);
|
||||||
|
|
||||||
@@ -326,14 +327,64 @@ public class BatteryHeaderPreferenceControllerTest {
|
|||||||
verify(mBatteryUsageProgressBarPref).setBottomSummary(expectedChargingString);
|
verify(mBatteryUsageProgressBarPref).setBottomSummary(expectedChargingString);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void updateBatteryStatus_chargingOptimizationMode_remainingLabel() {
|
||||||
|
var batteryInfo =
|
||||||
|
arrangeUpdateBatteryStatusTestWithRemainingLabel(
|
||||||
|
/* remainingLabel= */ "Expected remaining label",
|
||||||
|
/* statusLabel= */ "Fast Charging",
|
||||||
|
/* isFastCharging= */ true,
|
||||||
|
/* isChargingStringV2= */ true);
|
||||||
|
var expectedChargingString = batteryInfo.remainingLabel;
|
||||||
|
when(mFactory.batterySettingsFeatureProvider.isChargingOptimizationMode(mContext))
|
||||||
|
.thenReturn(true);
|
||||||
|
|
||||||
|
mController.updateBatteryStatus(/* label= */ null, batteryInfo);
|
||||||
|
|
||||||
|
verify(mBatteryUsageProgressBarPref).setBottomSummary(expectedChargingString);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void updateBatteryStatus_chargingOptimizationModeNoRemainingLabel_statusLabel() {
|
||||||
|
var batteryInfo =
|
||||||
|
arrangeUpdateBatteryStatusTestWithRemainingLabel(
|
||||||
|
/* remainingLabel= */ null,
|
||||||
|
/* statusLabel= */ "Fast Charging",
|
||||||
|
/* isFastCharging= */ true,
|
||||||
|
/* isChargingStringV2= */ true);
|
||||||
|
var expectedChargingString = batteryInfo.statusLabel;
|
||||||
|
when(mFactory.batterySettingsFeatureProvider.isChargingOptimizationMode(mContext))
|
||||||
|
.thenReturn(true);
|
||||||
|
|
||||||
|
mController.updateBatteryStatus(/* label= */ null, batteryInfo);
|
||||||
|
|
||||||
|
verify(mBatteryUsageProgressBarPref).setBottomSummary(expectedChargingString);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void updateBatteryStatus_notChargingOptimizationMode_statusWithRemainingLabel() {
|
||||||
|
var batteryInfo =
|
||||||
|
arrangeUpdateBatteryStatusTestWithRemainingLabel(
|
||||||
|
/* remainingLabel= */ "Full by 1:30 PM",
|
||||||
|
/* statusLabel= */ "Fast Charging",
|
||||||
|
/* isFastCharging= */ true,
|
||||||
|
/* isChargingStringV2= */ true);
|
||||||
|
var expectedChargingString = batteryInfo.statusLabel + " • " + batteryInfo.remainingLabel;
|
||||||
|
when(mFactory.batterySettingsFeatureProvider.isChargingOptimizationMode(mContext))
|
||||||
|
.thenReturn(false);
|
||||||
|
|
||||||
|
mController.updateBatteryStatus(/* label= */ null, batteryInfo);
|
||||||
|
|
||||||
|
verify(mBatteryUsageProgressBarPref).setBottomSummary(expectedChargingString);
|
||||||
|
}
|
||||||
|
|
||||||
private BatteryInfo arrangeUpdateBatteryStatusTestWithRemainingLabel(
|
private BatteryInfo arrangeUpdateBatteryStatusTestWithRemainingLabel(
|
||||||
String remainingLabel,
|
String remainingLabel,
|
||||||
String statusLabel,
|
String statusLabel,
|
||||||
boolean isFastCharging,
|
boolean isFastCharging,
|
||||||
boolean isChargingStringV2) {
|
boolean isChargingStringV2) {
|
||||||
SystemProperties.set(
|
SystemProperties.set(
|
||||||
BatteryUtils.PROPERTY_CHARGING_STRING_V2_KEY,
|
BatteryUtils.PROPERTY_CHARGING_STRING_V2_KEY, String.valueOf(isChargingStringV2));
|
||||||
String.valueOf(isChargingStringV2));
|
|
||||||
mBatteryInfo.isBatteryDefender = false;
|
mBatteryInfo.isBatteryDefender = false;
|
||||||
mBatteryInfo.remainingLabel = remainingLabel;
|
mBatteryInfo.remainingLabel = remainingLabel;
|
||||||
mBatteryInfo.statusLabel = statusLabel;
|
mBatteryInfo.statusLabel = statusLabel;
|
||||||
@@ -389,8 +440,11 @@ public class BatteryHeaderPreferenceControllerTest {
|
|||||||
|
|
||||||
mController.updateHeaderPreference(mBatteryInfo);
|
mController.updateHeaderPreference(mBatteryInfo);
|
||||||
|
|
||||||
verify(mBatteryUsageProgressBarPref).setBottomSummary(mContext.getString(
|
verify(mBatteryUsageProgressBarPref)
|
||||||
com.android.settingslib.R.string.battery_info_status_charging_on_hold));
|
.setBottomSummary(
|
||||||
|
mContext.getString(
|
||||||
|
com.android.settingslib.R.string
|
||||||
|
.battery_info_status_charging_on_hold));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
|
@@ -724,15 +724,15 @@ public class BatteryInfoTest {
|
|||||||
Intent batteryIntent =
|
Intent batteryIntent =
|
||||||
createIntentForGetBatteryInfoTest(
|
createIntentForGetBatteryInfoTest(
|
||||||
ChargingType.WIRED, ChargingSpeed.REGULAR, /* batteryLevel= */ 65);
|
ChargingType.WIRED, ChargingSpeed.REGULAR, /* batteryLevel= */ 65);
|
||||||
var expectedRemainingLabel = "Done charging by";
|
var expectedRemainingLabel = "Expected remaining label";
|
||||||
var expectedChargeLabel = "65% - " + expectedRemainingLabel;
|
var expectedChargeLabel = "65% - " + expectedRemainingLabel;
|
||||||
when(mFeatureFactory.batterySettingsFeatureProvider.isChargingOptimizationMode(mContext))
|
when(mFeatureFactory.batterySettingsFeatureProvider.isChargingOptimizationMode(mContext))
|
||||||
.thenReturn(true);
|
.thenReturn(true);
|
||||||
when(mFeatureFactory.batterySettingsFeatureProvider.getChargingOptimizationRemainingLabel(
|
when(mFeatureFactory.batterySettingsFeatureProvider.getChargingOptimizationRemainingLabel(
|
||||||
eq(mContext), anyLong(), anyLong()))
|
eq(mContext), anyInt(), anyInt(), anyLong(), anyLong()))
|
||||||
.thenReturn(expectedRemainingLabel);
|
.thenReturn(expectedRemainingLabel);
|
||||||
when(mFeatureFactory.batterySettingsFeatureProvider.getChargingOptimizationChargeLabel(
|
when(mFeatureFactory.batterySettingsFeatureProvider.getChargingOptimizationChargeLabel(
|
||||||
eq(mContext), anyString(), anyLong(), anyLong()))
|
eq(mContext), anyInt(), anyString(), anyLong(), anyLong()))
|
||||||
.thenReturn(expectedChargeLabel);
|
.thenReturn(expectedChargeLabel);
|
||||||
var expectedStatusLabel = "Charging";
|
var expectedStatusLabel = "Charging";
|
||||||
|
|
||||||
|
@@ -19,6 +19,7 @@ package com.android.settings.fuelgauge;
|
|||||||
import static com.google.common.truth.Truth.assertThat;
|
import static com.google.common.truth.Truth.assertThat;
|
||||||
|
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
|
import android.os.BatteryManager;
|
||||||
|
|
||||||
import androidx.test.core.app.ApplicationProvider;
|
import androidx.test.core.app.ApplicationProvider;
|
||||||
|
|
||||||
@@ -87,12 +88,15 @@ public class BatterySettingsFeatureProviderImplTest {
|
|||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void getChargingOptimizationRemainingLabel_default_returnNull() {
|
public void getChargingOptimizationRemainingLabel_default_returnNull() {
|
||||||
assertThat(mImpl.getChargingOptimizationRemainingLabel(mContext, 1000L, 1000L)).isNull();
|
assertThat(
|
||||||
|
mImpl.getChargingOptimizationRemainingLabel(
|
||||||
|
mContext, 75, BatteryManager.BATTERY_PLUGGED_AC, 1000L, 1000L))
|
||||||
|
.isNull();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void getChargingOptimizationChargeLabel_default_returnNull() {
|
public void getChargingOptimizationChargeLabel_default_returnNull() {
|
||||||
assertThat(mImpl.getChargingOptimizationChargeLabel(mContext, "70%", 1000L, 1000L))
|
assertThat(mImpl.getChargingOptimizationChargeLabel(mContext, 70, "70%", 1000L, 1000L))
|
||||||
.isNull();
|
.isNull();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user