summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
author Sudheer Shanka <sudheersai@google.com> 2022-05-20 18:01:58 +0000
committer Android (Google) Code Review <android-gerrit@google.com> 2022-05-20 18:01:58 +0000
commit92762b949bd234036683385d476f326dad830bce (patch)
treea9bcf8da26e957b617478a5352b6ea0b5aa39f2a
parent7950f77ee3b88d89ee1ee8e712fdfcbc82c24b5a (diff)
parentd8d5fed2b68a274df6767281621d98a905b00912 (diff)
Merge "Add a flag to limit notif-seen signal changes to T targeting apps." into tm-dev
-rw-r--r--apex/jobscheduler/service/java/com/android/server/usage/AppStandbyController.java52
1 files changed, 45 insertions, 7 deletions
diff --git a/apex/jobscheduler/service/java/com/android/server/usage/AppStandbyController.java b/apex/jobscheduler/service/java/com/android/server/usage/AppStandbyController.java
index 1c4ec857538f..c9afdad8e40e 100644
--- a/apex/jobscheduler/service/java/com/android/server/usage/AppStandbyController.java
+++ b/apex/jobscheduler/service/java/com/android/server/usage/AppStandbyController.java
@@ -225,6 +225,11 @@ public class AppStandbyController
| PackageManager.MATCH_DISABLED_COMPONENTS
| PackageManager.MATCH_SYSTEM_ONLY;
+ private static final int NOTIFICATION_SEEN_PROMOTED_BUCKET_FOR_PRE_T_APPS =
+ STANDBY_BUCKET_WORKING_SET;
+ private static final long NOTIFICATION_SEEN_HOLD_DURATION_FOR_PRE_T_APPS =
+ COMPRESS_TIME ? 12 * ONE_MINUTE : 12 * ONE_HOUR;
+
// To name the lock for stack traces
static class Lock {}
@@ -320,11 +325,17 @@ public class AppStandbyController
int mNotificationSeenPromotedBucket =
ConstantsObserver.DEFAULT_NOTIFICATION_SEEN_PROMOTED_BUCKET;
/**
- * If true, tell each {@link AppIdleStateChangeListener} to give quota bump for each
+ * If {@code true}, tell each {@link AppIdleStateChangeListener} to give quota bump for each
* notification seen event.
*/
private boolean mTriggerQuotaBumpOnNotificationSeen =
ConstantsObserver.DEFAULT_TRIGGER_QUOTA_BUMP_ON_NOTIFICATION_SEEN;
+ /**
+ * If {@code true}, we will retain the pre-T impact of notification signal on apps targeting
+ * pre-T sdk levels regardless of other flag changes.
+ */
+ boolean mRetainNotificationSeenImpactForPreTApps =
+ ConstantsObserver.DEFAULT_RETAIN_NOTIFICATION_SEEN_IMPACT_FOR_PRE_T_APPS;
/** Minimum time a system update event should keep the buckets elevated. */
long mSystemUpdateUsageTimeoutMillis = ConstantsObserver.DEFAULT_SYSTEM_UPDATE_TIMEOUT;
/** Maximum time to wait for a prediction before using simple timeouts to downgrade buckets. */
@@ -1098,17 +1109,29 @@ public class AppStandbyController
final int subReason = usageEventToSubReason(eventType);
final int reason = REASON_MAIN_USAGE | subReason;
if (eventType == UsageEvents.Event.NOTIFICATION_SEEN) {
- if (mTriggerQuotaBumpOnNotificationSeen) {
- mHandler.obtainMessage(MSG_TRIGGER_LISTENER_QUOTA_BUMP, userId, -1, pkg)
- .sendToTarget();
+ final int notificationSeenPromotedBucket;
+ final long notificationSeenTimeoutMillis;
+ if (mRetainNotificationSeenImpactForPreTApps
+ && getTargetSdkVersion(pkg) < Build.VERSION_CODES.TIRAMISU) {
+ notificationSeenPromotedBucket =
+ NOTIFICATION_SEEN_PROMOTED_BUCKET_FOR_PRE_T_APPS;
+ notificationSeenTimeoutMillis =
+ NOTIFICATION_SEEN_HOLD_DURATION_FOR_PRE_T_APPS;
+ } else {
+ if (mTriggerQuotaBumpOnNotificationSeen) {
+ mHandler.obtainMessage(MSG_TRIGGER_LISTENER_QUOTA_BUMP, userId, -1, pkg)
+ .sendToTarget();
+ }
+ notificationSeenPromotedBucket = mNotificationSeenPromotedBucket;
+ notificationSeenTimeoutMillis = mNotificationSeenTimeoutMillis;
}
// Notification-seen elevates to a higher bucket (depending on
// {@link ConstantsObserver#KEY_NOTIFICATION_SEEN_PROMOTED_BUCKET}) but doesn't
// change usage time.
mAppIdleHistory.reportUsage(appHistory, pkg, userId,
- mNotificationSeenPromotedBucket, subReason,
- 0, elapsedRealtime + mNotificationSeenTimeoutMillis);
- nextCheckDelay = mNotificationSeenTimeoutMillis;
+ notificationSeenPromotedBucket, subReason,
+ 0, elapsedRealtime + notificationSeenTimeoutMillis);
+ nextCheckDelay = notificationSeenTimeoutMillis;
} else if (eventType == UsageEvents.Event.SLICE_PINNED) {
// Mild usage elevates to WORKING_SET but doesn't change usage time.
mAppIdleHistory.reportUsage(appHistory, pkg, userId,
@@ -1149,6 +1172,10 @@ public class AppStandbyController
}
}
+ private int getTargetSdkVersion(String packageName) {
+ return mInjector.getPackageManagerInternal().getPackageTargetSdkVersion(packageName);
+ }
+
/**
* Returns the lowest standby bucket that is better than {@code targetBucket} and has an
* valid expiry time (i.e. the expiry time is not yet elapsed).
@@ -2226,6 +2253,9 @@ public class AppStandbyController
pw.print(" mTriggerQuotaBumpOnNotificationSeen=");
pw.print(mTriggerQuotaBumpOnNotificationSeen);
pw.println();
+ pw.print(" mRetainNotificationSeenImpactForPreTApps=");
+ pw.print(mRetainNotificationSeenImpactForPreTApps);
+ pw.println();
pw.print(" mSlicePinnedTimeoutMillis=");
TimeUtils.formatDuration(mSlicePinnedTimeoutMillis, pw);
pw.println();
@@ -2712,6 +2742,8 @@ public class AppStandbyController
"notification_seen_duration";
private static final String KEY_NOTIFICATION_SEEN_PROMOTED_BUCKET =
"notification_seen_promoted_bucket";
+ private static final String KEY_RETAIN_NOTIFICATION_SEEN_IMPACT_FOR_PRE_T_APPS =
+ "retain_notification_seen_impact_for_pre_t_apps";
private static final String KEY_TRIGGER_QUOTA_BUMP_ON_NOTIFICATION_SEEN =
"trigger_quota_bump_on_notification_seen";
private static final String KEY_SLICE_PINNED_HOLD_DURATION =
@@ -2773,6 +2805,7 @@ public class AppStandbyController
COMPRESS_TIME ? 12 * ONE_MINUTE : 12 * ONE_HOUR;
public static final int DEFAULT_NOTIFICATION_SEEN_PROMOTED_BUCKET =
STANDBY_BUCKET_WORKING_SET;
+ public static final boolean DEFAULT_RETAIN_NOTIFICATION_SEEN_IMPACT_FOR_PRE_T_APPS = false;
public static final boolean DEFAULT_TRIGGER_QUOTA_BUMP_ON_NOTIFICATION_SEEN = false;
public static final long DEFAULT_SYSTEM_UPDATE_TIMEOUT =
COMPRESS_TIME ? 2 * ONE_MINUTE : 2 * ONE_HOUR;
@@ -2874,6 +2907,11 @@ public class AppStandbyController
KEY_NOTIFICATION_SEEN_PROMOTED_BUCKET,
DEFAULT_NOTIFICATION_SEEN_PROMOTED_BUCKET);
break;
+ case KEY_RETAIN_NOTIFICATION_SEEN_IMPACT_FOR_PRE_T_APPS:
+ mRetainNotificationSeenImpactForPreTApps = properties.getBoolean(
+ KEY_RETAIN_NOTIFICATION_SEEN_IMPACT_FOR_PRE_T_APPS,
+ DEFAULT_RETAIN_NOTIFICATION_SEEN_IMPACT_FOR_PRE_T_APPS);
+ break;
case KEY_TRIGGER_QUOTA_BUMP_ON_NOTIFICATION_SEEN:
mTriggerQuotaBumpOnNotificationSeen = properties.getBoolean(
KEY_TRIGGER_QUOTA_BUMP_ON_NOTIFICATION_SEEN,