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

Commit 7e9d70ea authored by Riddle Hsu's avatar Riddle Hsu Committed by Automerger Merge Worker
Browse files

Merge "Skip reporting ANR on zero pid process" into tm-dev am: 577eebd5

parents e2528570 577eebd5
Loading
Loading
Loading
Loading
+5 −0
Original line number Diff line number Diff line
@@ -79,6 +79,11 @@ class AnrHelper {
            WindowProcessController parentProcess, boolean aboveSystem, String annotation) {
        final int incomingPid = anrProcess.mPid;
        synchronized (mAnrRecords) {
            if (incomingPid == 0) {
                // Extreme corner case such as zygote is no response to return pid for the process.
                Slog.i(TAG, "Skip zero pid ANR, process=" + anrProcess.processName);
                return;
            }
            if (mProcessingPid == incomingPid) {
                Slog.i(TAG, "Skip duplicated ANR, pid=" + incomingPid + " " + annotation);
                return;
+1 −1
Original line number Diff line number Diff line
@@ -70,6 +70,7 @@ public class AnrHelperTest {
        final Context context = getInstrumentation().getTargetContext();
        runWithDexmakerShareClassLoader(() -> {
            mAnrApp = mock(ProcessRecord.class);
            mAnrApp.mPid = 12345;
            final ProcessErrorStateRecord errorState = mock(ProcessErrorStateRecord.class);
            setFieldValue(ProcessErrorStateRecord.class, errorState, "mProcLock",
                    new ActivityManagerProcLock());
@@ -130,7 +131,6 @@ public class AnrHelperTest {
        }).when(mAnrApp.mErrorState).appNotResponding(anyString(), any(), any(), any(),
                anyBoolean(), anyString(), anyBoolean());
        final ApplicationInfo appInfo = new ApplicationInfo();
        mAnrApp.mPid = 12345;
        final Runnable reportAnr = () -> mAnrHelper.appNotResponding(mAnrApp,
                "activityShortComponentName", appInfo, "parentShortComponentName",
                null /* parentProcess */, false /* aboveSystem */, "annotation");