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 | |
Wale Ogunwale | 44fbdf5 | 2016-11-16 10:18:45 -0800 | [diff] [blame] | 39 | import static android.app.AppOpsManager.OP_NONE; |
Andrii Kulian | 367ff7f | 2017-01-25 19:45:34 -0800 | [diff] [blame] | 40 | import static android.view.DisplayAdjustments.DEFAULT_DISPLAY_ADJUSTMENTS; |
Wale Ogunwale | 44fbdf5 | 2016-11-16 10:18:45 -0800 | [diff] [blame] | 41 | import static android.view.WindowManager.LayoutParams.FIRST_APPLICATION_WINDOW; |
Wale Ogunwale | 3424795 | 2017-02-19 11:57:53 -0800 | [diff] [blame] | 42 | import static android.view.WindowManager.LayoutParams.FLAG_NOT_FOCUSABLE; |
Wale Ogunwale | 44fbdf5 | 2016-11-16 10:18:45 -0800 | [diff] [blame] | 43 | import static android.view.WindowManager.LayoutParams.LAST_APPLICATION_WINDOW; |
Wale Ogunwale | 3c1170d | 2016-12-02 14:44:52 -0800 | [diff] [blame] | 44 | import static android.view.WindowManager.LayoutParams.TYPE_APPLICATION_ATTACHED_DIALOG; |
| 45 | import static android.view.WindowManager.LayoutParams.TYPE_APPLICATION_MEDIA_OVERLAY; |
| 46 | import static android.view.WindowManager.LayoutParams.TYPE_BASE_APPLICATION; |
| 47 | import static android.view.WindowManager.LayoutParams.TYPE_DOCK_DIVIDER; |
| 48 | import static android.view.WindowManager.LayoutParams.TYPE_INPUT_METHOD; |
| 49 | import static android.view.WindowManager.LayoutParams.TYPE_INPUT_METHOD_DIALOG; |
| 50 | import static android.view.WindowManager.LayoutParams.TYPE_NAVIGATION_BAR; |
| 51 | import static android.view.WindowManager.LayoutParams.TYPE_STATUS_BAR; |
| 52 | import static android.view.WindowManager.LayoutParams.TYPE_WALLPAPER; |
Wale Ogunwale | 44fbdf5 | 2016-11-16 10:18:45 -0800 | [diff] [blame] | 53 | import static org.mockito.Mockito.mock; |
| 54 | |
Jorim Jaggi | 9bafc71 | 2017-01-19 17:28:30 +0100 | [diff] [blame] | 55 | import com.android.server.AttributeCache; |
Wale Ogunwale | 17f175c | 2017-02-07 16:54:10 -0800 | [diff] [blame] | 56 | |
| 57 | import java.util.HashSet; |
Wale Ogunwale | 3424795 | 2017-02-19 11:57:53 -0800 | [diff] [blame] | 58 | import java.util.LinkedList; |
Jorim Jaggi | 9bafc71 | 2017-01-19 17:28:30 +0100 | [diff] [blame] | 59 | |
Wale Ogunwale | 44fbdf5 | 2016-11-16 10:18:45 -0800 | [diff] [blame] | 60 | /** |
| 61 | * Common base class for window manager unit test classes. |
| 62 | */ |
Wale Ogunwale | 26c0dfe | 2016-12-14 14:42:30 -0800 | [diff] [blame] | 63 | class WindowTestsBase { |
Wale Ogunwale | 44fbdf5 | 2016-11-16 10:18:45 -0800 | [diff] [blame] | 64 | static WindowManagerService sWm = null; |
Wale Ogunwale | 11cc516 | 2017-04-25 20:29:13 -0700 | [diff] [blame] | 65 | private static final IWindow sIWindow = new TestIWindow(); |
Bryce Lee | a559286 | 2017-10-23 12:57:37 -0700 | [diff] [blame] | 66 | private static Session sMockSession; |
Bryce Lee | 310de9e | 2017-03-15 10:18:21 -0700 | [diff] [blame] | 67 | // The default display is removed in {@link #setUp} and then we iterate over all displays to |
| 68 | // 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] | 69 | // 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] | 70 | private static int sNextDisplayId = DEFAULT_DISPLAY + 1; |
Wale Ogunwale | 44f036f | 2017-09-29 05:09:09 -0700 | [diff] [blame] | 71 | static int sNextStackId = 1000; |
Wale Ogunwale | 44fbdf5 | 2016-11-16 10:18:45 -0800 | [diff] [blame] | 72 | |
Wale Ogunwale | 3c1170d | 2016-12-02 14:44:52 -0800 | [diff] [blame] | 73 | private static boolean sOneTimeSetupDone = false; |
Wale Ogunwale | 11cc516 | 2017-04-25 20:29:13 -0700 | [diff] [blame] | 74 | DisplayContent mDisplayContent; |
| 75 | DisplayInfo mDisplayInfo = new DisplayInfo(); |
Wale Ogunwale | 11cc516 | 2017-04-25 20:29:13 -0700 | [diff] [blame] | 76 | WindowState mWallpaperWindow; |
| 77 | WindowState mImeWindow; |
| 78 | WindowState mImeDialogWindow; |
| 79 | WindowState mStatusBarWindow; |
| 80 | WindowState mDockedDividerWindow; |
| 81 | WindowState mNavBarWindow; |
| 82 | WindowState mAppWindow; |
| 83 | WindowState mChildAppWindowAbove; |
| 84 | WindowState mChildAppWindowBelow; |
| 85 | HashSet<WindowState> mCommonWindows; |
Wale Ogunwale | 3c1170d | 2016-12-02 14:44:52 -0800 | [diff] [blame] | 86 | |
chaviw | 2fb06bc | 2018-01-19 17:09:15 -0800 | [diff] [blame^] | 87 | private final SurfaceAnimationRunner mSurfaceAnimationRunner; |
| 88 | |
| 89 | public WindowTestsBase() { |
| 90 | this(new SurfaceAnimationRunner()); |
| 91 | } |
| 92 | |
| 93 | public WindowTestsBase(SurfaceAnimationRunner surfaceAnimationRunner) { |
| 94 | mSurfaceAnimationRunner = surfaceAnimationRunner; |
| 95 | } |
| 96 | |
Wale Ogunwale | 44fbdf5 | 2016-11-16 10:18:45 -0800 | [diff] [blame] | 97 | @Before |
| 98 | public void setUp() throws Exception { |
Wale Ogunwale | 11cc516 | 2017-04-25 20:29:13 -0700 | [diff] [blame] | 99 | if (!sOneTimeSetupDone) { |
| 100 | sOneTimeSetupDone = true; |
Jorim Jaggi | 771d5b4 | 2017-10-20 15:07:41 +0200 | [diff] [blame] | 101 | |
| 102 | // Allows to mock package local classes and methods |
| 103 | System.setProperty("dexmaker.share_classloader", "true"); |
Wale Ogunwale | 11cc516 | 2017-04-25 20:29:13 -0700 | [diff] [blame] | 104 | MockitoAnnotations.initMocks(this); |
Bryce Lee | a559286 | 2017-10-23 12:57:37 -0700 | [diff] [blame] | 105 | sMockSession = mock(Session.class); |
Wale Ogunwale | 3c1170d | 2016-12-02 14:44:52 -0800 | [diff] [blame] | 106 | } |
Wale Ogunwale | 11cc516 | 2017-04-25 20:29:13 -0700 | [diff] [blame] | 107 | |
Wale Ogunwale | 44fbdf5 | 2016-11-16 10:18:45 -0800 | [diff] [blame] | 108 | final Context context = InstrumentationRegistry.getTargetContext(); |
Jorim Jaggi | 9bafc71 | 2017-01-19 17:28:30 +0100 | [diff] [blame] | 109 | AttributeCache.init(context); |
Robert Carr | b1579c8 | 2017-09-05 14:54:47 -0700 | [diff] [blame] | 110 | |
chaviw | 2fb06bc | 2018-01-19 17:09:15 -0800 | [diff] [blame^] | 111 | sWm = TestWindowManagerPolicy.getWindowManagerService(context, mSurfaceAnimationRunner); |
Robert Carr | b1579c8 | 2017-09-05 14:54:47 -0700 | [diff] [blame] | 112 | beforeCreateDisplay(); |
Bryce Lee | 6272c7f | 2017-03-17 17:22:35 -0700 | [diff] [blame] | 113 | |
Wale Ogunwale | 11cc516 | 2017-04-25 20:29:13 -0700 | [diff] [blame] | 114 | context.getDisplay().getDisplayInfo(mDisplayInfo); |
| 115 | mDisplayContent = createNewDisplay(); |
Jorim Jaggi | 9bafc71 | 2017-01-19 17:28:30 +0100 | [diff] [blame] | 116 | sWm.mDisplayEnabled = true; |
| 117 | sWm.mDisplayReady = true; |
Wale Ogunwale | 3c1170d | 2016-12-02 14:44:52 -0800 | [diff] [blame] | 118 | |
| 119 | // Set-up some common windows. |
Wale Ogunwale | 11cc516 | 2017-04-25 20:29:13 -0700 | [diff] [blame] | 120 | mCommonWindows = new HashSet(); |
| 121 | mWallpaperWindow = createCommonWindow(null, TYPE_WALLPAPER, "wallpaperWindow"); |
| 122 | mImeWindow = createCommonWindow(null, TYPE_INPUT_METHOD, "mImeWindow"); |
| 123 | sWm.mInputMethodWindow = mImeWindow; |
| 124 | mImeDialogWindow = createCommonWindow(null, TYPE_INPUT_METHOD_DIALOG, "mImeDialogWindow"); |
| 125 | mStatusBarWindow = createCommonWindow(null, TYPE_STATUS_BAR, "mStatusBarWindow"); |
| 126 | mNavBarWindow = createCommonWindow(null, TYPE_NAVIGATION_BAR, "mNavBarWindow"); |
| 127 | mDockedDividerWindow = createCommonWindow(null, TYPE_DOCK_DIVIDER, "mDockedDividerWindow"); |
| 128 | mAppWindow = createCommonWindow(null, TYPE_BASE_APPLICATION, "mAppWindow"); |
| 129 | mChildAppWindowAbove = createCommonWindow(mAppWindow, TYPE_APPLICATION_ATTACHED_DIALOG, |
| 130 | "mChildAppWindowAbove"); |
| 131 | mChildAppWindowBelow = createCommonWindow(mAppWindow, TYPE_APPLICATION_MEDIA_OVERLAY, |
| 132 | "mChildAppWindowBelow"); |
Jorim Jaggi | 153badb | 2017-05-24 13:18:28 +0200 | [diff] [blame] | 133 | |
| 134 | // Adding a display will cause freezing the display. Make sure to wait until it's unfrozen |
| 135 | // to not run into race conditions with the tests. |
| 136 | waitUntilHandlersIdle(); |
Wale Ogunwale | 17f175c | 2017-02-07 16:54:10 -0800 | [diff] [blame] | 137 | } |
| 138 | |
Robert Carr | b1579c8 | 2017-09-05 14:54:47 -0700 | [diff] [blame] | 139 | void beforeCreateDisplay() { |
| 140 | // Called before display is created. |
| 141 | } |
| 142 | |
Wale Ogunwale | 17f175c | 2017-02-07 16:54:10 -0800 | [diff] [blame] | 143 | @After |
| 144 | public void tearDown() throws Exception { |
Wale Ogunwale | 3424795 | 2017-02-19 11:57:53 -0800 | [diff] [blame] | 145 | final LinkedList<WindowState> nonCommonWindows = new LinkedList(); |
Wale Ogunwale | 027f475 | 2017-05-12 10:37:16 -0700 | [diff] [blame] | 146 | |
| 147 | synchronized (sWm.mWindowMap) { |
| 148 | sWm.mRoot.forAllWindows(w -> { |
| 149 | if (!mCommonWindows.contains(w)) { |
| 150 | nonCommonWindows.addLast(w); |
| 151 | } |
| 152 | }, true /* traverseTopToBottom */); |
| 153 | |
| 154 | while (!nonCommonWindows.isEmpty()) { |
| 155 | nonCommonWindows.pollLast().removeImmediately(); |
Wale Ogunwale | 17f175c | 2017-02-07 16:54:10 -0800 | [diff] [blame] | 156 | } |
Wale Ogunwale | 3424795 | 2017-02-19 11:57:53 -0800 | [diff] [blame] | 157 | |
Wale Ogunwale | 027f475 | 2017-05-12 10:37:16 -0700 | [diff] [blame] | 158 | mDisplayContent.removeImmediately(); |
| 159 | sWm.mInputMethodTarget = null; |
Wale Ogunwale | 3424795 | 2017-02-19 11:57:53 -0800 | [diff] [blame] | 160 | } |
Jorim Jaggi | 153badb | 2017-05-24 13:18:28 +0200 | [diff] [blame] | 161 | |
| 162 | // Wait until everything is really cleaned up. |
| 163 | waitUntilHandlersIdle(); |
Wale Ogunwale | 17f175c | 2017-02-07 16:54:10 -0800 | [diff] [blame] | 164 | } |
| 165 | |
Robert Carr | b1579c8 | 2017-09-05 14:54:47 -0700 | [diff] [blame] | 166 | /** |
| 167 | * @return A SurfaceBuilderFactory to inject in to the WindowManagerService during |
| 168 | * set-up (or null). |
| 169 | */ |
| 170 | SurfaceBuilderFactory getSurfaceBuilderFactory() { |
| 171 | return null; |
| 172 | } |
| 173 | |
Wale Ogunwale | 11cc516 | 2017-04-25 20:29:13 -0700 | [diff] [blame] | 174 | private WindowState createCommonWindow(WindowState parent, int type, String name) { |
Wale Ogunwale | 17f175c | 2017-02-07 16:54:10 -0800 | [diff] [blame] | 175 | final WindowState win = createWindow(parent, type, name); |
Wale Ogunwale | 11cc516 | 2017-04-25 20:29:13 -0700 | [diff] [blame] | 176 | mCommonWindows.add(win); |
Wale Ogunwale | 3424795 | 2017-02-19 11:57:53 -0800 | [diff] [blame] | 177 | // Prevent common windows from been IMe targets |
| 178 | win.mAttrs.flags |= FLAG_NOT_FOCUSABLE; |
Wale Ogunwale | 17f175c | 2017-02-07 16:54:10 -0800 | [diff] [blame] | 179 | return win; |
Wale Ogunwale | 44fbdf5 | 2016-11-16 10:18:45 -0800 | [diff] [blame] | 180 | } |
| 181 | |
| 182 | /** Asserts that the first entry is greater than the second entry. */ |
| 183 | void assertGreaterThan(int first, int second) throws Exception { |
| 184 | Assert.assertTrue("Excepted " + first + " to be greater than " + second, first > second); |
| 185 | } |
| 186 | |
Robert Carr | b1579c8 | 2017-09-05 14:54:47 -0700 | [diff] [blame] | 187 | /** Asserts that the first entry is greater than the second entry. */ |
| 188 | void assertLessThan(int first, int second) throws Exception { |
| 189 | Assert.assertTrue("Excepted " + first + " to be less than " + second, first < second); |
| 190 | } |
| 191 | |
Jorim Jaggi | 9bafc71 | 2017-01-19 17:28:30 +0100 | [diff] [blame] | 192 | /** |
| 193 | * Waits until the main handler for WM has processed all messages. |
| 194 | */ |
Jorim Jaggi | ed7993b | 2017-03-28 18:50:01 +0100 | [diff] [blame] | 195 | void waitUntilHandlersIdle() { |
Jorim Jaggi | 9bafc71 | 2017-01-19 17:28:30 +0100 | [diff] [blame] | 196 | sWm.mH.runWithScissors(() -> { }, 0); |
Jorim Jaggi | ed7993b | 2017-03-28 18:50:01 +0100 | [diff] [blame] | 197 | sWm.mAnimationHandler.runWithScissors(() -> { }, 0); |
Jorim Jaggi | 21c39a7 | 2017-10-20 15:47:51 +0200 | [diff] [blame] | 198 | SurfaceAnimationThread.getHandler().runWithScissors(() -> { }, 0); |
Jorim Jaggi | 9bafc71 | 2017-01-19 17:28:30 +0100 | [diff] [blame] | 199 | } |
| 200 | |
Wale Ogunwale | 6827856 | 2017-09-23 17:13:55 -0700 | [diff] [blame] | 201 | private WindowToken createWindowToken( |
| 202 | DisplayContent dc, int windowingMode, int activityType, int type) { |
Wale Ogunwale | 44fbdf5 | 2016-11-16 10:18:45 -0800 | [diff] [blame] | 203 | if (type < FIRST_APPLICATION_WINDOW || type > LAST_APPLICATION_WINDOW) { |
Bryce Lee | af691c0 | 2017-03-20 14:20:22 -0700 | [diff] [blame] | 204 | return new WindowTestUtils.TestWindowToken(type, dc); |
Wale Ogunwale | 44fbdf5 | 2016-11-16 10:18:45 -0800 | [diff] [blame] | 205 | } |
| 206 | |
Wale Ogunwale | 6827856 | 2017-09-23 17:13:55 -0700 | [diff] [blame] | 207 | final TaskStack stack = |
| 208 | createStackControllerOnStackOnDisplay(windowingMode, activityType, dc).mContainer; |
Andrii Kulian | d276563 | 2016-12-12 22:26:34 -0800 | [diff] [blame] | 209 | final Task task = createTaskInStack(stack, 0 /* userId */); |
Bryce Lee | af691c0 | 2017-03-20 14:20:22 -0700 | [diff] [blame] | 210 | final WindowTestUtils.TestAppWindowToken token = new WindowTestUtils.TestAppWindowToken(dc); |
Wale Ogunwale | 72919d2 | 2016-12-08 18:58:50 -0800 | [diff] [blame] | 211 | task.addChild(token, 0); |
Wale Ogunwale | 44fbdf5 | 2016-11-16 10:18:45 -0800 | [diff] [blame] | 212 | return token; |
| 213 | } |
| 214 | |
Wale Ogunwale | 11cc516 | 2017-04-25 20:29:13 -0700 | [diff] [blame] | 215 | WindowState createWindow(WindowState parent, int type, String name) { |
Wale Ogunwale | 805d9ec | 2016-12-07 12:22:08 -0800 | [diff] [blame] | 216 | return (parent == null) |
Wale Ogunwale | 11cc516 | 2017-04-25 20:29:13 -0700 | [diff] [blame] | 217 | ? createWindow(parent, type, mDisplayContent, name) |
Wale Ogunwale | 805d9ec | 2016-12-07 12:22:08 -0800 | [diff] [blame] | 218 | : createWindow(parent, type, parent.mToken, name); |
| 219 | } |
| 220 | |
Wale Ogunwale | 6827856 | 2017-09-23 17:13:55 -0700 | [diff] [blame] | 221 | WindowState createWindowOnStack(WindowState parent, int windowingMode, int activityType, |
| 222 | int type, DisplayContent dc, String name) { |
| 223 | final WindowToken token = createWindowToken(dc, windowingMode, activityType, type); |
Winson Chung | 8347163 | 2016-12-13 11:02:12 -0800 | [diff] [blame] | 224 | return createWindow(parent, type, token, name); |
| 225 | } |
| 226 | |
Jorim Jaggi | 02886a8 | 2016-12-06 09:10:06 -0800 | [diff] [blame] | 227 | WindowState createAppWindow(Task task, int type, String name) { |
Wale Ogunwale | 11cc516 | 2017-04-25 20:29:13 -0700 | [diff] [blame] | 228 | final AppWindowToken token = new WindowTestUtils.TestAppWindowToken(mDisplayContent); |
Jorim Jaggi | 02886a8 | 2016-12-06 09:10:06 -0800 | [diff] [blame] | 229 | task.addChild(token, 0); |
| 230 | return createWindow(null, type, token, name); |
| 231 | } |
| 232 | |
Wale Ogunwale | 11cc516 | 2017-04-25 20:29:13 -0700 | [diff] [blame] | 233 | WindowState createWindow(WindowState parent, int type, DisplayContent dc, String name) { |
Wale Ogunwale | 6827856 | 2017-09-23 17:13:55 -0700 | [diff] [blame] | 234 | final WindowToken token = createWindowToken( |
| 235 | dc, WINDOWING_MODE_FULLSCREEN, ACTIVITY_TYPE_STANDARD, type); |
Wale Ogunwale | 44fbdf5 | 2016-11-16 10:18:45 -0800 | [diff] [blame] | 236 | return createWindow(parent, type, token, name); |
| 237 | } |
| 238 | |
Wale Ogunwale | 11cc516 | 2017-04-25 20:29:13 -0700 | [diff] [blame] | 239 | WindowState createWindow(WindowState parent, int type, DisplayContent dc, String name, |
Wale Ogunwale | 17f175c | 2017-02-07 16:54:10 -0800 | [diff] [blame] | 240 | boolean ownerCanAddInternalSystemWindow) { |
Wale Ogunwale | 6827856 | 2017-09-23 17:13:55 -0700 | [diff] [blame] | 241 | final WindowToken token = createWindowToken( |
| 242 | dc, WINDOWING_MODE_FULLSCREEN, ACTIVITY_TYPE_STANDARD, type); |
Daichi Hirono | da0748d | 2017-12-13 12:48:59 +0900 | [diff] [blame] | 243 | return createWindow(parent, type, token, name, 0 /* ownerId */, |
| 244 | ownerCanAddInternalSystemWindow); |
Wale Ogunwale | 17f175c | 2017-02-07 16:54:10 -0800 | [diff] [blame] | 245 | } |
| 246 | |
Jorim Jaggi | 9bafc71 | 2017-01-19 17:28:30 +0100 | [diff] [blame] | 247 | static WindowState createWindow(WindowState parent, int type, WindowToken token, String name) { |
Daichi Hirono | da0748d | 2017-12-13 12:48:59 +0900 | [diff] [blame] | 248 | return createWindow(parent, type, token, name, 0 /* ownerId */, |
| 249 | false /* ownerCanAddInternalSystemWindow */); |
Wale Ogunwale | 17f175c | 2017-02-07 16:54:10 -0800 | [diff] [blame] | 250 | } |
| 251 | |
| 252 | static WindowState createWindow(WindowState parent, int type, WindowToken token, String name, |
Daichi Hirono | da0748d | 2017-12-13 12:48:59 +0900 | [diff] [blame] | 253 | int ownerId, boolean ownerCanAddInternalSystemWindow) { |
Wale Ogunwale | 44fbdf5 | 2016-11-16 10:18:45 -0800 | [diff] [blame] | 254 | final WindowManager.LayoutParams attrs = new WindowManager.LayoutParams(type); |
| 255 | attrs.setTitle(name); |
| 256 | |
Wale Ogunwale | 8e44f6c | 2017-03-09 15:25:10 -0800 | [diff] [blame] | 257 | final WindowState w = new WindowState(sWm, sMockSession, sIWindow, token, parent, OP_NONE, |
Daichi Hirono | da0748d | 2017-12-13 12:48:59 +0900 | [diff] [blame] | 258 | 0, attrs, VISIBLE, ownerId, ownerCanAddInternalSystemWindow); |
Wale Ogunwale | 44fbdf5 | 2016-11-16 10:18:45 -0800 | [diff] [blame] | 259 | // TODO: Probably better to make this call in the WindowState ctor to avoid errors with |
| 260 | // adding it to the token... |
| 261 | token.addWindow(w); |
| 262 | return w; |
| 263 | } |
Wale Ogunwale | 3d0bfd9 | 2016-12-05 11:38:02 -0800 | [diff] [blame] | 264 | |
Andrii Kulian | d276563 | 2016-12-12 22:26:34 -0800 | [diff] [blame] | 265 | /** Creates a {@link TaskStack} and adds it to the specified {@link DisplayContent}. */ |
Wale Ogunwale | 11cc516 | 2017-04-25 20:29:13 -0700 | [diff] [blame] | 266 | TaskStack createTaskStackOnDisplay(DisplayContent dc) { |
Wale Ogunwale | 1666e31 | 2016-12-16 11:27:18 -0800 | [diff] [blame] | 267 | return createStackControllerOnDisplay(dc).mContainer; |
| 268 | } |
| 269 | |
Wale Ogunwale | 11cc516 | 2017-04-25 20:29:13 -0700 | [diff] [blame] | 270 | StackWindowController createStackControllerOnDisplay(DisplayContent dc) { |
Wale Ogunwale | 6827856 | 2017-09-23 17:13:55 -0700 | [diff] [blame] | 271 | return createStackControllerOnStackOnDisplay( |
| 272 | WINDOWING_MODE_FULLSCREEN, ACTIVITY_TYPE_STANDARD, dc); |
Winson Chung | 8347163 | 2016-12-13 11:02:12 -0800 | [diff] [blame] | 273 | } |
| 274 | |
Wale Ogunwale | 6827856 | 2017-09-23 17:13:55 -0700 | [diff] [blame] | 275 | StackWindowController createStackControllerOnStackOnDisplay( |
| 276 | int windowingMode, int activityType, DisplayContent dc) { |
Wale Ogunwale | f75962a | 2017-08-23 14:58:04 -0700 | [diff] [blame] | 277 | final Configuration overrideConfig = new Configuration(); |
Wale Ogunwale | 6827856 | 2017-09-23 17:13:55 -0700 | [diff] [blame] | 278 | overrideConfig.windowConfiguration.setWindowingMode(windowingMode); |
| 279 | overrideConfig.windowConfiguration.setActivityType(activityType); |
| 280 | final int stackId = ++sNextStackId; |
Wale Ogunwale | 034a8ec | 2017-09-02 17:14:40 -0700 | [diff] [blame] | 281 | final StackWindowController controller = new StackWindowController(stackId, null, |
| 282 | dc.getDisplayId(), true /* onTop */, new Rect(), sWm); |
| 283 | controller.onOverrideConfigurationChanged(overrideConfig); |
| 284 | return controller; |
Andrii Kulian | d276563 | 2016-12-12 22:26:34 -0800 | [diff] [blame] | 285 | } |
| 286 | |
Andrii Kulian | 367ff7f | 2017-01-25 19:45:34 -0800 | [diff] [blame] | 287 | /** Creates a {@link Task} and adds it to the specified {@link TaskStack}. */ |
Wale Ogunwale | 11cc516 | 2017-04-25 20:29:13 -0700 | [diff] [blame] | 288 | Task createTaskInStack(TaskStack stack, int userId) { |
Bryce Lee | af691c0 | 2017-03-20 14:20:22 -0700 | [diff] [blame] | 289 | return WindowTestUtils.createTaskInStack(sWm, stack, userId); |
Andrii Kulian | d276563 | 2016-12-12 22:26:34 -0800 | [diff] [blame] | 290 | } |
| 291 | |
Andrii Kulian | 367ff7f | 2017-01-25 19:45:34 -0800 | [diff] [blame] | 292 | /** Creates a {@link DisplayContent} and adds it to the system. */ |
| 293 | DisplayContent createNewDisplay() { |
| 294 | final int displayId = sNextDisplayId++; |
| 295 | final Display display = new Display(DisplayManagerGlobal.getInstance(), displayId, |
Wale Ogunwale | 11cc516 | 2017-04-25 20:29:13 -0700 | [diff] [blame] | 296 | mDisplayInfo, DEFAULT_DISPLAY_ADJUSTMENTS); |
Robert Carr | b1579c8 | 2017-09-05 14:54:47 -0700 | [diff] [blame] | 297 | return new DisplayContent(display, sWm, new WallpaperController(sWm)); |
Andrii Kulian | 367ff7f | 2017-01-25 19:45:34 -0800 | [diff] [blame] | 298 | } |
| 299 | |
Bryce Lee | af691c0 | 2017-03-20 14:20:22 -0700 | [diff] [blame] | 300 | /** Creates a {@link com.android.server.wm.WindowTestUtils.TestWindowState} */ |
| 301 | WindowTestUtils.TestWindowState createWindowState(WindowManager.LayoutParams attrs, |
| 302 | WindowToken token) { |
| 303 | return new WindowTestUtils.TestWindowState(sWm, sMockSession, sIWindow, attrs, token); |
Wale Ogunwale | 3d0bfd9 | 2016-12-05 11:38:02 -0800 | [diff] [blame] | 304 | } |
| 305 | |
Wale Ogunwale | 44fbdf5 | 2016-11-16 10:18:45 -0800 | [diff] [blame] | 306 | } |