Merge "Remove redundant methods and refactor" into udc-qpr-dev am: 55774422b1
am: 6fb7cb85fd
Original change: https://googleplex-android-review.googlesource.com/c/platform/packages/apps/Settings/+/23634999 Change-Id: I31ff110702752ffcd819e94106a1434963ef6e1f Signed-off-by: Automerger Merge Worker <android-build-automerger-merge-worker@system.gserviceaccount.com>
This commit is contained in:
@@ -17,32 +17,51 @@
|
|||||||
package com.android.settings.deviceinfo.batteryinfo;
|
package com.android.settings.deviceinfo.batteryinfo;
|
||||||
|
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
|
import android.os.BatteryManager;
|
||||||
|
|
||||||
import com.android.settings.core.BasePreferenceController;
|
import com.android.settings.core.BasePreferenceController;
|
||||||
import com.android.settings.fuelgauge.BatterySettingsFeatureProvider;
|
import com.android.settings.fuelgauge.BatterySettingsFeatureProvider;
|
||||||
|
import com.android.settings.fuelgauge.BatteryUtils;
|
||||||
import com.android.settings.overlay.FeatureFactory;
|
import com.android.settings.overlay.FeatureFactory;
|
||||||
|
|
||||||
|
import java.util.concurrent.TimeUnit;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* A controller that manages the information about battery first use date.
|
* A controller that manages the information about battery first use date.
|
||||||
*/
|
*/
|
||||||
public class BatteryFirstUseDatePreferenceController extends BasePreferenceController {
|
public class BatteryFirstUseDatePreferenceController extends BasePreferenceController {
|
||||||
|
|
||||||
private BatterySettingsFeatureProvider mBatterySettingsFeatureProvider;
|
private final BatterySettingsFeatureProvider mBatterySettingsFeatureProvider;
|
||||||
|
private final BatteryManager mBatteryManager;
|
||||||
|
|
||||||
|
private long mFirstUseDateInMs;
|
||||||
|
|
||||||
public BatteryFirstUseDatePreferenceController(Context context, String preferenceKey) {
|
public BatteryFirstUseDatePreferenceController(Context context, String preferenceKey) {
|
||||||
super(context, preferenceKey);
|
super(context, preferenceKey);
|
||||||
mBatterySettingsFeatureProvider = FeatureFactory.getFactory(
|
mBatterySettingsFeatureProvider = FeatureFactory.getFactory(
|
||||||
context).getBatterySettingsFeatureProvider(context);
|
context).getBatterySettingsFeatureProvider();
|
||||||
|
mBatteryManager = mContext.getSystemService(BatteryManager.class);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public int getAvailabilityStatus() {
|
public int getAvailabilityStatus() {
|
||||||
return mBatterySettingsFeatureProvider.isFirstUseDateAvailable()
|
return mBatterySettingsFeatureProvider.isFirstUseDateAvailable(getFirstUseDate())
|
||||||
? AVAILABLE : CONDITIONALLY_UNAVAILABLE;
|
? AVAILABLE : CONDITIONALLY_UNAVAILABLE;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public CharSequence getSummary() {
|
public CharSequence getSummary() {
|
||||||
return mBatterySettingsFeatureProvider.getFirstUseDateSummary();
|
return isAvailable()
|
||||||
|
? BatteryUtils.getBatteryInfoFormattedDate(mFirstUseDateInMs)
|
||||||
|
: null;
|
||||||
|
}
|
||||||
|
|
||||||
|
private long getFirstUseDate() {
|
||||||
|
if (mFirstUseDateInMs == 0L) {
|
||||||
|
final long firstUseDateInSec = mBatteryManager.getLongProperty(
|
||||||
|
BatteryManager.BATTERY_PROPERTY_FIRST_USAGE_DATE);
|
||||||
|
mFirstUseDateInMs = TimeUnit.MILLISECONDS.convert(firstUseDateInSec, TimeUnit.SECONDS);
|
||||||
|
}
|
||||||
|
return mFirstUseDateInMs;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@@ -17,32 +17,52 @@
|
|||||||
package com.android.settings.deviceinfo.batteryinfo;
|
package com.android.settings.deviceinfo.batteryinfo;
|
||||||
|
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
|
import android.os.BatteryManager;
|
||||||
|
|
||||||
import com.android.settings.core.BasePreferenceController;
|
import com.android.settings.core.BasePreferenceController;
|
||||||
import com.android.settings.fuelgauge.BatterySettingsFeatureProvider;
|
import com.android.settings.fuelgauge.BatterySettingsFeatureProvider;
|
||||||
|
import com.android.settings.fuelgauge.BatteryUtils;
|
||||||
import com.android.settings.overlay.FeatureFactory;
|
import com.android.settings.overlay.FeatureFactory;
|
||||||
|
|
||||||
|
import java.util.concurrent.TimeUnit;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* A controller that manages the information about battery manufacture date.
|
* A controller that manages the information about battery manufacture date.
|
||||||
*/
|
*/
|
||||||
public class BatteryManufactureDatePreferenceController extends BasePreferenceController {
|
public class BatteryManufactureDatePreferenceController extends BasePreferenceController {
|
||||||
|
|
||||||
private BatterySettingsFeatureProvider mBatterySettingsFeatureProvider;
|
private final BatterySettingsFeatureProvider mBatterySettingsFeatureProvider;
|
||||||
|
private final BatteryManager mBatteryManager;
|
||||||
|
|
||||||
|
private long mManufactureDateInMs;
|
||||||
|
|
||||||
public BatteryManufactureDatePreferenceController(Context context, String preferenceKey) {
|
public BatteryManufactureDatePreferenceController(Context context, String preferenceKey) {
|
||||||
super(context, preferenceKey);
|
super(context, preferenceKey);
|
||||||
mBatterySettingsFeatureProvider = FeatureFactory.getFactory(
|
mBatterySettingsFeatureProvider = FeatureFactory.getFactory(
|
||||||
context).getBatterySettingsFeatureProvider(context);
|
context).getBatterySettingsFeatureProvider();
|
||||||
|
mBatteryManager = mContext.getSystemService(BatteryManager.class);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public int getAvailabilityStatus() {
|
public int getAvailabilityStatus() {
|
||||||
return mBatterySettingsFeatureProvider.isManufactureDateAvailable()
|
return mBatterySettingsFeatureProvider.isManufactureDateAvailable(getManufactureDate())
|
||||||
? AVAILABLE : CONDITIONALLY_UNAVAILABLE;
|
? AVAILABLE : CONDITIONALLY_UNAVAILABLE;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public CharSequence getSummary() {
|
public CharSequence getSummary() {
|
||||||
return mBatterySettingsFeatureProvider.getManufactureDateSummary();
|
return isAvailable()
|
||||||
|
? BatteryUtils.getBatteryInfoFormattedDate(mManufactureDateInMs)
|
||||||
|
: null;
|
||||||
|
}
|
||||||
|
|
||||||
|
private long getManufactureDate() {
|
||||||
|
if (mManufactureDateInMs == 0L) {
|
||||||
|
final long manufactureDateInSec = mBatteryManager.getLongProperty(
|
||||||
|
BatteryManager.BATTERY_PROPERTY_MANUFACTURING_DATE);
|
||||||
|
mManufactureDateInMs = TimeUnit.MILLISECONDS.convert(manufactureDateInSec,
|
||||||
|
TimeUnit.SECONDS);
|
||||||
|
}
|
||||||
|
return mManufactureDateInMs;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@@ -20,15 +20,8 @@ package com.android.settings.fuelgauge;
|
|||||||
public interface BatterySettingsFeatureProvider {
|
public interface BatterySettingsFeatureProvider {
|
||||||
|
|
||||||
/** Returns true if manufacture date should be shown */
|
/** Returns true if manufacture date should be shown */
|
||||||
boolean isManufactureDateAvailable();
|
boolean isManufactureDateAvailable(long manufactureDateMs);
|
||||||
|
|
||||||
/** Returns true if first use date should be shown */
|
/** Returns true if first use date should be shown */
|
||||||
boolean isFirstUseDateAvailable();
|
boolean isFirstUseDateAvailable(long firstUseDateMs);
|
||||||
|
|
||||||
/** Returns the summary of battery manufacture date */
|
|
||||||
CharSequence getManufactureDateSummary();
|
|
||||||
|
|
||||||
/** Returns the summary of battery first use date */
|
|
||||||
CharSequence getFirstUseDateSummary();
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@@ -16,77 +16,16 @@
|
|||||||
|
|
||||||
package com.android.settings.fuelgauge;
|
package com.android.settings.fuelgauge;
|
||||||
|
|
||||||
import android.content.Context;
|
|
||||||
import android.os.BatteryManager;
|
|
||||||
|
|
||||||
import java.time.Instant;
|
|
||||||
import java.time.ZoneId;
|
|
||||||
import java.time.format.DateTimeFormatter;
|
|
||||||
import java.time.format.FormatStyle;
|
|
||||||
import java.util.concurrent.TimeUnit;
|
|
||||||
|
|
||||||
/** Feature provider implementation for battery settings usage. */
|
/** Feature provider implementation for battery settings usage. */
|
||||||
public class BatterySettingsFeatureProviderImpl implements BatterySettingsFeatureProvider {
|
public class BatterySettingsFeatureProviderImpl implements BatterySettingsFeatureProvider {
|
||||||
|
|
||||||
protected Context mContext;
|
|
||||||
|
|
||||||
private BatteryManager mBatteryManager;
|
|
||||||
private long mManufactureDateInMs;
|
|
||||||
private long mFirstUseDateInMs;
|
|
||||||
|
|
||||||
public BatterySettingsFeatureProviderImpl(Context context) {
|
|
||||||
mContext = context.getApplicationContext();
|
|
||||||
mBatteryManager = mContext.getSystemService(BatteryManager.class);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean isManufactureDateAvailable() {
|
public boolean isManufactureDateAvailable(long manufactureDateMs) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean isFirstUseDateAvailable() {
|
public boolean isFirstUseDateAvailable(long firstUseDateMs) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
|
||||||
public CharSequence getManufactureDateSummary() {
|
|
||||||
return isManufactureDateAvailable()
|
|
||||||
? getFormattedDate(getManufactureDate())
|
|
||||||
: null;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public CharSequence getFirstUseDateSummary() {
|
|
||||||
return isFirstUseDateAvailable()
|
|
||||||
? getFormattedDate(getFirstUseDate())
|
|
||||||
: null;
|
|
||||||
}
|
|
||||||
|
|
||||||
protected long getManufactureDate() {
|
|
||||||
if (mManufactureDateInMs == 0L) {
|
|
||||||
final long manufactureDateInSec = mBatteryManager.getLongProperty(
|
|
||||||
BatteryManager.BATTERY_PROPERTY_MANUFACTURING_DATE);
|
|
||||||
mManufactureDateInMs = TimeUnit.MILLISECONDS.convert(manufactureDateInSec,
|
|
||||||
TimeUnit.SECONDS);
|
|
||||||
}
|
|
||||||
return mManufactureDateInMs;
|
|
||||||
}
|
|
||||||
|
|
||||||
protected long getFirstUseDate() {
|
|
||||||
if (mFirstUseDateInMs == 0L) {
|
|
||||||
final long firstUseDateInSec = mBatteryManager.getLongProperty(
|
|
||||||
BatteryManager.BATTERY_PROPERTY_FIRST_USAGE_DATE);
|
|
||||||
mFirstUseDateInMs = TimeUnit.MILLISECONDS.convert(firstUseDateInSec, TimeUnit.SECONDS);
|
|
||||||
}
|
|
||||||
return mFirstUseDateInMs;
|
|
||||||
}
|
|
||||||
|
|
||||||
private CharSequence getFormattedDate(long dateInMs) {
|
|
||||||
final Instant instant = Instant.ofEpochMilli(dateInMs);
|
|
||||||
final String localDate = instant.atZone(ZoneId.systemDefault()).toLocalDate().format(
|
|
||||||
DateTimeFormatter.ofLocalizedDate(FormatStyle.LONG));
|
|
||||||
|
|
||||||
return localDate;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
@@ -64,8 +64,10 @@ import com.google.protobuf.MessageLite;
|
|||||||
|
|
||||||
import java.lang.annotation.Retention;
|
import java.lang.annotation.Retention;
|
||||||
import java.lang.annotation.RetentionPolicy;
|
import java.lang.annotation.RetentionPolicy;
|
||||||
import java.time.Duration;
|
|
||||||
import java.time.Instant;
|
import java.time.Instant;
|
||||||
|
import java.time.ZoneId;
|
||||||
|
import java.time.format.DateTimeFormatter;
|
||||||
|
import java.time.format.FormatStyle;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -671,6 +673,14 @@ public class BatteryUtils {
|
|||||||
}
|
}
|
||||||
return summary.toString();
|
return summary.toString();
|
||||||
}
|
}
|
||||||
|
/** Format the date of battery related info */
|
||||||
|
public static CharSequence getBatteryInfoFormattedDate(long dateInMs) {
|
||||||
|
final Instant instant = Instant.ofEpochMilli(dateInMs);
|
||||||
|
final String localDate = instant.atZone(ZoneId.systemDefault()).toLocalDate().format(
|
||||||
|
DateTimeFormatter.ofLocalizedDate(FormatStyle.LONG));
|
||||||
|
|
||||||
|
return localDate;
|
||||||
|
}
|
||||||
|
|
||||||
/** Builds the battery usage time information for one timestamp. */
|
/** Builds the battery usage time information for one timestamp. */
|
||||||
private static String buildBatteryUsageTimeInfo(final Context context, long timeInMs,
|
private static String buildBatteryUsageTimeInfo(final Context context, long timeInMs,
|
||||||
|
@@ -136,8 +136,7 @@ public abstract class FeatureFactory {
|
|||||||
/**
|
/**
|
||||||
* Gets implementation for Battery Settings provider.
|
* Gets implementation for Battery Settings provider.
|
||||||
*/
|
*/
|
||||||
public abstract BatterySettingsFeatureProvider getBatterySettingsFeatureProvider(
|
public abstract BatterySettingsFeatureProvider getBatterySettingsFeatureProvider();
|
||||||
Context context);
|
|
||||||
|
|
||||||
public abstract DashboardFeatureProvider getDashboardFeatureProvider(Context context);
|
public abstract DashboardFeatureProvider getDashboardFeatureProvider(Context context);
|
||||||
|
|
||||||
|
@@ -150,9 +150,9 @@ public class FeatureFactoryImpl extends FeatureFactory {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public BatterySettingsFeatureProvider getBatterySettingsFeatureProvider(Context context) {
|
public BatterySettingsFeatureProvider getBatterySettingsFeatureProvider() {
|
||||||
if (mBatterySettingsFeatureProvider == null) {
|
if (mBatterySettingsFeatureProvider == null) {
|
||||||
mBatterySettingsFeatureProvider = new BatterySettingsFeatureProviderImpl(context);
|
mBatterySettingsFeatureProvider = new BatterySettingsFeatureProviderImpl();
|
||||||
}
|
}
|
||||||
return mBatterySettingsFeatureProvider;
|
return mBatterySettingsFeatureProvider;
|
||||||
}
|
}
|
||||||
|
@@ -21,9 +21,12 @@ import static com.android.settings.core.BasePreferenceController.CONDITIONALLY_U
|
|||||||
|
|
||||||
import static com.google.common.truth.Truth.assertThat;
|
import static com.google.common.truth.Truth.assertThat;
|
||||||
|
|
||||||
|
import static org.mockito.ArgumentMatchers.anyLong;
|
||||||
import static org.mockito.Mockito.when;
|
import static org.mockito.Mockito.when;
|
||||||
|
import static org.robolectric.Shadows.shadowOf;
|
||||||
|
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
|
import android.os.BatteryManager;
|
||||||
|
|
||||||
import androidx.test.core.app.ApplicationProvider;
|
import androidx.test.core.app.ApplicationProvider;
|
||||||
|
|
||||||
@@ -33,16 +36,23 @@ import org.junit.Before;
|
|||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
import org.junit.runner.RunWith;
|
import org.junit.runner.RunWith;
|
||||||
import org.robolectric.RobolectricTestRunner;
|
import org.robolectric.RobolectricTestRunner;
|
||||||
|
import org.robolectric.annotation.Config;
|
||||||
|
import org.robolectric.shadows.ShadowBatteryManager;
|
||||||
|
|
||||||
@RunWith(RobolectricTestRunner.class)
|
@RunWith(RobolectricTestRunner.class)
|
||||||
|
@Config(shadows = {ShadowBatteryManager.class})
|
||||||
public class BatteryFirstUseDatePreferenceControllerTest {
|
public class BatteryFirstUseDatePreferenceControllerTest {
|
||||||
private BatteryFirstUseDatePreferenceController mController;
|
private BatteryFirstUseDatePreferenceController mController;
|
||||||
private Context mContext;
|
private Context mContext;
|
||||||
|
private BatteryManager mBatteryManager;
|
||||||
|
private ShadowBatteryManager mShadowBatteryManager;
|
||||||
private FakeFeatureFactory mFactory;
|
private FakeFeatureFactory mFactory;
|
||||||
|
|
||||||
@Before
|
@Before
|
||||||
public void setUp() {
|
public void setUp() {
|
||||||
mContext = ApplicationProvider.getApplicationContext();
|
mContext = ApplicationProvider.getApplicationContext();
|
||||||
|
mBatteryManager = mContext.getSystemService(BatteryManager.class);
|
||||||
|
mShadowBatteryManager = shadowOf(mBatteryManager);
|
||||||
mFactory = FakeFeatureFactory.setupForTest();
|
mFactory = FakeFeatureFactory.setupForTest();
|
||||||
mController = new BatteryFirstUseDatePreferenceController(mContext,
|
mController = new BatteryFirstUseDatePreferenceController(mContext,
|
||||||
"battery_info_first_use_date");
|
"battery_info_first_use_date");
|
||||||
@@ -50,15 +60,37 @@ public class BatteryFirstUseDatePreferenceControllerTest {
|
|||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void getAvailabilityStatus_dateAvailable_returnAvailable() {
|
public void getAvailabilityStatus_dateAvailable_returnAvailable() {
|
||||||
when(mFactory.batterySettingsFeatureProvider.isFirstUseDateAvailable()).thenReturn(true);
|
when(mFactory.batterySettingsFeatureProvider.isFirstUseDateAvailable(anyLong()))
|
||||||
|
.thenReturn(true);
|
||||||
|
|
||||||
assertThat(mController.getAvailabilityStatus()).isEqualTo(AVAILABLE);
|
assertThat(mController.getAvailabilityStatus()).isEqualTo(AVAILABLE);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void getAvailabilityStatus_dateUnavailable_returnNotAvailable() {
|
public void getAvailabilityStatus_dateUnavailable_returnNotAvailable() {
|
||||||
when(mFactory.batterySettingsFeatureProvider.isFirstUseDateAvailable()).thenReturn(false);
|
when(mFactory.batterySettingsFeatureProvider.isFirstUseDateAvailable(anyLong()))
|
||||||
|
.thenReturn(false);
|
||||||
|
|
||||||
assertThat(mController.getAvailabilityStatus()).isEqualTo(CONDITIONALLY_UNAVAILABLE);
|
assertThat(mController.getAvailabilityStatus()).isEqualTo(CONDITIONALLY_UNAVAILABLE);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void getSummary_available_returnExpectedDate() {
|
||||||
|
when(mFactory.batterySettingsFeatureProvider.isFirstUseDateAvailable(anyLong()))
|
||||||
|
.thenReturn(true);
|
||||||
|
mShadowBatteryManager.setLongProperty(BatteryManager.BATTERY_PROPERTY_FIRST_USAGE_DATE,
|
||||||
|
1669680000L);
|
||||||
|
|
||||||
|
final CharSequence result = mController.getSummary();
|
||||||
|
|
||||||
|
assertThat(result.toString()).isEqualTo("November 29, 2022");
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void getSummary_unavailable_returnNull() {
|
||||||
|
when(mFactory.batterySettingsFeatureProvider.isFirstUseDateAvailable(anyLong()))
|
||||||
|
.thenReturn(false);
|
||||||
|
|
||||||
|
assertThat(mController.getSummary()).isNull();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@@ -21,9 +21,12 @@ import static com.android.settings.core.BasePreferenceController.CONDITIONALLY_U
|
|||||||
|
|
||||||
import static com.google.common.truth.Truth.assertThat;
|
import static com.google.common.truth.Truth.assertThat;
|
||||||
|
|
||||||
|
import static org.mockito.ArgumentMatchers.anyLong;
|
||||||
import static org.mockito.Mockito.when;
|
import static org.mockito.Mockito.when;
|
||||||
|
import static org.robolectric.Shadows.shadowOf;
|
||||||
|
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
|
import android.os.BatteryManager;
|
||||||
|
|
||||||
import androidx.test.core.app.ApplicationProvider;
|
import androidx.test.core.app.ApplicationProvider;
|
||||||
|
|
||||||
@@ -33,17 +36,24 @@ import org.junit.Before;
|
|||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
import org.junit.runner.RunWith;
|
import org.junit.runner.RunWith;
|
||||||
import org.robolectric.RobolectricTestRunner;
|
import org.robolectric.RobolectricTestRunner;
|
||||||
|
import org.robolectric.annotation.Config;
|
||||||
|
import org.robolectric.shadows.ShadowBatteryManager;
|
||||||
|
|
||||||
@RunWith(RobolectricTestRunner.class)
|
@RunWith(RobolectricTestRunner.class)
|
||||||
|
@Config(shadows = {ShadowBatteryManager.class})
|
||||||
public class BatteryManufactureDatePreferenceControllerTest {
|
public class BatteryManufactureDatePreferenceControllerTest {
|
||||||
|
|
||||||
private BatteryManufactureDatePreferenceController mController;
|
private BatteryManufactureDatePreferenceController mController;
|
||||||
private Context mContext;
|
private Context mContext;
|
||||||
|
private BatteryManager mBatteryManager;
|
||||||
|
private ShadowBatteryManager mShadowBatteryManager;
|
||||||
private FakeFeatureFactory mFactory;
|
private FakeFeatureFactory mFactory;
|
||||||
|
|
||||||
@Before
|
@Before
|
||||||
public void setUp() {
|
public void setUp() {
|
||||||
mContext = ApplicationProvider.getApplicationContext();
|
mContext = ApplicationProvider.getApplicationContext();
|
||||||
|
mBatteryManager = mContext.getSystemService(BatteryManager.class);
|
||||||
|
mShadowBatteryManager = shadowOf(mBatteryManager);
|
||||||
mFactory = FakeFeatureFactory.setupForTest();
|
mFactory = FakeFeatureFactory.setupForTest();
|
||||||
mController = new BatteryManufactureDatePreferenceController(mContext,
|
mController = new BatteryManufactureDatePreferenceController(mContext,
|
||||||
"battery_info_manufacture_date");
|
"battery_info_manufacture_date");
|
||||||
@@ -51,16 +61,37 @@ public class BatteryManufactureDatePreferenceControllerTest {
|
|||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void getAvailabilityStatus_dateAvailable_returnAvailable() {
|
public void getAvailabilityStatus_dateAvailable_returnAvailable() {
|
||||||
when(mFactory.batterySettingsFeatureProvider.isManufactureDateAvailable()).thenReturn(true);
|
when(mFactory.batterySettingsFeatureProvider.isManufactureDateAvailable(
|
||||||
|
anyLong())).thenReturn(true);
|
||||||
|
|
||||||
assertThat(mController.getAvailabilityStatus()).isEqualTo(AVAILABLE);
|
assertThat(mController.getAvailabilityStatus()).isEqualTo(AVAILABLE);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void getAvailabilityStatus_dateUnavailable_returnNotAvailable() {
|
public void getAvailabilityStatus_dateUnavailable_returnNotAvailable() {
|
||||||
when(mFactory.batterySettingsFeatureProvider.isManufactureDateAvailable())
|
when(mFactory.batterySettingsFeatureProvider.isManufactureDateAvailable(anyLong()))
|
||||||
.thenReturn(false);
|
.thenReturn(false);
|
||||||
|
|
||||||
assertThat(mController.getAvailabilityStatus()).isEqualTo(CONDITIONALLY_UNAVAILABLE);
|
assertThat(mController.getAvailabilityStatus()).isEqualTo(CONDITIONALLY_UNAVAILABLE);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void getSummary_available_returnExpectedDate() {
|
||||||
|
when(mFactory.batterySettingsFeatureProvider.isManufactureDateAvailable(
|
||||||
|
anyLong())).thenReturn(true);
|
||||||
|
mShadowBatteryManager.setLongProperty(BatteryManager.BATTERY_PROPERTY_MANUFACTURING_DATE,
|
||||||
|
1669680000L);
|
||||||
|
|
||||||
|
final CharSequence result = mController.getSummary();
|
||||||
|
|
||||||
|
assertThat(result.toString()).isEqualTo("November 29, 2022");
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void getSummary_unavailable_returnNull() {
|
||||||
|
when(mFactory.batterySettingsFeatureProvider.isManufactureDateAvailable(anyLong()))
|
||||||
|
.thenReturn(false);
|
||||||
|
|
||||||
|
assertThat(mController.getSummary()).isNull();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@@ -18,83 +18,29 @@ 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.Mockito.doReturn;
|
import static org.mockito.ArgumentMatchers.anyLong;
|
||||||
import static org.mockito.Mockito.spy;
|
|
||||||
import static org.robolectric.Shadows.shadowOf;
|
|
||||||
|
|
||||||
import android.content.Context;
|
|
||||||
import android.os.BatteryManager;
|
|
||||||
|
|
||||||
import androidx.test.core.app.ApplicationProvider;
|
|
||||||
|
|
||||||
import org.junit.Before;
|
import org.junit.Before;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
import org.junit.runner.RunWith;
|
import org.junit.runner.RunWith;
|
||||||
import org.mockito.MockitoAnnotations;
|
|
||||||
import org.robolectric.RobolectricTestRunner;
|
import org.robolectric.RobolectricTestRunner;
|
||||||
import org.robolectric.annotation.Config;
|
|
||||||
import org.robolectric.shadows.ShadowBatteryManager;
|
|
||||||
|
|
||||||
@RunWith(RobolectricTestRunner.class)
|
@RunWith(RobolectricTestRunner.class)
|
||||||
@Config(shadows = {ShadowBatteryManager.class})
|
|
||||||
public class BatterySettingsFeatureProviderImplTest {
|
public class BatterySettingsFeatureProviderImplTest {
|
||||||
private BatteryManager mBatteryManager;
|
|
||||||
private ShadowBatteryManager mShadowBatteryManager;
|
|
||||||
private Context mContext;
|
|
||||||
private BatterySettingsFeatureProviderImpl mImpl;
|
private BatterySettingsFeatureProviderImpl mImpl;
|
||||||
|
|
||||||
@Before
|
@Before
|
||||||
public void setUp() {
|
public void setUp() {
|
||||||
MockitoAnnotations.initMocks(this);
|
mImpl = new BatterySettingsFeatureProviderImpl();
|
||||||
mContext = spy(ApplicationProvider.getApplicationContext());
|
|
||||||
mBatteryManager = mContext.getSystemService(BatteryManager.class);
|
|
||||||
mShadowBatteryManager = shadowOf(mBatteryManager);
|
|
||||||
mImpl = spy(new BatterySettingsFeatureProviderImpl(mContext));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void isManufactureDateAvailable_returnFalse() {
|
public void isManufactureDateAvailable_returnFalse() {
|
||||||
assertThat(mImpl.isManufactureDateAvailable()).isFalse();
|
assertThat(mImpl.isManufactureDateAvailable(anyLong())).isFalse();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void isFirstUseDateAvailable_returnFalse() {
|
public void isFirstUseDateAvailable_returnFalse() {
|
||||||
assertThat(mImpl.isFirstUseDateAvailable()).isFalse();
|
assertThat(mImpl.isFirstUseDateAvailable(anyLong())).isFalse();
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void getManufactureDateSummary_available_returnExpectedDate() {
|
|
||||||
doReturn(true).when(mImpl).isManufactureDateAvailable();
|
|
||||||
mShadowBatteryManager.setLongProperty(BatteryManager.BATTERY_PROPERTY_MANUFACTURING_DATE,
|
|
||||||
1669680000L);
|
|
||||||
|
|
||||||
final CharSequence result = mImpl.getManufactureDateSummary();
|
|
||||||
|
|
||||||
assertThat(result.toString()).isEqualTo("November 29, 2022");
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void getManufactureDateSummary_unavailable_returnNull() {
|
|
||||||
doReturn(false).when(mImpl).isManufactureDateAvailable();
|
|
||||||
|
|
||||||
assertThat(mImpl.getManufactureDateSummary()).isNull();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void getFirstUseDateSummary_available_returnExpectedDate() {
|
|
||||||
doReturn(true).when(mImpl).isFirstUseDateAvailable();
|
|
||||||
mShadowBatteryManager.setLongProperty(BatteryManager.BATTERY_PROPERTY_FIRST_USAGE_DATE,
|
|
||||||
1669680000L);
|
|
||||||
|
|
||||||
final CharSequence result = mImpl.getFirstUseDateSummary();
|
|
||||||
|
|
||||||
assertThat(result.toString()).isEqualTo("November 29, 2022");
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void getFirstUseDateSummary_unavailable_returnNull() {
|
|
||||||
doReturn(false).when(mImpl).isFirstUseDateAvailable();
|
|
||||||
|
|
||||||
assertThat(mImpl.getFirstUseDateSummary()).isNull();
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@@ -171,7 +171,7 @@ public class FakeFeatureFactory extends FeatureFactory {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public BatterySettingsFeatureProvider getBatterySettingsFeatureProvider(Context context) {
|
public BatterySettingsFeatureProvider getBatterySettingsFeatureProvider() {
|
||||||
return batterySettingsFeatureProvider;
|
return batterySettingsFeatureProvider;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@@ -84,9 +84,7 @@ class FakeFeatureFactory : FeatureFactory() {
|
|||||||
TODO("Not yet implemented")
|
TODO("Not yet implemented")
|
||||||
}
|
}
|
||||||
|
|
||||||
override fun getBatterySettingsFeatureProvider(
|
override fun getBatterySettingsFeatureProvider(): BatterySettingsFeatureProvider {
|
||||||
context: Context?,
|
|
||||||
): BatterySettingsFeatureProvider {
|
|
||||||
TODO("Not yet implemented")
|
TODO("Not yet implemented")
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@@ -157,7 +157,7 @@ public class FakeFeatureFactory extends FeatureFactory {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public BatterySettingsFeatureProvider getBatterySettingsFeatureProvider(Context context) {
|
public BatterySettingsFeatureProvider getBatterySettingsFeatureProvider() {
|
||||||
return batterySettingsFeatureProvider;
|
return batterySettingsFeatureProvider;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user