Snap for 12052458 from 8d5d69d62f to 24Q4-release
Change-Id: I592160fe66e9951db31d00ec1c81c5dab89891f8
This commit is contained in:
@@ -235,9 +235,6 @@
|
|||||||
Can be overridden for specific product builds if the target device does not support it -->
|
Can be overridden for specific product builds if the target device does not support it -->
|
||||||
<bool name="config_media_vibration_supported">true</bool>
|
<bool name="config_media_vibration_supported">true</bool>
|
||||||
|
|
||||||
<!-- Whether to show Keyboard vibration settings in the vibration and haptics screen. -->
|
|
||||||
<bool name="config_keyboard_vibration_supported">false</bool>
|
|
||||||
|
|
||||||
<!--
|
<!--
|
||||||
Whether or not the homepage should be powered by legacy suggestion (versus contextual cards)
|
Whether or not the homepage should be powered by legacy suggestion (versus contextual cards)
|
||||||
Default to true as not all devices support contextual cards.
|
Default to true as not all devices support contextual cards.
|
||||||
|
|||||||
@@ -111,9 +111,8 @@ public class KeyboardVibrationTogglePreferenceController extends TogglePreferenc
|
|||||||
@Override
|
@Override
|
||||||
public int getAvailabilityStatus() {
|
public int getAvailabilityStatus() {
|
||||||
if (Flags.keyboardCategoryEnabled()
|
if (Flags.keyboardCategoryEnabled()
|
||||||
&& mContext.getResources().getBoolean(R.bool.config_keyboard_vibration_supported)
|
&& mContext.getResources().getBoolean(
|
||||||
&& mContext.getResources().getFloat(
|
com.android.internal.R.bool.config_keyboardVibrationSettingsSupported)) {
|
||||||
com.android.internal.R.dimen.config_keyboardHapticFeedbackFixedAmplitude) > 0) {
|
|
||||||
return AVAILABLE;
|
return AVAILABLE;
|
||||||
}
|
}
|
||||||
return UNSUPPORTED_ON_DEVICE;
|
return UNSUPPORTED_ON_DEVICE;
|
||||||
|
|||||||
@@ -166,6 +166,9 @@ public interface PowerUsageFeatureProvider {
|
|||||||
/** Whether the device is under the battery defender mode */
|
/** Whether the device is under the battery defender mode */
|
||||||
boolean isBatteryDefend(BatteryInfo info);
|
boolean isBatteryDefend(BatteryInfo info);
|
||||||
|
|
||||||
|
/** Whether the battery usage reattribute is eabled or not. */
|
||||||
|
boolean isBatteryUsageReattributeEnabled();
|
||||||
|
|
||||||
/** Collect and process battery reattribute data if needed. */
|
/** Collect and process battery reattribute data if needed. */
|
||||||
boolean processBatteryReattributeData(
|
boolean processBatteryReattributeData(
|
||||||
@NonNull Context context,
|
@NonNull Context context,
|
||||||
|
|||||||
@@ -256,6 +256,11 @@ public class PowerUsageFeatureProviderImpl implements PowerUsageFeatureProvider
|
|||||||
return info.isLongLife && !isExtraDefend();
|
return info.isLongLife && !isExtraDefend();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean isBatteryUsageReattributeEnabled() {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean processBatteryReattributeData(
|
public boolean processBatteryReattributeData(
|
||||||
@NonNull Context context,
|
@NonNull Context context,
|
||||||
|
|||||||
@@ -38,6 +38,7 @@ import com.android.settings.fuelgauge.batteryusage.db.BatteryStateDao;
|
|||||||
import com.android.settings.fuelgauge.batteryusage.db.BatteryStateDatabase;
|
import com.android.settings.fuelgauge.batteryusage.db.BatteryStateDatabase;
|
||||||
import com.android.settings.fuelgauge.batteryusage.db.BatteryUsageSlotDao;
|
import com.android.settings.fuelgauge.batteryusage.db.BatteryUsageSlotDao;
|
||||||
import com.android.settings.fuelgauge.batteryusage.db.BatteryUsageSlotEntity;
|
import com.android.settings.fuelgauge.batteryusage.db.BatteryUsageSlotEntity;
|
||||||
|
import com.android.settings.overlay.FeatureFactory;
|
||||||
|
|
||||||
import java.io.PrintWriter;
|
import java.io.PrintWriter;
|
||||||
import java.time.Clock;
|
import java.time.Clock;
|
||||||
@@ -132,14 +133,23 @@ public final class LogUtils {
|
|||||||
}
|
}
|
||||||
|
|
||||||
static void dumpBatteryReattributeDatabaseHist(Context context, PrintWriter writer) {
|
static void dumpBatteryReattributeDatabaseHist(Context context, PrintWriter writer) {
|
||||||
|
try {
|
||||||
dumpBatteryReattributeDatabaseHist(
|
dumpBatteryReattributeDatabaseHist(
|
||||||
BatteryStateDatabase.getInstance(context).batteryReattributeDao(),
|
BatteryStateDatabase.getInstance(context).batteryReattributeDao(),
|
||||||
writer);
|
writer);
|
||||||
|
} catch (Exception e) {
|
||||||
|
Log.e(TAG, "failed to run dumpBatteryReattributeDatabaseHist()", e);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@VisibleForTesting
|
@VisibleForTesting
|
||||||
static void dumpBatteryReattributeDatabaseHist(
|
static void dumpBatteryReattributeDatabaseHist(
|
||||||
BatteryReattributeDao batteryReattributeDao, PrintWriter writer) {
|
BatteryReattributeDao batteryReattributeDao, PrintWriter writer) {
|
||||||
|
if (!FeatureFactory.getFeatureFactory().getPowerUsageFeatureProvider()
|
||||||
|
.isBatteryUsageReattributeEnabled()) {
|
||||||
|
writer.println("\n\tBatteryReattribute is disabled!");
|
||||||
|
return;
|
||||||
|
}
|
||||||
writer.println("\n\tBatteryReattribute DatabaseHistory:");
|
writer.println("\n\tBatteryReattribute DatabaseHistory:");
|
||||||
final List<BatteryReattributeEntity> entities =
|
final List<BatteryReattributeEntity> entities =
|
||||||
batteryReattributeDao.getAllAfter(
|
batteryReattributeDao.getAllAfter(
|
||||||
|
|||||||
@@ -88,10 +88,9 @@ public class KeyboardVibrationTogglePreferenceControllerTest {
|
|||||||
@Test
|
@Test
|
||||||
public void getAvailabilityStatus_featureSupported_available() {
|
public void getAvailabilityStatus_featureSupported_available() {
|
||||||
mSetFlagsRule.enableFlags(Flags.FLAG_KEYBOARD_CATEGORY_ENABLED);
|
mSetFlagsRule.enableFlags(Flags.FLAG_KEYBOARD_CATEGORY_ENABLED);
|
||||||
when(mResources.getBoolean(R.bool.config_keyboard_vibration_supported)).thenReturn(true);
|
when(mResources.getBoolean(
|
||||||
when(mResources.getFloat(
|
com.android.internal.R.bool.config_keyboardVibrationSettingsSupported))
|
||||||
com.android.internal.R.dimen.config_keyboardHapticFeedbackFixedAmplitude))
|
.thenReturn(true);
|
||||||
.thenReturn(0.8f);
|
|
||||||
|
|
||||||
assertThat(mController.getAvailabilityStatus()).isEqualTo(AVAILABLE);
|
assertThat(mController.getAvailabilityStatus()).isEqualTo(AVAILABLE);
|
||||||
}
|
}
|
||||||
@@ -99,7 +98,9 @@ public class KeyboardVibrationTogglePreferenceControllerTest {
|
|||||||
@Test
|
@Test
|
||||||
public void getAvailabilityStatus_featureNotSupported_unavailable() {
|
public void getAvailabilityStatus_featureNotSupported_unavailable() {
|
||||||
mSetFlagsRule.enableFlags(Flags.FLAG_KEYBOARD_CATEGORY_ENABLED);
|
mSetFlagsRule.enableFlags(Flags.FLAG_KEYBOARD_CATEGORY_ENABLED);
|
||||||
when(mResources.getBoolean(R.bool.config_keyboard_vibration_supported)).thenReturn(false);
|
when(mResources.getBoolean(
|
||||||
|
com.android.internal.R.bool.config_keyboardVibrationSettingsSupported))
|
||||||
|
.thenReturn(false);
|
||||||
|
|
||||||
assertThat(mController.getAvailabilityStatus()).isEqualTo(UNSUPPORTED_ON_DEVICE);
|
assertThat(mController.getAvailabilityStatus()).isEqualTo(UNSUPPORTED_ON_DEVICE);
|
||||||
}
|
}
|
||||||
@@ -107,7 +108,9 @@ public class KeyboardVibrationTogglePreferenceControllerTest {
|
|||||||
@Test
|
@Test
|
||||||
public void getAvailabilityStatus_keyboardCategoryDisabled_unavailable() {
|
public void getAvailabilityStatus_keyboardCategoryDisabled_unavailable() {
|
||||||
mSetFlagsRule.disableFlags(Flags.FLAG_KEYBOARD_CATEGORY_ENABLED);
|
mSetFlagsRule.disableFlags(Flags.FLAG_KEYBOARD_CATEGORY_ENABLED);
|
||||||
when(mResources.getBoolean(R.bool.config_keyboard_vibration_supported)).thenReturn(true);
|
when(mResources.getBoolean(
|
||||||
|
com.android.internal.R.bool.config_keyboardVibrationSettingsSupported))
|
||||||
|
.thenReturn(true);
|
||||||
|
|
||||||
assertThat(mController.getAvailabilityStatus()).isEqualTo(UNSUPPORTED_ON_DEVICE);
|
assertThat(mController.getAvailabilityStatus()).isEqualTo(UNSUPPORTED_ON_DEVICE);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -18,15 +18,19 @@ package com.android.settings.fuelgauge.batteryusage.bugreport;
|
|||||||
|
|
||||||
import static com.google.common.truth.Truth.assertThat;
|
import static com.google.common.truth.Truth.assertThat;
|
||||||
|
|
||||||
|
import static org.mockito.Mockito.when;
|
||||||
|
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
|
|
||||||
import androidx.test.core.app.ApplicationProvider;
|
import androidx.test.core.app.ApplicationProvider;
|
||||||
|
|
||||||
|
import com.android.settings.fuelgauge.PowerUsageFeatureProvider;
|
||||||
import com.android.settings.fuelgauge.batteryusage.BatteryReattribute;
|
import com.android.settings.fuelgauge.batteryusage.BatteryReattribute;
|
||||||
import com.android.settings.fuelgauge.batteryusage.db.BatteryReattributeDao;
|
import com.android.settings.fuelgauge.batteryusage.db.BatteryReattributeDao;
|
||||||
import com.android.settings.fuelgauge.batteryusage.db.BatteryReattributeEntity;
|
import com.android.settings.fuelgauge.batteryusage.db.BatteryReattributeEntity;
|
||||||
import com.android.settings.fuelgauge.batteryusage.db.BatteryStateDatabase;
|
import com.android.settings.fuelgauge.batteryusage.db.BatteryStateDatabase;
|
||||||
import com.android.settings.testutils.BatteryTestUtils;
|
import com.android.settings.testutils.BatteryTestUtils;
|
||||||
|
import com.android.settings.testutils.FakeFeatureFactory;
|
||||||
|
|
||||||
import org.junit.After;
|
import org.junit.After;
|
||||||
import org.junit.Before;
|
import org.junit.Before;
|
||||||
@@ -48,6 +52,7 @@ public final class LogUtilsTest {
|
|||||||
private Context mContext;
|
private Context mContext;
|
||||||
private BatteryStateDatabase mDatabase;
|
private BatteryStateDatabase mDatabase;
|
||||||
private BatteryReattributeDao mBatteryReattributeDao;
|
private BatteryReattributeDao mBatteryReattributeDao;
|
||||||
|
private PowerUsageFeatureProvider mPowerUsageFeatureProvider;
|
||||||
|
|
||||||
@Before
|
@Before
|
||||||
public void setUp() {
|
public void setUp() {
|
||||||
@@ -56,6 +61,8 @@ public final class LogUtilsTest {
|
|||||||
mTestPrintWriter = new PrintWriter(mTestStringWriter);
|
mTestPrintWriter = new PrintWriter(mTestStringWriter);
|
||||||
mDatabase = BatteryTestUtils.setUpBatteryStateDatabase(mContext);
|
mDatabase = BatteryTestUtils.setUpBatteryStateDatabase(mContext);
|
||||||
mBatteryReattributeDao = mDatabase.batteryReattributeDao();
|
mBatteryReattributeDao = mDatabase.batteryReattributeDao();
|
||||||
|
mPowerUsageFeatureProvider = FakeFeatureFactory.setupForTest().powerUsageFeatureProvider;
|
||||||
|
when(mPowerUsageFeatureProvider.isBatteryUsageReattributeEnabled()).thenReturn(true);
|
||||||
}
|
}
|
||||||
|
|
||||||
@After
|
@After
|
||||||
@@ -99,4 +106,17 @@ public final class LogUtilsTest {
|
|||||||
assertThat(result).contains(batteryReattribute1.toString());
|
assertThat(result).contains(batteryReattribute1.toString());
|
||||||
assertThat(result).contains(batteryReattribute2.toString());
|
assertThat(result).contains(batteryReattribute2.toString());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void dumpBatteryReattributeDatabaseHist_featureDisable_notPrintData() {
|
||||||
|
mBatteryReattributeDao.insert(new BatteryReattributeEntity(
|
||||||
|
BatteryReattribute.getDefaultInstance()));
|
||||||
|
when(mPowerUsageFeatureProvider.isBatteryUsageReattributeEnabled()).thenReturn(false);
|
||||||
|
|
||||||
|
LogUtils.dumpBatteryReattributeDatabaseHist(mBatteryReattributeDao, mTestPrintWriter);
|
||||||
|
|
||||||
|
final String result = mTestStringWriter.toString();
|
||||||
|
assertThat(result).contains("BatteryReattribute is disabled!");
|
||||||
|
assertThat(result.contains("BatteryReattribute DatabaseHistory:")).isFalse();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user