Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 7611ac2a authored by Gavin Corkery's avatar Gavin Corkery Committed by Automerger Merge Worker
Browse files

Merge "Replace broadcast with adding a method in BugreportCallback" am: d45d533b

Original change: https://android-review.googlesource.com/c/platform/frameworks/base/+/1507504

MUST ONLY BE SUBMITTED BY AUTOMERGER

Change-Id: Ied674d7ff891caf26d751b6f15af2db9f0eea08f
parents 4ef13ea0 d45d533b
Loading
Loading
Loading
Loading
+1 −0
Original line number Diff line number Diff line
@@ -7001,6 +7001,7 @@ package android.os {
  public abstract static class BugreportManager.BugreportCallback {
    ctor public BugreportManager.BugreportCallback();
    method public void onEarlyReportFinished();
    method public void onError(int);
    method public void onFinished();
    method public void onProgress(@FloatRange(from=0.0f, to=100.0f) float);
+8 −14
Original line number Diff line number Diff line
@@ -26,7 +26,6 @@ import android.annotation.SystemApi;
import android.annotation.SystemService;
import android.app.ActivityManager;
import android.content.Context;
import android.content.Intent;
import android.os.Handler;
import android.util.Log;
import android.widget.Toast;
@@ -52,8 +51,6 @@ import java.util.concurrent.Executor;
public final class BugreportManager {

    private static final String TAG = "BugreportManager";
    private static final String INTENT_UI_INTENSIVE_BUGREPORT_DUMPS_FINISHED =
            "com.android.internal.intent.action.UI_INTENSIVE_BUGREPORT_DUMPS_FINISHED";

    private final Context mContext;
    private final IDumpstate mBinder;
@@ -126,6 +123,12 @@ public final class BugreportManager {
         * Called when taking bugreport finishes successfully.
         */
        public void onFinished() {}

        /**
         * Called when it is ready for calling app to show UI, showing any extra UI before this
         * callback can interfere with bugreport generation.
         */
        public void onEarlyReportFinished() {}
    }

    /**
@@ -288,21 +291,12 @@ public final class BugreportManager {
        }

        @Override
        public void onUiIntensiveBugreportDumpsFinished(String callingPackage)
        public void onUiIntensiveBugreportDumpsFinished()
                throws RemoteException {
            final long identity = Binder.clearCallingIdentity();
            try {
                mExecutor.execute(() -> {
                    // Send intent to let calling app to show UI safely without interfering with
                    // the bugreport/screenshot generation.
                    // TODO(b/154298410): When S is ready for API change, add a method in
                    // BugreportCallback so we can just call the callback instead of using
                    // broadcast.
                    Intent intent = new Intent(INTENT_UI_INTENSIVE_BUGREPORT_DUMPS_FINISHED);
                    intent.setPackage(callingPackage);
                    intent.addFlags(Intent.FLAG_RECEIVER_FOREGROUND);
                    intent.addFlags(Intent.FLAG_RECEIVER_INCLUDE_BACKGROUND);
                    mContext.sendBroadcast(intent, android.Manifest.permission.DUMP);
                    mCallback.onEarlyReportFinished();
                });
            } finally {
                Binder.restoreCallingIdentity(identity);
+16 −0
Original line number Diff line number Diff line
@@ -118,6 +118,7 @@ public class BugreportManagerTest {
        // Wifi bugreports should not receive any progress.
        assertThat(callback.hasReceivedProgress()).isFalse();
        assertThat(mBugreportFile.length()).isGreaterThan(0L);
        assertThat(callback.hasEarlyReportFinished()).isTrue();
        assertFdsAreClosed(mBugreportFd);
    }

@@ -135,6 +136,7 @@ public class BugreportManagerTest {
        // Interactive bugreports show progress updates.
        assertThat(callback.hasReceivedProgress()).isTrue();
        assertThat(mBugreportFile.length()).isGreaterThan(0L);
        assertThat(callback.hasEarlyReportFinished()).isTrue();
        assertFdsAreClosed(mBugreportFd);
    }

@@ -246,6 +248,7 @@ public class BugreportManagerTest {
        private int mErrorCode = -1;
        private boolean mSuccess = false;
        private boolean mReceivedProgress = false;
        private boolean mEarlyReportFinished = false;
        private final Object mLock = new Object();

        @Override
@@ -271,6 +274,13 @@ public class BugreportManagerTest {
            }
        }

        @Override
        public void onEarlyReportFinished() {
            synchronized (mLock) {
                mEarlyReportFinished = true;
            }
        }

        /* Indicates completion; and ended up with a success or error. */
        public boolean isDone() {
            synchronized (mLock) {
@@ -295,6 +305,12 @@ public class BugreportManagerTest {
                return mReceivedProgress;
            }
        }

        public boolean hasEarlyReportFinished() {
            synchronized (mLock) {
                return mEarlyReportFinished;
            }
        }
    }

    public static BugreportManager getBugreportManager() {
+3 −0
Original line number Diff line number Diff line
@@ -378,6 +378,9 @@ public class BugreportProgressService extends Service {
            }
        }

        @Override
        public void onEarlyReportFinished() {}

        /**
         * Reads bugreport id and links it to the bugreport info to track a bugreport that is in
         * process. id is incremented in the dumpstate code.
+2 −3
Original line number Diff line number Diff line
@@ -297,9 +297,8 @@ class BugreportManagerServiceImpl extends IDumpstate.Stub {
        }

        @Override
        public void onUiIntensiveBugreportDumpsFinished(String callingPackage)
                throws RemoteException {
            mListener.onUiIntensiveBugreportDumpsFinished(callingPackage);
        public void onUiIntensiveBugreportDumpsFinished() throws RemoteException {
            mListener.onUiIntensiveBugreportDumpsFinished();
        }

        @Override