Merge changes I77a53f70,I853d3611
* changes: Add functions for table action. Create table to store user action.
This commit is contained in:
@@ -22,6 +22,7 @@ import static org.mockito.Mockito.spy;
|
||||
|
||||
import android.content.Context;
|
||||
import android.text.format.DateUtils;
|
||||
import android.util.SparseLongArray;
|
||||
|
||||
import com.android.settings.fuelgauge.batterytip.AnomalyDatabaseHelper;
|
||||
import com.android.settings.fuelgauge.batterytip.AppInfo;
|
||||
@@ -88,7 +89,7 @@ public class BatteryDatabaseManagerTest {
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testAllFunctions() {
|
||||
public void allAnomalyFunctions() {
|
||||
mBatteryDatabaseManager.insertAnomaly(UID_NEW, PACKAGE_NAME_NEW, TYPE_NEW,
|
||||
AnomalyDatabaseHelper.State.NEW, NOW);
|
||||
mBatteryDatabaseManager.insertAnomaly(UID_OLD, PACKAGE_NAME_OLD, TYPE_OLD,
|
||||
@@ -113,7 +114,7 @@ public class BatteryDatabaseManagerTest {
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testUpdateAnomalies_updateSuccessfully() {
|
||||
public void updateAnomalies_updateSuccessfully() {
|
||||
mBatteryDatabaseManager.insertAnomaly(UID_NEW, PACKAGE_NAME_NEW, TYPE_NEW,
|
||||
AnomalyDatabaseHelper.State.NEW, NOW);
|
||||
mBatteryDatabaseManager.insertAnomaly(UID_OLD, PACKAGE_NAME_OLD, TYPE_OLD,
|
||||
@@ -138,7 +139,7 @@ public class BatteryDatabaseManagerTest {
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testQueryAnomalies_removeDuplicateByUid() {
|
||||
public void queryAnomalies_removeDuplicateByUid() {
|
||||
mBatteryDatabaseManager.insertAnomaly(UID_NEW, PACKAGE_NAME_NEW, TYPE_NEW,
|
||||
AnomalyDatabaseHelper.State.NEW, NOW);
|
||||
mBatteryDatabaseManager.insertAnomaly(UID_NEW, PACKAGE_NAME_NEW, TYPE_OLD,
|
||||
@@ -149,4 +150,28 @@ public class BatteryDatabaseManagerTest {
|
||||
AnomalyDatabaseHelper.State.NEW);
|
||||
assertThat(newAppInfos).containsExactly(mCombinedAppInfo);
|
||||
}
|
||||
|
||||
@Test
|
||||
public void allActionFunctions() {
|
||||
final long timestamp = System.currentTimeMillis();
|
||||
mBatteryDatabaseManager.insertAction(AnomalyDatabaseHelper.ActionType.RESTRICTION, UID_OLD,
|
||||
PACKAGE_NAME_OLD, 0);
|
||||
mBatteryDatabaseManager.insertAction(AnomalyDatabaseHelper.ActionType.RESTRICTION, UID_OLD,
|
||||
PACKAGE_NAME_OLD, 1);
|
||||
mBatteryDatabaseManager.insertAction(AnomalyDatabaseHelper.ActionType.RESTRICTION, UID_NEW,
|
||||
PACKAGE_NAME_NEW, timestamp);
|
||||
|
||||
final SparseLongArray timeArray = mBatteryDatabaseManager.queryActionTime(
|
||||
AnomalyDatabaseHelper.ActionType.RESTRICTION);
|
||||
assertThat(timeArray.size()).isEqualTo(2);
|
||||
assertThat(timeArray.get(UID_OLD)).isEqualTo(1);
|
||||
assertThat(timeArray.get(UID_NEW)).isEqualTo(timestamp);
|
||||
|
||||
mBatteryDatabaseManager.deleteAction(AnomalyDatabaseHelper.ActionType.RESTRICTION, UID_NEW,
|
||||
PACKAGE_NAME_NEW);
|
||||
final SparseLongArray recentTimeArray = mBatteryDatabaseManager.queryActionTime(
|
||||
AnomalyDatabaseHelper.ActionType.RESTRICTION);
|
||||
assertThat(recentTimeArray.size()).isEqualTo(1);
|
||||
assertThat(timeArray.get(UID_OLD)).isEqualTo(1);
|
||||
}
|
||||
}
|
||||
|
@@ -51,9 +51,12 @@ import android.text.format.DateUtils;
|
||||
|
||||
import com.android.internal.os.BatterySipper;
|
||||
import com.android.internal.os.BatteryStatsHelper;
|
||||
import com.android.settings.fuelgauge.batterytip.AnomalyDatabaseHelper;
|
||||
import com.android.settings.fuelgauge.batterytip.AnomalyInfo;
|
||||
import com.android.settings.fuelgauge.batterytip.BatteryDatabaseManager;
|
||||
import com.android.settings.testutils.FakeFeatureFactory;
|
||||
import com.android.settings.testutils.SettingsRobolectricTestRunner;
|
||||
import com.android.settings.testutils.shadow.ShadowThreadUtils;
|
||||
import com.android.settingslib.fuelgauge.PowerWhitelistBackend;
|
||||
|
||||
import org.junit.Before;
|
||||
@@ -148,6 +151,8 @@ public class BatteryUtilsTest {
|
||||
private ApplicationInfo mLowApplicationInfo;
|
||||
@Mock
|
||||
private PowerWhitelistBackend mPowerWhitelistBackend;
|
||||
@Mock
|
||||
private BatteryDatabaseManager mBatteryDatabaseManager;
|
||||
private AnomalyInfo mAnomalyInfo;
|
||||
private BatteryUtils mBatteryUtils;
|
||||
private FakeFeatureFactory mFeatureFactory;
|
||||
@@ -225,6 +230,8 @@ public class BatteryUtilsTest {
|
||||
.thenReturn(TOTAL_BATTERY_USAGE + BATTERY_SCREEN_USAGE);
|
||||
when(mBatteryStatsHelper.getStats().getDischargeAmount(anyInt()))
|
||||
.thenReturn(DISCHARGE_AMOUNT);
|
||||
BatteryDatabaseManager.setUpForTest(mBatteryDatabaseManager);
|
||||
ShadowThreadUtils.setIsMainThread(true);
|
||||
}
|
||||
|
||||
@Test
|
||||
@@ -569,6 +576,23 @@ public class BatteryUtilsTest {
|
||||
HIGH_SDK_PACKAGE, AppOpsManager.MODE_IGNORED);
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testSetForceAppStandby_restrictApp_recordTime() {
|
||||
mBatteryUtils.setForceAppStandby(UID, HIGH_SDK_PACKAGE, AppOpsManager.MODE_IGNORED);
|
||||
|
||||
verify(mBatteryDatabaseManager).insertAction(
|
||||
eq(AnomalyDatabaseHelper.ActionType.RESTRICTION), eq(UID),
|
||||
eq(HIGH_SDK_PACKAGE), anyLong());
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testSetForceAppStandby_unrestrictApp_deleteTime() {
|
||||
mBatteryUtils.setForceAppStandby(UID, HIGH_SDK_PACKAGE, AppOpsManager.MODE_ALLOWED);
|
||||
|
||||
verify(mBatteryDatabaseManager).deleteAction(AnomalyDatabaseHelper.ActionType.RESTRICTION,
|
||||
UID, HIGH_SDK_PACKAGE);
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testIsForceAppStandbyEnabled_enabled_returnTrue() {
|
||||
when(mAppOpsManager.checkOpNoThrow(AppOpsManager.OP_RUN_ANY_IN_BACKGROUND, UID,
|
||||
|
@@ -28,10 +28,13 @@ import android.content.pm.PackageManager;
|
||||
import android.os.Bundle;
|
||||
import android.os.UserHandle;
|
||||
import android.util.IconDrawableFactory;
|
||||
import android.util.SparseLongArray;
|
||||
|
||||
import com.android.settings.SettingsActivity;
|
||||
import com.android.settings.core.InstrumentedPreferenceFragment;
|
||||
import com.android.settings.fuelgauge.batterytip.AnomalyDatabaseHelper;
|
||||
import com.android.settings.fuelgauge.batterytip.AppInfo;
|
||||
import com.android.settings.fuelgauge.batterytip.BatteryDatabaseManager;
|
||||
import com.android.settings.fuelgauge.batterytip.BatteryTipDialogFragment;
|
||||
import com.android.settings.fuelgauge.batterytip.tips.BatteryTip;
|
||||
import com.android.settings.fuelgauge.batterytip.tips.RestrictAppTip;
|
||||
@@ -52,6 +55,7 @@ import org.robolectric.annotation.Config;
|
||||
|
||||
import java.util.ArrayList;
|
||||
import java.util.List;
|
||||
import java.util.concurrent.TimeUnit;
|
||||
|
||||
import androidx.appcompat.app.AlertDialog;
|
||||
import androidx.preference.CheckBoxPreference;
|
||||
@@ -76,6 +80,8 @@ public class RestrictedAppDetailsTest {
|
||||
private IconDrawableFactory mIconDrawableFactory;
|
||||
@Mock
|
||||
private InstrumentedPreferenceFragment mFragment;
|
||||
@Mock
|
||||
private BatteryDatabaseManager mBatteryDatabaseManager;
|
||||
private PreferenceManager mPreferenceManager;
|
||||
private RestrictedAppDetails mRestrictedAppDetails;
|
||||
private Context mContext;
|
||||
@@ -98,12 +104,14 @@ public class RestrictedAppDetailsTest {
|
||||
|
||||
doReturn(mPreferenceManager).when(mRestrictedAppDetails).getPreferenceManager();
|
||||
doReturn(mContext).when(mFragment).getContext();
|
||||
doReturn(mContext).when(mRestrictedAppDetails).getContext();
|
||||
mRestrictedAppDetails.mPackageManager = mPackageManager;
|
||||
mRestrictedAppDetails.mIconDrawableFactory = mIconDrawableFactory;
|
||||
mRestrictedAppDetails.mAppInfos = new ArrayList<>();
|
||||
mRestrictedAppDetails.mAppInfos.add(mAppInfo);
|
||||
mRestrictedAppDetails.mRestrictedAppListGroup = spy(new PreferenceCategory(mContext));
|
||||
mRestrictedAppDetails.mBatteryUtils = spy(new BatteryUtils(mContext));
|
||||
mRestrictedAppDetails.mBatteryDatabaseManager = mBatteryDatabaseManager;
|
||||
doReturn(mPreferenceManager).when(
|
||||
mRestrictedAppDetails.mRestrictedAppListGroup).getPreferenceManager();
|
||||
|
||||
@@ -118,6 +126,10 @@ public class RestrictedAppDetailsTest {
|
||||
doReturn(APP_NAME).when(mPackageManager).getApplicationLabel(mApplicationInfo);
|
||||
doReturn(true).when(mRestrictedAppDetails.mBatteryUtils).isForceAppStandbyEnabled(UID,
|
||||
PACKAGE_NAME);
|
||||
final SparseLongArray timestampArray = new SparseLongArray();
|
||||
timestampArray.put(UID, System.currentTimeMillis() - TimeUnit.HOURS.toMillis(5));
|
||||
doReturn(timestampArray).when(mBatteryDatabaseManager)
|
||||
.queryActionTime(AnomalyDatabaseHelper.ActionType.RESTRICTION);
|
||||
|
||||
mRestrictedAppDetails.refreshUi();
|
||||
|
||||
@@ -126,6 +138,7 @@ public class RestrictedAppDetailsTest {
|
||||
(CheckBoxPreference) mRestrictedAppDetails.mRestrictedAppListGroup.getPreference(0);
|
||||
assertThat(preference.getTitle()).isEqualTo(APP_NAME);
|
||||
assertThat(preference.isChecked()).isTrue();
|
||||
assertThat(preference.getSummary()).isEqualTo("Restricted 5 hours ago");
|
||||
}
|
||||
|
||||
@Test
|
||||
|
Reference in New Issue
Block a user