Merge "Refactor battery related feature provider" into udc-qpr-dev
This commit is contained in:
committed by
Android (Google) Code Review
commit
75af9aa3f5
@@ -32,6 +32,8 @@ import android.os.BatteryManager;
|
||||
|
||||
import androidx.test.core.app.ApplicationProvider;
|
||||
|
||||
import com.android.settings.R;
|
||||
|
||||
import org.junit.Before;
|
||||
import org.junit.Test;
|
||||
import org.junit.runner.RunWith;
|
||||
@@ -62,4 +64,13 @@ public class BatteryCycleCountPreferenceControllerTest {
|
||||
|
||||
assertThat(mController.getSummary()).isEqualTo("10");
|
||||
}
|
||||
|
||||
@Test
|
||||
public void getSummary_noValue_returnUnavailable() {
|
||||
final Intent batteryIntent = new Intent();
|
||||
doReturn(batteryIntent).when(mContext).registerReceiver(any(), any());
|
||||
|
||||
assertThat(mController.getSummary()).isEqualTo(
|
||||
mContext.getText(R.string.battery_cycle_count_not_available));
|
||||
}
|
||||
}
|
||||
|
@@ -50,14 +50,14 @@ public class BatteryFirstUseDatePreferenceControllerTest {
|
||||
|
||||
@Test
|
||||
public void getAvailabilityStatus_dateAvailable_returnAvailable() {
|
||||
when(mFactory.mBatteryInfoFeatureProvider.isFirstUseDateAvailable()).thenReturn(true);
|
||||
when(mFactory.batterySettingsFeatureProvider.isFirstUseDateAvailable()).thenReturn(true);
|
||||
|
||||
assertThat(mController.getAvailabilityStatus()).isEqualTo(AVAILABLE);
|
||||
}
|
||||
|
||||
@Test
|
||||
public void getAvailabilityStatus_dateUnavailable_returnNotAvailable() {
|
||||
when(mFactory.mBatteryInfoFeatureProvider.isFirstUseDateAvailable()).thenReturn(false);
|
||||
when(mFactory.batterySettingsFeatureProvider.isFirstUseDateAvailable()).thenReturn(false);
|
||||
|
||||
assertThat(mController.getAvailabilityStatus()).isEqualTo(CONDITIONALLY_UNAVAILABLE);
|
||||
}
|
||||
|
@@ -51,14 +51,15 @@ public class BatteryManufactureDatePreferenceControllerTest {
|
||||
|
||||
@Test
|
||||
public void getAvailabilityStatus_dateAvailable_returnAvailable() {
|
||||
when(mFactory.mBatteryInfoFeatureProvider.isManufactureDateAvailable()).thenReturn(true);
|
||||
when(mFactory.batterySettingsFeatureProvider.isManufactureDateAvailable()).thenReturn(true);
|
||||
|
||||
assertThat(mController.getAvailabilityStatus()).isEqualTo(AVAILABLE);
|
||||
}
|
||||
|
||||
@Test
|
||||
public void getAvailabilityStatus_dateUnavailable_returnNotAvailable() {
|
||||
when(mFactory.mBatteryInfoFeatureProvider.isManufactureDateAvailable()).thenReturn(false);
|
||||
when(mFactory.batterySettingsFeatureProvider.isManufactureDateAvailable())
|
||||
.thenReturn(false);
|
||||
|
||||
assertThat(mController.getAvailabilityStatus()).isEqualTo(CONDITIONALLY_UNAVAILABLE);
|
||||
}
|
||||
|
@@ -14,39 +14,42 @@
|
||||
* limitations under the License.
|
||||
*/
|
||||
|
||||
package com.android.settings.deviceinfo.batteryinfo;
|
||||
package com.android.settings.fuelgauge;
|
||||
|
||||
import static com.google.common.truth.Truth.assertThat;
|
||||
|
||||
import static org.mockito.Mockito.doReturn;
|
||||
import static org.mockito.Mockito.spy;
|
||||
import static org.mockito.Mockito.when;
|
||||
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.Test;
|
||||
import org.junit.runner.RunWith;
|
||||
import org.mockito.Mock;
|
||||
import org.mockito.MockitoAnnotations;
|
||||
import org.robolectric.RobolectricTestRunner;
|
||||
|
||||
import org.robolectric.annotation.Config;
|
||||
import org.robolectric.shadows.ShadowBatteryManager;
|
||||
|
||||
@RunWith(RobolectricTestRunner.class)
|
||||
public class BatteryInfoFeatureProviderImplTest {
|
||||
@Mock
|
||||
@Config(shadows = {ShadowBatteryManager.class})
|
||||
public class BatterySettingsFeatureProviderImplTest {
|
||||
private BatteryManager mBatteryManager;
|
||||
|
||||
private ShadowBatteryManager mShadowBatteryManager;
|
||||
private Context mContext;
|
||||
private BatteryInfoFeatureProviderImpl mImpl;
|
||||
private BatterySettingsFeatureProviderImpl mImpl;
|
||||
|
||||
@Before
|
||||
public void setUp() {
|
||||
MockitoAnnotations.initMocks(this);
|
||||
mContext = spy(org.robolectric.RuntimeEnvironment.application);
|
||||
doReturn(mBatteryManager).when(mContext).getSystemService(BatteryManager.class);
|
||||
mImpl = spy(new BatteryInfoFeatureProviderImpl(mContext));
|
||||
mContext = spy(ApplicationProvider.getApplicationContext());
|
||||
mBatteryManager = mContext.getSystemService(BatteryManager.class);
|
||||
mShadowBatteryManager = shadowOf(mBatteryManager);
|
||||
mImpl = spy(new BatterySettingsFeatureProviderImpl(mContext));
|
||||
}
|
||||
|
||||
@Test
|
||||
@@ -62,12 +65,12 @@ public class BatteryInfoFeatureProviderImplTest {
|
||||
@Test
|
||||
public void getManufactureDateSummary_available_returnExpectedDate() {
|
||||
doReturn(true).when(mImpl).isManufactureDateAvailable();
|
||||
when(mBatteryManager.getLongProperty(BatteryManager.BATTERY_PROPERTY_MANUFACTURING_DATE))
|
||||
.thenReturn(1669680000L);
|
||||
mShadowBatteryManager.setLongProperty(BatteryManager.BATTERY_PROPERTY_MANUFACTURING_DATE,
|
||||
1669680000L);
|
||||
|
||||
final CharSequence result = mImpl.getManufactureDateSummary();
|
||||
|
||||
assertThat(result).isEqualTo("November 29, 2022");
|
||||
assertThat(result.toString()).isEqualTo("November 29, 2022");
|
||||
}
|
||||
|
||||
@Test
|
||||
@@ -80,12 +83,12 @@ public class BatteryInfoFeatureProviderImplTest {
|
||||
@Test
|
||||
public void getFirstUseDateSummary_available_returnExpectedDate() {
|
||||
doReturn(true).when(mImpl).isFirstUseDateAvailable();
|
||||
when(mBatteryManager.getLongProperty(BatteryManager.BATTERY_PROPERTY_FIRST_USAGE_DATE))
|
||||
.thenReturn(1669680000L);
|
||||
mShadowBatteryManager.setLongProperty(BatteryManager.BATTERY_PROPERTY_FIRST_USAGE_DATE,
|
||||
1669680000L);
|
||||
|
||||
final CharSequence result = mImpl.getFirstUseDateSummary();
|
||||
|
||||
assertThat(result).isEqualTo("November 29, 2022");
|
||||
assertThat(result.toString()).isEqualTo("November 29, 2022");
|
||||
}
|
||||
|
||||
@Test
|
@@ -31,7 +31,6 @@ import com.android.settings.biometrics2.factory.BiometricsRepositoryProvider;
|
||||
import com.android.settings.bluetooth.BluetoothFeatureProvider;
|
||||
import com.android.settings.dashboard.DashboardFeatureProvider;
|
||||
import com.android.settings.dashboard.suggestions.SuggestionFeatureProvider;
|
||||
import com.android.settings.deviceinfo.batteryinfo.BatteryInfoFeatureProvider;
|
||||
import com.android.settings.enterprise.EnterprisePrivacyFeatureProvider;
|
||||
import com.android.settings.fuelgauge.BatterySettingsFeatureProvider;
|
||||
import com.android.settings.fuelgauge.BatteryStatusFeatureProvider;
|
||||
@@ -83,7 +82,6 @@ public class FakeFeatureFactory extends FeatureFactory {
|
||||
public final AwareFeatureProvider mAwareFeatureProvider;
|
||||
public final FaceFeatureProvider mFaceFeatureProvider;
|
||||
public final BiometricsRepositoryProvider mBiometricsRepositoryProvider;
|
||||
public final BatteryInfoFeatureProvider mBatteryInfoFeatureProvider;
|
||||
|
||||
public PanelFeatureProvider panelFeatureProvider;
|
||||
public SlicesFeatureProvider slicesFeatureProvider;
|
||||
@@ -150,7 +148,6 @@ public class FakeFeatureFactory extends FeatureFactory {
|
||||
mAdvancedVpnFeatureProvider = mock(AdvancedVpnFeatureProvider.class);
|
||||
mWifiFeatureProvider = mock(WifiFeatureProvider.class);
|
||||
mKeyboardSettingsFeatureProvider = mock(KeyboardSettingsFeatureProvider.class);
|
||||
mBatteryInfoFeatureProvider = mock(BatteryInfoFeatureProvider.class);
|
||||
}
|
||||
|
||||
@Override
|
||||
@@ -307,9 +304,4 @@ public class FakeFeatureFactory extends FeatureFactory {
|
||||
public KeyboardSettingsFeatureProvider getKeyboardSettingsFeatureProvider() {
|
||||
return mKeyboardSettingsFeatureProvider;
|
||||
}
|
||||
|
||||
@Override
|
||||
public BatteryInfoFeatureProvider getBatteryInfoFeatureProvider() {
|
||||
return mBatteryInfoFeatureProvider;
|
||||
}
|
||||
}
|
||||
|
Reference in New Issue
Block a user