Wale Ogunwale | 44fbdf5 | 2016-11-16 10:18:45 -0800 | [diff] [blame] | 1 | /* |
| 2 | * Copyright (C) 2016 The Android Open Source Project |
| 3 | * |
| 4 | * Licensed under the Apache License, Version 2.0 (the "License"); |
| 5 | * you may not use this file except in compliance with the License. |
| 6 | * You may obtain a copy of the License at |
| 7 | * |
| 8 | * http://www.apache.org/licenses/LICENSE-2.0 |
| 9 | * |
| 10 | * Unless required by applicable law or agreed to in writing, software |
| 11 | * distributed under the License is distributed on an "AS IS" BASIS, |
| 12 | * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| 13 | * See the License for the specific language governing permissions and |
| 14 | * limitations under the License |
| 15 | */ |
| 16 | |
| 17 | package com.android.server.wm; |
| 18 | |
Wale Ogunwale | 6827856 | 2017-09-23 17:13:55 -0700 | [diff] [blame] | 19 | import static android.app.WindowConfiguration.ACTIVITY_TYPE_STANDARD; |
| 20 | import static android.app.WindowConfiguration.WINDOWING_MODE_FULLSCREEN; |
Wale Ogunwale | 11cc516 | 2017-04-25 20:29:13 -0700 | [diff] [blame] | 21 | import static android.view.Display.DEFAULT_DISPLAY; |
David Stevens | 4693956 | 2017-03-24 13:04:00 -0700 | [diff] [blame] | 22 | import static android.view.View.VISIBLE; |
| 23 | |
Wale Ogunwale | 687b427 | 2017-07-27 02:56:23 -0700 | [diff] [blame] | 24 | import android.content.res.Configuration; |
Wale Ogunwale | c5cc301 | 2017-01-13 13:26:16 -0800 | [diff] [blame] | 25 | import android.graphics.Rect; |
Andrii Kulian | 367ff7f | 2017-01-25 19:45:34 -0800 | [diff] [blame] | 26 | import android.hardware.display.DisplayManagerGlobal; |
Andrii Kulian | 367ff7f | 2017-01-25 19:45:34 -0800 | [diff] [blame] | 27 | import android.view.Display; |
| 28 | import android.view.DisplayInfo; |
Wale Ogunwale | 44fbdf5 | 2016-11-16 10:18:45 -0800 | [diff] [blame] | 29 | import org.junit.Assert; |
Wale Ogunwale | 17f175c | 2017-02-07 16:54:10 -0800 | [diff] [blame] | 30 | import org.junit.After; |
Wale Ogunwale | 44fbdf5 | 2016-11-16 10:18:45 -0800 | [diff] [blame] | 31 | import org.junit.Before; |
Jorim Jaggi | 9bafc71 | 2017-01-19 17:28:30 +0100 | [diff] [blame] | 32 | import org.mockito.MockitoAnnotations; |
Wale Ogunwale | 44fbdf5 | 2016-11-16 10:18:45 -0800 | [diff] [blame] | 33 | |
| 34 | import android.content.Context; |
Wale Ogunwale | 44fbdf5 | 2016-11-16 10:18:45 -0800 | [diff] [blame] | 35 | import android.support.test.InstrumentationRegistry; |
Wale Ogunwale | 44fbdf5 | 2016-11-16 10:18:45 -0800 | [diff] [blame] | 36 | import android.view.IWindow; |
| 37 | import android.view.WindowManager; |
| 38 | |
| 39 | import static android.app.ActivityManager.StackId.FIRST_DYNAMIC_STACK_ID; |
Winson Chung | 8347163 | 2016-12-13 11:02:12 -0800 | [diff] [blame] | 40 | import static android.app.ActivityManager.StackId.INVALID_STACK_ID; |
Wale Ogunwale | 44fbdf5 | 2016-11-16 10:18:45 -0800 | [diff] [blame] | 41 | import static android.app.AppOpsManager.OP_NONE; |
Andrii Kulian | 367ff7f | 2017-01-25 19:45:34 -0800 | [diff] [blame] | 42 | import static android.view.DisplayAdjustments.DEFAULT_DISPLAY_ADJUSTMENTS; |
Wale Ogunwale | 44fbdf5 | 2016-11-16 10:18:45 -0800 | [diff] [blame] | 43 | import static android.view.WindowManager.LayoutParams.FIRST_APPLICATION_WINDOW; |
Wale Ogunwale | 3424795 | 2017-02-19 11:57:53 -0800 | [diff] [blame] | 44 | import static android.view.WindowManager.LayoutParams.FLAG_NOT_FOCUSABLE; |
Wale Ogunwale | 44fbdf5 | 2016-11-16 10:18:45 -0800 | [diff] [blame] | 45 | import static android.view.WindowManager.LayoutParams.LAST_APPLICATION_WINDOW; |
Wale Ogunwale | 3c1170d | 2016-12-02 14:44:52 -0800 | [diff] [blame] | 46 | import static android.view.WindowManager.LayoutParams.TYPE_APPLICATION_ATTACHED_DIALOG; |
| 47 | import static android.view.WindowManager.LayoutParams.TYPE_APPLICATION_MEDIA_OVERLAY; |
| 48 | import static android.view.WindowManager.LayoutParams.TYPE_BASE_APPLICATION; |
| 49 | import static android.view.WindowManager.LayoutParams.TYPE_DOCK_DIVIDER; |
| 50 | import static android.view.WindowManager.LayoutParams.TYPE_INPUT_METHOD; |
| 51 | import static android.view.WindowManager.LayoutParams.TYPE_INPUT_METHOD_DIALOG; |
| 52 | import static android.view.WindowManager.LayoutParams.TYPE_NAVIGATION_BAR; |
| 53 | import static android.view.WindowManager.LayoutParams.TYPE_STATUS_BAR; |
| 54 | import static android.view.WindowManager.LayoutParams.TYPE_WALLPAPER; |
Wale Ogunwale | 44fbdf5 | 2016-11-16 10:18:45 -0800 | [diff] [blame] | 55 | import static org.mockito.Mockito.mock; |
| 56 | |
Jorim Jaggi | 9bafc71 | 2017-01-19 17:28:30 +0100 | [diff] [blame] | 57 | import com.android.server.AttributeCache; |
Wale Ogunwale | 17f175c | 2017-02-07 16:54:10 -0800 | [diff] [blame] | 58 | |
| 59 | import java.util.HashSet; |
Wale Ogunwale | 3424795 | 2017-02-19 11:57:53 -0800 | [diff] [blame] | 60 | import java.util.LinkedList; |
Jorim Jaggi | 9bafc71 | 2017-01-19 17:28:30 +0100 | [diff] [blame] | 61 | |
Wale Ogunwale | 44fbdf5 | 2016-11-16 10:18:45 -0800 | [diff] [blame] | 62 | /** |
| 63 | * Common base class for window manager unit test classes. |
| 64 | */ |
Wale Ogunwale | 26c0dfe | 2016-12-14 14:42:30 -0800 | [diff] [blame] | 65 | class WindowTestsBase { |
Wale Ogunwale | 44fbdf5 | 2016-11-16 10:18:45 -0800 | [diff] [blame] | 66 | static WindowManagerService sWm = null; |
Wale Ogunwale | 11cc516 | 2017-04-25 20:29:13 -0700 | [diff] [blame] | 67 | private static final IWindow sIWindow = new TestIWindow(); |
| 68 | private static final Session sMockSession = mock(Session.class); |
Bryce Lee | 310de9e | 2017-03-15 10:18:21 -0700 | [diff] [blame] | 69 | // The default display is removed in {@link #setUp} and then we iterate over all displays to |
| 70 | // make sure we don't collide with any existing display. If we run into no other display, the |
Bryce Lee | 6272c7f | 2017-03-17 17:22:35 -0700 | [diff] [blame] | 71 | // added display should be treated as default. This cannot be the default display |
Wale Ogunwale | 11cc516 | 2017-04-25 20:29:13 -0700 | [diff] [blame] | 72 | private static int sNextDisplayId = DEFAULT_DISPLAY + 1; |
Bryce Lee | af691c0 | 2017-03-20 14:20:22 -0700 | [diff] [blame] | 73 | private static int sNextStackId = FIRST_DYNAMIC_STACK_ID; |
Wale Ogunwale | 44fbdf5 | 2016-11-16 10:18:45 -0800 | [diff] [blame] | 74 | |
Wale Ogunwale | 3c1170d | 2016-12-02 14:44:52 -0800 | [diff] [blame] | 75 | private static boolean sOneTimeSetupDone = false; |
Wale Ogunwale | 11cc516 | 2017-04-25 20:29:13 -0700 | [diff] [blame] | 76 | DisplayContent mDisplayContent; |
| 77 | DisplayInfo mDisplayInfo = new DisplayInfo(); |
| 78 | WindowLayersController mLayersController; |
| 79 | WindowState mWallpaperWindow; |
| 80 | WindowState mImeWindow; |
| 81 | WindowState mImeDialogWindow; |
| 82 | WindowState mStatusBarWindow; |
| 83 | WindowState mDockedDividerWindow; |
| 84 | WindowState mNavBarWindow; |
| 85 | WindowState mAppWindow; |
| 86 | WindowState mChildAppWindowAbove; |
| 87 | WindowState mChildAppWindowBelow; |
| 88 | HashSet<WindowState> mCommonWindows; |
Wale Ogunwale | 3c1170d | 2016-12-02 14:44:52 -0800 | [diff] [blame] | 89 | |
Wale Ogunwale | 44fbdf5 | 2016-11-16 10:18:45 -0800 | [diff] [blame] | 90 | @Before |
| 91 | public void setUp() throws Exception { |
Wale Ogunwale | 11cc516 | 2017-04-25 20:29:13 -0700 | [diff] [blame] | 92 | if (!sOneTimeSetupDone) { |
| 93 | sOneTimeSetupDone = true; |
| 94 | MockitoAnnotations.initMocks(this); |
Wale Ogunwale | 3c1170d | 2016-12-02 14:44:52 -0800 | [diff] [blame] | 95 | } |
Wale Ogunwale | 11cc516 | 2017-04-25 20:29:13 -0700 | [diff] [blame] | 96 | |
Wale Ogunwale | 44fbdf5 | 2016-11-16 10:18:45 -0800 | [diff] [blame] | 97 | final Context context = InstrumentationRegistry.getTargetContext(); |
Jorim Jaggi | 9bafc71 | 2017-01-19 17:28:30 +0100 | [diff] [blame] | 98 | AttributeCache.init(context); |
Wale Ogunwale | 44fbdf5 | 2016-11-16 10:18:45 -0800 | [diff] [blame] | 99 | sWm = TestWindowManagerPolicy.getWindowManagerService(context); |
Wale Ogunwale | 11cc516 | 2017-04-25 20:29:13 -0700 | [diff] [blame] | 100 | mLayersController = new WindowLayersController(sWm); |
Bryce Lee | 6272c7f | 2017-03-17 17:22:35 -0700 | [diff] [blame] | 101 | |
Wale Ogunwale | 11cc516 | 2017-04-25 20:29:13 -0700 | [diff] [blame] | 102 | context.getDisplay().getDisplayInfo(mDisplayInfo); |
| 103 | mDisplayContent = createNewDisplay(); |
Jorim Jaggi | 9bafc71 | 2017-01-19 17:28:30 +0100 | [diff] [blame] | 104 | sWm.mDisplayEnabled = true; |
| 105 | sWm.mDisplayReady = true; |
Wale Ogunwale | 3c1170d | 2016-12-02 14:44:52 -0800 | [diff] [blame] | 106 | |
| 107 | // Set-up some common windows. |
Wale Ogunwale | 11cc516 | 2017-04-25 20:29:13 -0700 | [diff] [blame] | 108 | mCommonWindows = new HashSet(); |
| 109 | mWallpaperWindow = createCommonWindow(null, TYPE_WALLPAPER, "wallpaperWindow"); |
| 110 | mImeWindow = createCommonWindow(null, TYPE_INPUT_METHOD, "mImeWindow"); |
| 111 | sWm.mInputMethodWindow = mImeWindow; |
| 112 | mImeDialogWindow = createCommonWindow(null, TYPE_INPUT_METHOD_DIALOG, "mImeDialogWindow"); |
| 113 | mStatusBarWindow = createCommonWindow(null, TYPE_STATUS_BAR, "mStatusBarWindow"); |
| 114 | mNavBarWindow = createCommonWindow(null, TYPE_NAVIGATION_BAR, "mNavBarWindow"); |
| 115 | mDockedDividerWindow = createCommonWindow(null, TYPE_DOCK_DIVIDER, "mDockedDividerWindow"); |
| 116 | mAppWindow = createCommonWindow(null, TYPE_BASE_APPLICATION, "mAppWindow"); |
| 117 | mChildAppWindowAbove = createCommonWindow(mAppWindow, TYPE_APPLICATION_ATTACHED_DIALOG, |
| 118 | "mChildAppWindowAbove"); |
| 119 | mChildAppWindowBelow = createCommonWindow(mAppWindow, TYPE_APPLICATION_MEDIA_OVERLAY, |
| 120 | "mChildAppWindowBelow"); |
Jorim Jaggi | 153badb | 2017-05-24 13:18:28 +0200 | [diff] [blame] | 121 | |
| 122 | // Adding a display will cause freezing the display. Make sure to wait until it's unfrozen |
| 123 | // to not run into race conditions with the tests. |
| 124 | waitUntilHandlersIdle(); |
Wale Ogunwale | 17f175c | 2017-02-07 16:54:10 -0800 | [diff] [blame] | 125 | } |
| 126 | |
| 127 | @After |
| 128 | public void tearDown() throws Exception { |
Wale Ogunwale | 3424795 | 2017-02-19 11:57:53 -0800 | [diff] [blame] | 129 | final LinkedList<WindowState> nonCommonWindows = new LinkedList(); |
Wale Ogunwale | 027f475 | 2017-05-12 10:37:16 -0700 | [diff] [blame] | 130 | |
| 131 | synchronized (sWm.mWindowMap) { |
| 132 | sWm.mRoot.forAllWindows(w -> { |
| 133 | if (!mCommonWindows.contains(w)) { |
| 134 | nonCommonWindows.addLast(w); |
| 135 | } |
| 136 | }, true /* traverseTopToBottom */); |
| 137 | |
| 138 | while (!nonCommonWindows.isEmpty()) { |
| 139 | nonCommonWindows.pollLast().removeImmediately(); |
Wale Ogunwale | 17f175c | 2017-02-07 16:54:10 -0800 | [diff] [blame] | 140 | } |
Wale Ogunwale | 3424795 | 2017-02-19 11:57:53 -0800 | [diff] [blame] | 141 | |
Wale Ogunwale | 027f475 | 2017-05-12 10:37:16 -0700 | [diff] [blame] | 142 | mDisplayContent.removeImmediately(); |
| 143 | sWm.mInputMethodTarget = null; |
Wale Ogunwale | 3424795 | 2017-02-19 11:57:53 -0800 | [diff] [blame] | 144 | } |
Jorim Jaggi | 153badb | 2017-05-24 13:18:28 +0200 | [diff] [blame] | 145 | |
| 146 | // Wait until everything is really cleaned up. |
| 147 | waitUntilHandlersIdle(); |
Wale Ogunwale | 17f175c | 2017-02-07 16:54:10 -0800 | [diff] [blame] | 148 | } |
| 149 | |
Wale Ogunwale | 11cc516 | 2017-04-25 20:29:13 -0700 | [diff] [blame] | 150 | private WindowState createCommonWindow(WindowState parent, int type, String name) { |
Wale Ogunwale | 17f175c | 2017-02-07 16:54:10 -0800 | [diff] [blame] | 151 | final WindowState win = createWindow(parent, type, name); |
Wale Ogunwale | 11cc516 | 2017-04-25 20:29:13 -0700 | [diff] [blame] | 152 | mCommonWindows.add(win); |
Wale Ogunwale | 3424795 | 2017-02-19 11:57:53 -0800 | [diff] [blame] | 153 | // Prevent common windows from been IMe targets |
| 154 | win.mAttrs.flags |= FLAG_NOT_FOCUSABLE; |
Wale Ogunwale | 17f175c | 2017-02-07 16:54:10 -0800 | [diff] [blame] | 155 | return win; |
Wale Ogunwale | 44fbdf5 | 2016-11-16 10:18:45 -0800 | [diff] [blame] | 156 | } |
| 157 | |
| 158 | /** Asserts that the first entry is greater than the second entry. */ |
| 159 | void assertGreaterThan(int first, int second) throws Exception { |
| 160 | Assert.assertTrue("Excepted " + first + " to be greater than " + second, first > second); |
| 161 | } |
| 162 | |
Jorim Jaggi | 9bafc71 | 2017-01-19 17:28:30 +0100 | [diff] [blame] | 163 | /** |
| 164 | * Waits until the main handler for WM has processed all messages. |
| 165 | */ |
Jorim Jaggi | ed7993b | 2017-03-28 18:50:01 +0100 | [diff] [blame] | 166 | void waitUntilHandlersIdle() { |
Jorim Jaggi | 9bafc71 | 2017-01-19 17:28:30 +0100 | [diff] [blame] | 167 | sWm.mH.runWithScissors(() -> { }, 0); |
Jorim Jaggi | ed7993b | 2017-03-28 18:50:01 +0100 | [diff] [blame] | 168 | sWm.mAnimationHandler.runWithScissors(() -> { }, 0); |
Jorim Jaggi | 9bafc71 | 2017-01-19 17:28:30 +0100 | [diff] [blame] | 169 | } |
| 170 | |
Wale Ogunwale | 6827856 | 2017-09-23 17:13:55 -0700 | [diff] [blame] | 171 | private WindowToken createWindowToken( |
| 172 | DisplayContent dc, int windowingMode, int activityType, int type) { |
Wale Ogunwale | 44fbdf5 | 2016-11-16 10:18:45 -0800 | [diff] [blame] | 173 | if (type < FIRST_APPLICATION_WINDOW || type > LAST_APPLICATION_WINDOW) { |
Bryce Lee | af691c0 | 2017-03-20 14:20:22 -0700 | [diff] [blame] | 174 | return new WindowTestUtils.TestWindowToken(type, dc); |
Wale Ogunwale | 44fbdf5 | 2016-11-16 10:18:45 -0800 | [diff] [blame] | 175 | } |
| 176 | |
Wale Ogunwale | 6827856 | 2017-09-23 17:13:55 -0700 | [diff] [blame] | 177 | final TaskStack stack = |
| 178 | createStackControllerOnStackOnDisplay(windowingMode, activityType, dc).mContainer; |
Andrii Kulian | d276563 | 2016-12-12 22:26:34 -0800 | [diff] [blame] | 179 | final Task task = createTaskInStack(stack, 0 /* userId */); |
Bryce Lee | af691c0 | 2017-03-20 14:20:22 -0700 | [diff] [blame] | 180 | final WindowTestUtils.TestAppWindowToken token = new WindowTestUtils.TestAppWindowToken(dc); |
Wale Ogunwale | 72919d2 | 2016-12-08 18:58:50 -0800 | [diff] [blame] | 181 | task.addChild(token, 0); |
Wale Ogunwale | 44fbdf5 | 2016-11-16 10:18:45 -0800 | [diff] [blame] | 182 | return token; |
| 183 | } |
| 184 | |
Wale Ogunwale | 11cc516 | 2017-04-25 20:29:13 -0700 | [diff] [blame] | 185 | WindowState createWindow(WindowState parent, int type, String name) { |
Wale Ogunwale | 805d9ec | 2016-12-07 12:22:08 -0800 | [diff] [blame] | 186 | return (parent == null) |
Wale Ogunwale | 11cc516 | 2017-04-25 20:29:13 -0700 | [diff] [blame] | 187 | ? createWindow(parent, type, mDisplayContent, name) |
Wale Ogunwale | 805d9ec | 2016-12-07 12:22:08 -0800 | [diff] [blame] | 188 | : createWindow(parent, type, parent.mToken, name); |
| 189 | } |
| 190 | |
Wale Ogunwale | 6827856 | 2017-09-23 17:13:55 -0700 | [diff] [blame] | 191 | WindowState createWindowOnStack(WindowState parent, int windowingMode, int activityType, |
| 192 | int type, DisplayContent dc, String name) { |
| 193 | final WindowToken token = createWindowToken(dc, windowingMode, activityType, type); |
Winson Chung | 8347163 | 2016-12-13 11:02:12 -0800 | [diff] [blame] | 194 | return createWindow(parent, type, token, name); |
| 195 | } |
| 196 | |
Jorim Jaggi | 02886a8 | 2016-12-06 09:10:06 -0800 | [diff] [blame] | 197 | WindowState createAppWindow(Task task, int type, String name) { |
Wale Ogunwale | 11cc516 | 2017-04-25 20:29:13 -0700 | [diff] [blame] | 198 | final AppWindowToken token = new WindowTestUtils.TestAppWindowToken(mDisplayContent); |
Jorim Jaggi | 02886a8 | 2016-12-06 09:10:06 -0800 | [diff] [blame] | 199 | task.addChild(token, 0); |
| 200 | return createWindow(null, type, token, name); |
| 201 | } |
| 202 | |
Wale Ogunwale | 11cc516 | 2017-04-25 20:29:13 -0700 | [diff] [blame] | 203 | WindowState createWindow(WindowState parent, int type, DisplayContent dc, String name) { |
Wale Ogunwale | 6827856 | 2017-09-23 17:13:55 -0700 | [diff] [blame] | 204 | final WindowToken token = createWindowToken( |
| 205 | dc, WINDOWING_MODE_FULLSCREEN, ACTIVITY_TYPE_STANDARD, type); |
Wale Ogunwale | 44fbdf5 | 2016-11-16 10:18:45 -0800 | [diff] [blame] | 206 | return createWindow(parent, type, token, name); |
| 207 | } |
| 208 | |
Wale Ogunwale | 11cc516 | 2017-04-25 20:29:13 -0700 | [diff] [blame] | 209 | WindowState createWindow(WindowState parent, int type, DisplayContent dc, String name, |
Wale Ogunwale | 17f175c | 2017-02-07 16:54:10 -0800 | [diff] [blame] | 210 | boolean ownerCanAddInternalSystemWindow) { |
Wale Ogunwale | 6827856 | 2017-09-23 17:13:55 -0700 | [diff] [blame] | 211 | final WindowToken token = createWindowToken( |
| 212 | dc, WINDOWING_MODE_FULLSCREEN, ACTIVITY_TYPE_STANDARD, type); |
Wale Ogunwale | 17f175c | 2017-02-07 16:54:10 -0800 | [diff] [blame] | 213 | return createWindow(parent, type, token, name, ownerCanAddInternalSystemWindow); |
| 214 | } |
| 215 | |
Jorim Jaggi | 9bafc71 | 2017-01-19 17:28:30 +0100 | [diff] [blame] | 216 | static WindowState createWindow(WindowState parent, int type, WindowToken token, String name) { |
Wale Ogunwale | 17f175c | 2017-02-07 16:54:10 -0800 | [diff] [blame] | 217 | return createWindow(parent, type, token, name, false /* ownerCanAddInternalSystemWindow */); |
| 218 | } |
| 219 | |
| 220 | static WindowState createWindow(WindowState parent, int type, WindowToken token, String name, |
| 221 | boolean ownerCanAddInternalSystemWindow) { |
Wale Ogunwale | 44fbdf5 | 2016-11-16 10:18:45 -0800 | [diff] [blame] | 222 | final WindowManager.LayoutParams attrs = new WindowManager.LayoutParams(type); |
| 223 | attrs.setTitle(name); |
| 224 | |
Wale Ogunwale | 8e44f6c | 2017-03-09 15:25:10 -0800 | [diff] [blame] | 225 | final WindowState w = new WindowState(sWm, sMockSession, sIWindow, token, parent, OP_NONE, |
David Stevens | 4693956 | 2017-03-24 13:04:00 -0700 | [diff] [blame] | 226 | 0, attrs, VISIBLE, 0, ownerCanAddInternalSystemWindow); |
Wale Ogunwale | 44fbdf5 | 2016-11-16 10:18:45 -0800 | [diff] [blame] | 227 | // TODO: Probably better to make this call in the WindowState ctor to avoid errors with |
| 228 | // adding it to the token... |
| 229 | token.addWindow(w); |
| 230 | return w; |
| 231 | } |
Wale Ogunwale | 3d0bfd9 | 2016-12-05 11:38:02 -0800 | [diff] [blame] | 232 | |
Andrii Kulian | d276563 | 2016-12-12 22:26:34 -0800 | [diff] [blame] | 233 | /** Creates a {@link TaskStack} and adds it to the specified {@link DisplayContent}. */ |
Wale Ogunwale | 11cc516 | 2017-04-25 20:29:13 -0700 | [diff] [blame] | 234 | TaskStack createTaskStackOnDisplay(DisplayContent dc) { |
Wale Ogunwale | 1666e31 | 2016-12-16 11:27:18 -0800 | [diff] [blame] | 235 | return createStackControllerOnDisplay(dc).mContainer; |
| 236 | } |
| 237 | |
Wale Ogunwale | 11cc516 | 2017-04-25 20:29:13 -0700 | [diff] [blame] | 238 | StackWindowController createStackControllerOnDisplay(DisplayContent dc) { |
Wale Ogunwale | 6827856 | 2017-09-23 17:13:55 -0700 | [diff] [blame] | 239 | return createStackControllerOnStackOnDisplay( |
| 240 | WINDOWING_MODE_FULLSCREEN, ACTIVITY_TYPE_STANDARD, dc); |
Winson Chung | 8347163 | 2016-12-13 11:02:12 -0800 | [diff] [blame] | 241 | } |
| 242 | |
Wale Ogunwale | 6827856 | 2017-09-23 17:13:55 -0700 | [diff] [blame] | 243 | StackWindowController createStackControllerOnStackOnDisplay( |
| 244 | int windowingMode, int activityType, DisplayContent dc) { |
Wale Ogunwale | f75962a | 2017-08-23 14:58:04 -0700 | [diff] [blame] | 245 | final Configuration overrideConfig = new Configuration(); |
Wale Ogunwale | 6827856 | 2017-09-23 17:13:55 -0700 | [diff] [blame] | 246 | overrideConfig.windowConfiguration.setWindowingMode(windowingMode); |
| 247 | overrideConfig.windowConfiguration.setActivityType(activityType); |
| 248 | final int stackId = ++sNextStackId; |
Wale Ogunwale | 034a8ec | 2017-09-02 17:14:40 -0700 | [diff] [blame] | 249 | final StackWindowController controller = new StackWindowController(stackId, null, |
| 250 | dc.getDisplayId(), true /* onTop */, new Rect(), sWm); |
| 251 | controller.onOverrideConfigurationChanged(overrideConfig); |
| 252 | return controller; |
Andrii Kulian | d276563 | 2016-12-12 22:26:34 -0800 | [diff] [blame] | 253 | } |
| 254 | |
Andrii Kulian | 367ff7f | 2017-01-25 19:45:34 -0800 | [diff] [blame] | 255 | /** Creates a {@link Task} and adds it to the specified {@link TaskStack}. */ |
Wale Ogunwale | 11cc516 | 2017-04-25 20:29:13 -0700 | [diff] [blame] | 256 | Task createTaskInStack(TaskStack stack, int userId) { |
Bryce Lee | af691c0 | 2017-03-20 14:20:22 -0700 | [diff] [blame] | 257 | return WindowTestUtils.createTaskInStack(sWm, stack, userId); |
Andrii Kulian | d276563 | 2016-12-12 22:26:34 -0800 | [diff] [blame] | 258 | } |
| 259 | |
Andrii Kulian | 367ff7f | 2017-01-25 19:45:34 -0800 | [diff] [blame] | 260 | /** Creates a {@link DisplayContent} and adds it to the system. */ |
| 261 | DisplayContent createNewDisplay() { |
| 262 | final int displayId = sNextDisplayId++; |
| 263 | final Display display = new Display(DisplayManagerGlobal.getInstance(), displayId, |
Wale Ogunwale | 11cc516 | 2017-04-25 20:29:13 -0700 | [diff] [blame] | 264 | mDisplayInfo, DEFAULT_DISPLAY_ADJUSTMENTS); |
| 265 | return new DisplayContent(display, sWm, mLayersController, new WallpaperController(sWm)); |
Andrii Kulian | 367ff7f | 2017-01-25 19:45:34 -0800 | [diff] [blame] | 266 | } |
| 267 | |
Bryce Lee | af691c0 | 2017-03-20 14:20:22 -0700 | [diff] [blame] | 268 | /** Creates a {@link com.android.server.wm.WindowTestUtils.TestWindowState} */ |
| 269 | WindowTestUtils.TestWindowState createWindowState(WindowManager.LayoutParams attrs, |
| 270 | WindowToken token) { |
| 271 | return new WindowTestUtils.TestWindowState(sWm, sMockSession, sIWindow, attrs, token); |
Wale Ogunwale | 3d0bfd9 | 2016-12-05 11:38:02 -0800 | [diff] [blame] | 272 | } |
| 273 | |
Wale Ogunwale | 44fbdf5 | 2016-11-16 10:18:45 -0800 | [diff] [blame] | 274 | } |