summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--services/core/java/com/android/server/wm/ActivityRecord.java12
-rw-r--r--services/core/java/com/android/server/wm/ActivityStarter.java4
-rw-r--r--services/core/java/com/android/server/wm/LaunchParamsController.java19
-rw-r--r--services/core/java/com/android/server/wm/TaskLaunchParamsModifier.java74
-rw-r--r--services/core/java/com/android/server/wm/WindowProcessController.java22
-rw-r--r--services/tests/wmtests/src/com/android/server/wm/ActivityStarterTests.java2
-rw-r--r--services/tests/wmtests/src/com/android/server/wm/LaunchParamsControllerTests.java50
-rw-r--r--services/tests/wmtests/src/com/android/server/wm/TaskLaunchParamsModifierTests.java137
-rw-r--r--services/tests/wmtests/src/com/android/server/wm/WindowProcessControllerTests.java41
9 files changed, 44 insertions, 317 deletions
diff --git a/services/core/java/com/android/server/wm/ActivityRecord.java b/services/core/java/com/android/server/wm/ActivityRecord.java
index 56ec8c1fb326..9868fc1657e2 100644
--- a/services/core/java/com/android/server/wm/ActivityRecord.java
+++ b/services/core/java/com/android/server/wm/ActivityRecord.java
@@ -7508,10 +7508,6 @@ final class ActivityRecord extends WindowToken implements WindowManagerService.A
return (config.uiMode & UI_MODE_TYPE_MASK) == UI_MODE_TYPE_VR_HEADSET;
}
- String getProcessName() {
- return info.applicationInfo.processName;
- }
-
int getUid() {
return info.applicationInfo.uid;
}
@@ -7524,14 +7520,6 @@ final class ActivityRecord extends WindowToken implements WindowManagerService.A
return app != null ? app.getPid() : 0;
}
- int getLaunchedFromPid() {
- return launchedFromPid;
- }
-
- int getLaunchedFromUid() {
- return launchedFromUid;
- }
-
/**
* Determines whether this ActivityRecord can turn the screen on. It checks whether the flag
* {@link ActivityRecord#getTurnScreenOnFlag} is set and checks whether the ActivityRecord
diff --git a/services/core/java/com/android/server/wm/ActivityStarter.java b/services/core/java/com/android/server/wm/ActivityStarter.java
index 10c15a79846a..28e71fa7230a 100644
--- a/services/core/java/com/android/server/wm/ActivityStarter.java
+++ b/services/core/java/com/android/server/wm/ActivityStarter.java
@@ -1807,7 +1807,7 @@ class ActivityStarter {
}
mSupervisor.getLaunchParamsController().calculate(targetTask, r.info.windowLayout, r,
- sourceRecord, mOptions, PHASE_BOUNDS, mLaunchParams, mRequest);
+ sourceRecord, mOptions, PHASE_BOUNDS, mLaunchParams);
mPreferredTaskDisplayArea = mLaunchParams.hasPreferredTaskDisplayArea()
? mLaunchParams.mPreferredTaskDisplayArea
: mRootWindowContainer.getDefaultTaskDisplayArea();
@@ -2177,7 +2177,7 @@ class ActivityStarter {
// Preferred display id is the only state we need for now and it could be updated again
// after we located a reusable task (which might be resided in another display).
mSupervisor.getLaunchParamsController().calculate(inTask, r.info.windowLayout, r,
- sourceRecord, options, PHASE_DISPLAY, mLaunchParams, mRequest);
+ sourceRecord, options, PHASE_DISPLAY, mLaunchParams);
mPreferredTaskDisplayArea = mLaunchParams.hasPreferredTaskDisplayArea()
? mLaunchParams.mPreferredTaskDisplayArea
: mRootWindowContainer.getDefaultTaskDisplayArea();
diff --git a/services/core/java/com/android/server/wm/LaunchParamsController.java b/services/core/java/com/android/server/wm/LaunchParamsController.java
index 4f65a9e8a064..a0074a2d760c 100644
--- a/services/core/java/com/android/server/wm/LaunchParamsController.java
+++ b/services/core/java/com/android/server/wm/LaunchParamsController.java
@@ -19,7 +19,6 @@ package com.android.server.wm;
import static android.app.WindowConfiguration.WINDOWING_MODE_UNDEFINED;
import static android.view.Display.INVALID_DISPLAY;
-import static com.android.server.wm.ActivityStarter.Request;
import static com.android.server.wm.LaunchParamsController.LaunchParamsModifier.PHASE_BOUNDS;
import static com.android.server.wm.LaunchParamsController.LaunchParamsModifier.RESULT_CONTINUE;
import static com.android.server.wm.LaunchParamsController.LaunchParamsModifier.RESULT_DONE;
@@ -74,10 +73,9 @@ class LaunchParamsController {
* @param source The {@link ActivityRecord} from which activity was started from.
* @param options The {@link ActivityOptions} specified for the activity.
* @param result The resulting params.
- * @param request The optional request from the activity starter.
*/
- void calculate(Task task, WindowLayout layout, ActivityRecord activity, ActivityRecord source,
- ActivityOptions options, int phase, LaunchParams result, @Nullable Request request) {
+ void calculate(Task task, WindowLayout layout, ActivityRecord activity,
+ ActivityRecord source, ActivityOptions options, int phase, LaunchParams result) {
result.reset();
if (task != null || activity != null) {
@@ -93,7 +91,7 @@ class LaunchParamsController {
final LaunchParamsModifier modifier = mModifiers.get(i);
switch(modifier.onCalculate(task, layout, activity, source, options, phase, mTmpCurrent,
- mTmpResult, request)) {
+ mTmpResult)) {
case RESULT_SKIP:
// Do not apply any results when we are told to skip
continue;
@@ -130,8 +128,7 @@ class LaunchParamsController {
boolean layoutTask(Task task, WindowLayout layout, ActivityRecord activity,
ActivityRecord source, ActivityOptions options) {
- calculate(task, layout, activity, source, options, PHASE_BOUNDS, mTmpParams,
- null /* request */);
+ calculate(task, layout, activity, source, options, PHASE_BOUNDS, mTmpParams);
// No changes, return.
if (mTmpParams.isEmpty()) {
@@ -308,17 +305,15 @@ class LaunchParamsController {
* launched should have this be non-null.
* @param source the Activity that launched a new task. Could be {@code null}.
* @param options {@link ActivityOptions} used to start the activity with.
- * @param phase the calculation phase, see {@link Phase}
+ * @param phase the calculation phase, see {@link LaunchParamsModifier.Phase}
* @param currentParams launching params after the process of last {@link
* LaunchParamsModifier}.
* @param outParams the result params to be set.
- * @param request Optional data to give more context on the launch
* @return see {@link LaunchParamsModifier.Result}
*/
@Result
- int onCalculate(@Nullable Task task, WindowLayout layout, ActivityRecord activity,
+ int onCalculate(Task task, WindowLayout layout, ActivityRecord activity,
ActivityRecord source, ActivityOptions options, @Phase int phase,
- LaunchParams currentParams, LaunchParams outParams,
- @Nullable Request request);
+ LaunchParams currentParams, LaunchParams outParams);
}
}
diff --git a/services/core/java/com/android/server/wm/TaskLaunchParamsModifier.java b/services/core/java/com/android/server/wm/TaskLaunchParamsModifier.java
index f52cb2d332b7..9a818ce80872 100644
--- a/services/core/java/com/android/server/wm/TaskLaunchParamsModifier.java
+++ b/services/core/java/com/android/server/wm/TaskLaunchParamsModifier.java
@@ -35,7 +35,6 @@ import static android.util.DisplayMetrics.DENSITY_DEFAULT;
import static android.view.Display.DEFAULT_DISPLAY;
import static android.view.Display.INVALID_DISPLAY;
-import static com.android.server.wm.ActivityStarter.Request;
import static com.android.server.wm.ActivityTaskManagerDebugConfig.TAG_ATM;
import static com.android.server.wm.ActivityTaskManagerDebugConfig.TAG_WITH_CLASS_NAME;
@@ -99,25 +98,23 @@ class TaskLaunchParamsModifier implements LaunchParamsModifier {
ActivityRecord source, ActivityOptions options, LaunchParams currentParams,
LaunchParams outParams) {
return onCalculate(task, layout, activity, source, options, PHASE_BOUNDS, currentParams,
- outParams, null);
+ outParams);
}
@Override
- public int onCalculate(@Nullable Task task, @NonNull ActivityInfo.WindowLayout layout,
- @NonNull ActivityRecord activity, @Nullable ActivityRecord source,
- ActivityOptions options, int phase, LaunchParams currentParams, LaunchParams outParams,
- @Nullable Request request) {
+ public int onCalculate(Task task, ActivityInfo.WindowLayout layout,
+ ActivityRecord activity, ActivityRecord source, ActivityOptions options,
+ int phase, LaunchParams currentParams, LaunchParams outParams) {
initLogBuilder(task, activity);
final int result = calculate(task, layout, activity, source, options, phase, currentParams,
- outParams, request);
+ outParams);
outputLog();
return result;
}
- private int calculate(@Nullable Task task, @NonNull ActivityInfo.WindowLayout layout,
- @NonNull ActivityRecord activity, @Nullable ActivityRecord source,
- ActivityOptions options, int phase, LaunchParams currentParams, LaunchParams outParams,
- @Nullable Request request) {
+ private int calculate(Task task, ActivityInfo.WindowLayout layout,
+ ActivityRecord activity, ActivityRecord source, ActivityOptions options, int phase,
+ LaunchParams currentParams, LaunchParams outParams) {
final ActivityRecord root;
if (task != null) {
root = task.getRootActivity() == null ? activity : task.getRootActivity();
@@ -140,7 +137,7 @@ class TaskLaunchParamsModifier implements LaunchParamsModifier {
// STEP 1: Determine the display area to launch the activity/task.
final TaskDisplayArea taskDisplayArea = getPreferredLaunchTaskDisplayArea(task,
- options, source, currentParams, activity, request);
+ options, source, currentParams);
outParams.mPreferredTaskDisplayArea = taskDisplayArea;
// TODO(b/152116619): Update the usages of display to use taskDisplayArea below.
final DisplayContent display = taskDisplayArea.mDisplayContent;
@@ -300,8 +297,7 @@ class TaskLaunchParamsModifier implements LaunchParamsModifier {
}
private TaskDisplayArea getPreferredLaunchTaskDisplayArea(@Nullable Task task,
- @Nullable ActivityOptions options, ActivityRecord source, LaunchParams currentParams,
- @NonNull ActivityRecord activityRecord, @Nullable Request request) {
+ @Nullable ActivityOptions options, ActivityRecord source, LaunchParams currentParams) {
TaskDisplayArea taskDisplayArea = null;
final WindowContainerToken optionLaunchTaskDisplayAreaToken = options != null
@@ -372,7 +368,7 @@ class TaskLaunchParamsModifier implements LaunchParamsModifier {
taskDisplayArea = currentParams.mPreferredTaskDisplayArea;
}
- // Re-route to default display if the device didn't declare support for multi-display
+ // Fallback to default display if the device didn't declare support for multi-display
if (taskDisplayArea != null && !mSupervisor.mService.mSupportsMultiDisplay
&& taskDisplayArea.getDisplayId() != DEFAULT_DISPLAY) {
taskDisplayArea = mSupervisor.mRootWindowContainer.getDefaultTaskDisplayArea();
@@ -380,53 +376,7 @@ class TaskLaunchParamsModifier implements LaunchParamsModifier {
return (taskDisplayArea != null)
? taskDisplayArea
- : getFallbackDisplayAreaForActivity(activityRecord, request);
- }
-
- /**
- * Calculate the default display area for a task. We attempt to put the activity within the
- * same display area if possible. The strategy is to find the display in the following order:
- *
- * <ol>
- * <li>The default is to launch the new activity in the same display area as the current top
- * running activity in its process</li>
- * <li>The display area of the top activity from the launching process will be used</li>
- * <li>The display area of the top activity from the real launching process will be used
- * </li>
- * <li>Default display area from the associated root window container.</li>
- * </ol>
- * @param activityRecord the activity being started
- * @param request optional {@link Request} made to start the activity record
- * @return {@link TaskDisplayArea} to house the task
- */
- private TaskDisplayArea getFallbackDisplayAreaForActivity(
- @NonNull ActivityRecord activityRecord, @Nullable Request request) {
- WindowProcessController controllerFromProcess = mSupervisor.mService.getProcessController(
- activityRecord.getProcessName(), activityRecord.getUid());
- final TaskDisplayArea displayAreaForRecord = controllerFromProcess == null ? null
- : controllerFromProcess.getTopActivityDisplayArea();
- if (displayAreaForRecord != null) {
- return displayAreaForRecord;
- }
-
- WindowProcessController controllerFromLaunchingRecord = mSupervisor.mService
- .getProcessController(activityRecord.launchedFromPid,
- activityRecord.launchedFromUid);
- final TaskDisplayArea displayAreaForLaunchingRecord = controllerFromLaunchingRecord == null
- ? null : controllerFromLaunchingRecord.getTopActivityDisplayArea();
- if (displayAreaForLaunchingRecord != null) {
- return displayAreaForLaunchingRecord;
- }
-
- WindowProcessController controllerFromRealRequest = request == null ? null : mSupervisor
- .mService.getProcessController(request.realCallingPid, request.realCallingUid);
- final TaskDisplayArea displayAreaFromRealSource = controllerFromRealRequest == null ? null
- : controllerFromRealRequest.getTopActivityDisplayArea();
- if (displayAreaFromRealSource != null) {
- return displayAreaFromRealSource;
- }
-
- return mSupervisor.mRootWindowContainer.getDefaultTaskDisplayArea();
+ : mSupervisor.mRootWindowContainer.getDefaultTaskDisplayArea();
}
private boolean canInheritWindowingModeFromSource(@NonNull DisplayContent display,
diff --git a/services/core/java/com/android/server/wm/WindowProcessController.java b/services/core/java/com/android/server/wm/WindowProcessController.java
index bb93900878e4..4b8a398582f3 100644
--- a/services/core/java/com/android/server/wm/WindowProcessController.java
+++ b/services/core/java/com/android/server/wm/WindowProcessController.java
@@ -702,28 +702,6 @@ public class WindowProcessController extends ConfigurationContainer<Configuratio
}
}
- @Nullable
- TaskDisplayArea getTopActivityDisplayArea() {
- if (mActivities.isEmpty()) {
- return null;
- }
-
- int topActivityIndex = mActivities.size() - 1;
- ActivityRecord topRecord = mActivities.get(topActivityIndex);
- TaskDisplayArea displayArea = topRecord.getDisplayArea();
-
- for (int index = topActivityIndex - 1; index >= 0; --index) {
- ActivityRecord nextRecord = mActivities.get(index);
- TaskDisplayArea nextDisplayArea = nextRecord.getDisplayArea();
- if (nextRecord.compareTo(topRecord) > 0 && nextDisplayArea != null) {
- topRecord = nextRecord;
- displayArea = nextDisplayArea;
- }
- }
-
- return displayArea;
- }
-
private boolean hasActivityInVisibleTask() {
for (int i = mActivities.size() - 1; i >= 0; --i) {
Task task = mActivities.get(i).getTask();
diff --git a/services/tests/wmtests/src/com/android/server/wm/ActivityStarterTests.java b/services/tests/wmtests/src/com/android/server/wm/ActivityStarterTests.java
index e11474b28041..e47881917b2c 100644
--- a/services/tests/wmtests/src/com/android/server/wm/ActivityStarterTests.java
+++ b/services/tests/wmtests/src/com/android/server/wm/ActivityStarterTests.java
@@ -406,7 +406,7 @@ public class ActivityStarterTests extends WindowTestsBase {
// verify that values are passed to the modifier. Values are passed thrice -- two for
// setting initial state, another when task is created.
verify(modifier, times(3)).onCalculate(any(), eq(windowLayout), any(), any(), eq(options),
- anyInt(), any(), any(), any());
+ anyInt(), any(), any());
}
/**
diff --git a/services/tests/wmtests/src/com/android/server/wm/LaunchParamsControllerTests.java b/services/tests/wmtests/src/com/android/server/wm/LaunchParamsControllerTests.java
index fccfa8ad7a85..bc7516f6514f 100644
--- a/services/tests/wmtests/src/com/android/server/wm/LaunchParamsControllerTests.java
+++ b/services/tests/wmtests/src/com/android/server/wm/LaunchParamsControllerTests.java
@@ -33,7 +33,6 @@ import static com.android.dx.mockito.inline.extended.ExtendedMockito.spy;
import static com.android.dx.mockito.inline.extended.ExtendedMockito.spyOn;
import static com.android.dx.mockito.inline.extended.ExtendedMockito.times;
import static com.android.dx.mockito.inline.extended.ExtendedMockito.verify;
-import static com.android.server.wm.ActivityStarter.Request;
import static com.android.server.wm.LaunchParamsController.LaunchParamsModifier.PHASE_BOUNDS;
import static com.android.server.wm.LaunchParamsController.LaunchParamsModifier.RESULT_CONTINUE;
import static com.android.server.wm.LaunchParamsController.LaunchParamsModifier.RESULT_DONE;
@@ -93,12 +92,11 @@ public class LaunchParamsControllerTests extends WindowTestsBase {
final ActivityRecord source = new ActivityBuilder(mAtm).build();
final WindowLayout layout = new WindowLayout(0, 0, 0, 0, 0, 0, 0);
final ActivityOptions options = mock(ActivityOptions.class);
- final Request request = new Request();
mController.calculate(record.getTask(), layout, record, source, options, PHASE_BOUNDS,
- new LaunchParams(), request);
+ new LaunchParams());
verify(positioner, times(1)).onCalculate(eq(record.getTask()), eq(layout), eq(record),
- eq(source), eq(options), anyInt(), any(), any(), eq(request));
+ eq(source), eq(options), anyInt(), any(), any());
}
/**
@@ -121,9 +119,9 @@ public class LaunchParamsControllerTests extends WindowTestsBase {
mPersister.putLaunchParams(userId, name, expected);
mController.calculate(activity.getTask(), null /*layout*/, activity, null /*source*/,
- null /*options*/, PHASE_BOUNDS, new LaunchParams(), null /* request */);
+ null /*options*/, PHASE_BOUNDS, new LaunchParams());
verify(positioner, times(1)).onCalculate(any(), any(), any(), any(), any(), anyInt(),
- eq(expected), any(), any());
+ eq(expected), any());
}
/**
@@ -134,17 +132,16 @@ public class LaunchParamsControllerTests extends WindowTestsBase {
final LaunchParamsModifier
ignoredPositioner = mock(LaunchParamsModifier.class);
final LaunchParamsModifier earlyExitPositioner =
- (task, layout, activity, source, options, phase, currentParams, outParams, request)
+ (task, layout, activity, source, options, phase, currentParams, outParams)
-> RESULT_DONE;
mController.registerModifier(ignoredPositioner);
mController.registerModifier(earlyExitPositioner);
mController.calculate(null /*task*/, null /*layout*/, null /*activity*/,
- null /*source*/, null /*options*/, PHASE_BOUNDS, new LaunchParams(),
- null /* request */);
+ null /*source*/, null /*options*/, PHASE_BOUNDS, new LaunchParams());
verify(ignoredPositioner, never()).onCalculate(any(), any(), any(), any(), any(), anyInt(),
- any(), any(), any());
+ any(), any());
}
/**
@@ -160,22 +157,20 @@ public class LaunchParamsControllerTests extends WindowTestsBase {
mController.registerModifier(firstPositioner);
mController.calculate(null /*task*/, null /*layout*/, null /*activity*/,
- null /*source*/, null /*options*/, PHASE_BOUNDS, new LaunchParams(),
- null /* request */);
+ null /*source*/, null /*options*/, PHASE_BOUNDS, new LaunchParams());
verify(firstPositioner, times(1)).onCalculate(any(), any(), any(), any(), any(), anyInt(),
- any(), any(), any());
+ any(), any());
final LaunchParamsModifier secondPositioner = spy(earlyExitPositioner);
mController.registerModifier(secondPositioner);
mController.calculate(null /*task*/, null /*layout*/, null /*activity*/,
- null /*source*/, null /*options*/, PHASE_BOUNDS, new LaunchParams(),
- null /* request */);
+ null /*source*/, null /*options*/, PHASE_BOUNDS, new LaunchParams());
verify(firstPositioner, times(1)).onCalculate(any(), any(), any(), any(), any(), anyInt(),
- any(), any(), any());
+ any(), any());
verify(secondPositioner, times(1)).onCalculate(any(), any(), any(), any(), any(), anyInt(),
- any(), any(), any());
+ any(), any());
}
/**
@@ -197,10 +192,10 @@ public class LaunchParamsControllerTests extends WindowTestsBase {
mController.registerModifier(positioner2);
mController.calculate(null /*task*/, null /*layout*/, null /*activity*/, null /*source*/,
- null /*options*/, PHASE_BOUNDS, new LaunchParams(), null /* request */);
+ null /*options*/, PHASE_BOUNDS, new LaunchParams());
verify(positioner1, times(1)).onCalculate(any(), any(), any(), any(), any(), anyInt(),
- eq(positioner2.getLaunchParams()), any(), any());
+ eq(positioner2.getLaunchParams()), any());
}
/**
@@ -223,7 +218,7 @@ public class LaunchParamsControllerTests extends WindowTestsBase {
final LaunchParams result = new LaunchParams();
mController.calculate(null /*task*/, null /*layout*/, null /*activity*/, null /*source*/,
- null /*options*/, PHASE_BOUNDS, result, null /* request */);
+ null /*options*/, PHASE_BOUNDS, result);
assertEquals(result, positioner2.getLaunchParams());
}
@@ -242,17 +237,17 @@ public class LaunchParamsControllerTests extends WindowTestsBase {
// VR activities should always land on default display.
mController.calculate(null /*task*/, null /*layout*/, vrActivity /*activity*/,
- null /*source*/, null /*options*/, PHASE_BOUNDS, result, null /* request */);
+ null /*source*/, null /*options*/, PHASE_BOUNDS, result);
assertEquals(mRootWindowContainer.getDefaultTaskDisplayArea(),
result.mPreferredTaskDisplayArea);
// Otherwise, always lands on VR 2D display.
final ActivityRecord vr2dActivity = new ActivityBuilder(mAtm).build();
mController.calculate(null /*task*/, null /*layout*/, vr2dActivity /*activity*/,
- null /*source*/, null /*options*/, PHASE_BOUNDS, result, null /* request */);
+ null /*source*/, null /*options*/, PHASE_BOUNDS, result);
assertEquals(vrDisplay.getDefaultTaskDisplayArea(), result.mPreferredTaskDisplayArea);
mController.calculate(null /*task*/, null /*layout*/, null /*activity*/, null /*source*/,
- null /*options*/, PHASE_BOUNDS, result, null /* request */);
+ null /*options*/, PHASE_BOUNDS, result);
assertEquals(vrDisplay.getDefaultTaskDisplayArea(), result.mPreferredTaskDisplayArea);
mAtm.mVr2dDisplayId = INVALID_DISPLAY;
@@ -274,9 +269,9 @@ public class LaunchParamsControllerTests extends WindowTestsBase {
final ActivityOptions options = mock(ActivityOptions.class);
mController.calculate(record.getTask(), layout, record, source, options, PHASE_BOUNDS,
- new LaunchParams(), null /* request */);
+ new LaunchParams());
verify(positioner, times(1)).onCalculate(eq(record.getTask()), eq(layout), eq(record),
- eq(source), eq(options), eq(PHASE_BOUNDS), any(), any(), any());
+ eq(source), eq(options), eq(PHASE_BOUNDS), any(), any());
}
/**
@@ -408,9 +403,8 @@ public class LaunchParamsControllerTests extends WindowTestsBase {
@Override
public int onCalculate(Task task, WindowLayout layout, ActivityRecord activity,
- ActivityRecord source, ActivityOptions options, int phase,
- LaunchParams currentParams, LaunchParams outParams,
- Request request) {
+ ActivityRecord source, ActivityOptions options, int phase,
+ LaunchParams currentParams, LaunchParams outParams) {
outParams.set(mParams);
return mReturnVal;
}
diff --git a/services/tests/wmtests/src/com/android/server/wm/TaskLaunchParamsModifierTests.java b/services/tests/wmtests/src/com/android/server/wm/TaskLaunchParamsModifierTests.java
index 1e251732f93d..1d32e17dd5e1 100644
--- a/services/tests/wmtests/src/com/android/server/wm/TaskLaunchParamsModifierTests.java
+++ b/services/tests/wmtests/src/com/android/server/wm/TaskLaunchParamsModifierTests.java
@@ -31,15 +31,11 @@ import static android.view.Display.DEFAULT_DISPLAY;
import static com.android.dx.mockito.inline.extended.ExtendedMockito.doNothing;
import static com.android.dx.mockito.inline.extended.ExtendedMockito.spyOn;
-import static com.android.server.wm.ActivityStarter.Request;
import static com.android.server.wm.LaunchParamsController.LaunchParamsModifier.RESULT_CONTINUE;
import static com.android.server.wm.LaunchParamsController.LaunchParamsModifier.RESULT_SKIP;
import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertTrue;
-import static org.mockito.Mockito.doReturn;
-import static org.mockito.Mockito.mock;
-import static org.mockito.Mockito.when;
import android.app.ActivityOptions;
import android.content.pm.ActivityInfo;
@@ -262,139 +258,6 @@ public class TaskLaunchParamsModifierTests extends WindowTestsBase {
mResult.mPreferredTaskDisplayArea);
}
- @Test
- public void testUsesDisplayAreaFromTopMostActivityInApplicationIfAvailable() {
- final String processName = "processName";
- final int uid = 124214;
- final TestDisplayContent firstScreen = createNewDisplayContent(WINDOWING_MODE_FULLSCREEN);
- final TestDisplayContent secondScreen = createNewDisplayContent(WINDOWING_MODE_FULLSCREEN);
- final TaskDisplayArea expectedDisplayArea = secondScreen.getDefaultTaskDisplayArea();
- final WindowProcessController controller = mock(WindowProcessController.class);
-
- when(controller.getTopActivityDisplayArea()).thenReturn(expectedDisplayArea);
-
- when(mActivity.getProcessName()).thenReturn(processName);
- when(mActivity.getUid()).thenReturn(uid);
- doReturn(controller)
- .when(mSupervisor.mService)
- .getProcessController(processName, uid);
-
- assertEquals(RESULT_CONTINUE, mTarget.onCalculate(
- null /* task */,
- null /* layout */,
- mActivity /* activity */,
- null /* source */,
- null /* options */,
- -1 /* phase */,
- mCurrent,
- mResult,
- null /* request */
- ));
-
- assertEquals(expectedDisplayArea, mResult.mPreferredTaskDisplayArea);
- }
-
- @Test
- public void testUsesDisplayAreaFromLaunchingActivityIfApplicationLaunching() {
- final String processName = "processName";
- final int uid = 124214;
- final TestDisplayContent firstScreen = createNewDisplayContent(WINDOWING_MODE_FULLSCREEN);
- final TestDisplayContent secondScreen = createNewDisplayContent(WINDOWING_MODE_FULLSCREEN);
- final TaskDisplayArea expectedTaskDisplayArea = secondScreen.getDefaultTaskDisplayArea();
- final WindowProcessController controller = mock(WindowProcessController.class);
-
- when(controller.getTopActivityDisplayArea()).thenReturn(expectedTaskDisplayArea);
-
- when(mActivity.getProcessName()).thenReturn(processName);
- when(mActivity.getUid()).thenReturn(uid);
- doReturn(null)
- .when(mSupervisor.mService)
- .getProcessController(processName, uid);
-
- doReturn(controller)
- .when(mSupervisor.mService)
- .getProcessController(mActivity.launchedFromPid, mActivity.launchedFromUid);
-
- assertEquals(RESULT_CONTINUE, mTarget.onCalculate(
- null /* task */,
- null /* layout */,
- mActivity /* activity */,
- null /* source */,
- null /* options */,
- -1 /* phase */,
- mCurrent,
- mResult,
- null /* request */
- ));
-
- assertEquals(expectedTaskDisplayArea, mResult.mPreferredTaskDisplayArea);
- }
-
- @Test
- public void testUsesDisplayAreaOriginalProcessAsLastResort() {
- final TestDisplayContent firstScreen = createNewDisplayContent(WINDOWING_MODE_FULLSCREEN);
- final TestDisplayContent secondScreen = createNewDisplayContent(WINDOWING_MODE_FULLSCREEN);
- final TaskDisplayArea expectedTaskDisplayArea = secondScreen.getDefaultTaskDisplayArea();
- final Request request = new Request();
- request.realCallingPid = 12412413;
- request.realCallingUid = 235424;
-
- final WindowProcessController controller = mock(WindowProcessController.class);
-
- when(controller.getTopActivityDisplayArea()).thenReturn(expectedTaskDisplayArea);
-
- doReturn(null)
- .when(mSupervisor.mService)
- .getProcessController(mActivity.processName, mActivity.info.applicationInfo.uid);
-
- doReturn(null)
- .when(mSupervisor.mService)
- .getProcessController(mActivity.launchedFromPid, mActivity.launchedFromUid);
-
- doReturn(controller)
- .when(mSupervisor.mService)
- .getProcessController(request.realCallingPid, request.realCallingUid);
-
- assertEquals(RESULT_CONTINUE, mTarget.onCalculate(
- null /* task */,
- null /* layout */,
- mActivity /* activity */,
- null /* source */,
- null /* options */,
- -1 /* phase */,
- mCurrent,
- mResult,
- request
- ));
-
- assertEquals(expectedTaskDisplayArea, mResult.mPreferredTaskDisplayArea);
- }
-
- @Test
- public void testUsesDefaultDisplayAreaIfWindowProcessControllerIsNotPresent() {
- doReturn(null)
- .when(mSupervisor.mService)
- .getProcessController(mActivity.processName, mActivity.info.applicationInfo.uid);
-
- doReturn(null)
- .when(mSupervisor.mService)
- .getProcessController(mActivity.launchedFromPid, mActivity.launchedFromUid);
-
- assertEquals(RESULT_CONTINUE, mTarget.onCalculate(
- null /* task */,
- null /* layout */,
- mActivity /* activity */,
- null /* source */,
- null /* options */,
- -1 /* phase */,
- mCurrent,
- mResult,
- null /* request */
- ));
-
- assertEquals(DEFAULT_DISPLAY, mResult.mPreferredTaskDisplayArea.getDisplayId());
- }
-
// =====================================
// Launch Windowing Mode Related Tests
// =====================================
diff --git a/services/tests/wmtests/src/com/android/server/wm/WindowProcessControllerTests.java b/services/tests/wmtests/src/com/android/server/wm/WindowProcessControllerTests.java
index 8180776e3901..e50c00975a7f 100644
--- a/services/tests/wmtests/src/com/android/server/wm/WindowProcessControllerTests.java
+++ b/services/tests/wmtests/src/com/android/server/wm/WindowProcessControllerTests.java
@@ -24,10 +24,8 @@ import static android.view.Display.INVALID_DISPLAY;
import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertFalse;
-import static org.junit.Assert.assertNull;
import static org.junit.Assert.assertTrue;
import static org.mockito.ArgumentMatchers.eq;
-import static org.mockito.Mockito.doReturn;
import static org.mockito.Mockito.mock;
import static org.mockito.Mockito.times;
import static org.mockito.Mockito.when;
@@ -342,45 +340,6 @@ public class WindowProcessControllerTests extends WindowTestsBase {
assertEquals(other, callbackResult[0]);
}
- @Test
- public void testTopActivityDisplayAreaMatchesTopMostActivity_noActivities() {
- assertNull(mWpc.getTopActivityDisplayArea());
- }
-
- @Test
- public void testTopActivityDisplayAreaMatchesTopMostActivity_singleActivity() {
- final ActivityRecord activityRecord = new ActivityBuilder(mSupervisor.mService).build();
- final TaskDisplayArea expectedDisplayArea = mock(TaskDisplayArea.class);
-
- when(activityRecord.getDisplayArea())
- .thenReturn(expectedDisplayArea);
-
- mWpc.addActivityIfNeeded(activityRecord);
-
- assertEquals(expectedDisplayArea, mWpc.getTopActivityDisplayArea());
- }
-
- /**
- * Test that top most activity respects z-order.
- */
- @Test
- public void testTopActivityDisplayAreaMatchesTopMostActivity_multipleActivities() {
- final ActivityRecord bottomRecord = new ActivityBuilder(mSupervisor.mService).build();
- final TaskDisplayArea bottomDisplayArea = mock(TaskDisplayArea.class);
- final ActivityRecord topRecord = new ActivityBuilder(mSupervisor.mService).build();
- final TaskDisplayArea topDisplayArea = mock(TaskDisplayArea.class);
-
- when(bottomRecord.getDisplayArea()).thenReturn(bottomDisplayArea);
- when(topRecord.getDisplayArea()).thenReturn(topDisplayArea);
- doReturn(-1).when(bottomRecord).compareTo(topRecord);
- doReturn(1).when(topRecord).compareTo(bottomRecord);
-
- mWpc.addActivityIfNeeded(topRecord);
- mWpc.addActivityIfNeeded(bottomRecord);
-
- assertEquals(topDisplayArea, mWpc.getTopActivityDisplayArea());
- }
-
private TestDisplayContent createTestDisplayContentInContainer() {
return new TestDisplayContent.Builder(mAtm, 1000, 1500).build();
}