diff options
| author | Riddle Hsu <riddlehsu@google.com> | 2018-06-30 02:06:42 +0800 |
|---|---|---|
| committer | Riddle Hsu <riddlehsu@google.com> | 2018-07-12 11:54:47 +0800 |
| commit | d3062cbf41664a09354528ea9e795a55a806c8c0 (patch) | |
| tree | 496cf96875c48296b809004648371e656704a415 /core/java/android/app/ClientTransactionHandler.java | |
| parent | d9afa508633dd6863f0845f63383c3e95e8232b2 (diff) | |
Skip execution of transactions on a destroyed activity
An Activity may not yet create on client side, there is another
launch request with flags to clear task, then a destroy transaction
is scheduled. If client side keeps blocking until destroy timeout,
the token on server side will be removed. When client begins to
handle the first creation, it will report its activity token to
server that causes IllegalArgumentException because there is no
matched ActivityRecord.
Bug: 32375307
Test: atest FrameworksCoreTests:TransactionExecutorTests
Change-Id: I1b7e0c2863b13091c3fd50df602ff31ae02ff38d
Diffstat (limited to 'core/java/android/app/ClientTransactionHandler.java')
| -rw-r--r-- | core/java/android/app/ClientTransactionHandler.java | 5 |
1 files changed, 5 insertions, 0 deletions
diff --git a/core/java/android/app/ClientTransactionHandler.java b/core/java/android/app/ClientTransactionHandler.java index d9c7cf3ccc74..193f933df782 100644 --- a/core/java/android/app/ClientTransactionHandler.java +++ b/core/java/android/app/ClientTransactionHandler.java @@ -16,6 +16,7 @@ package android.app; import android.app.servertransaction.ClientTransaction; +import android.app.servertransaction.ClientTransactionItem; import android.app.servertransaction.PendingTransactionActions; import android.app.servertransaction.TransactionExecutor; import android.content.Intent; @@ -29,6 +30,7 @@ import com.android.internal.annotations.VisibleForTesting; import com.android.internal.content.ReferrerIntent; import java.util.List; +import java.util.Map; /** * Defines operations that a {@link android.app.servertransaction.ClientTransaction} or its items @@ -78,6 +80,9 @@ public abstract class ClientTransactionHandler { // Execute phase related logic and handlers. Methods here execute actual lifecycle transactions // and deliver callbacks. + /** Get activity and its corresponding transaction item which are going to destroy. */ + public abstract Map<IBinder, ClientTransactionItem> getActivitiesToBeDestroyed(); + /** Destroy the activity. */ public abstract void handleDestroyActivity(IBinder token, boolean finishing, int configChanges, boolean getNonConfigInstance, String reason); |
