Loading services/core/java/com/android/server/wm/WindowManagerService.java +9 −5 Original line number Original line Diff line number Diff line Loading @@ -1183,7 +1183,8 @@ public class WindowManagerService extends IWindowManager.Stub final boolean showBootMsgs, final boolean onlyCore, WindowManagerPolicy policy, final boolean showBootMsgs, final boolean onlyCore, WindowManagerPolicy policy, ActivityTaskManagerService atm) { ActivityTaskManagerService atm) { return main(context, im, showBootMsgs, onlyCore, policy, atm, return main(context, im, showBootMsgs, onlyCore, policy, atm, SurfaceControl.Transaction::new, Surface::new, SurfaceControl.Builder::new); new DisplayWindowSettingsProvider(), SurfaceControl.Transaction::new, Surface::new, SurfaceControl.Builder::new); } } /** /** Loading @@ -1193,12 +1194,14 @@ public class WindowManagerService extends IWindowManager.Stub @VisibleForTesting @VisibleForTesting public static WindowManagerService main(final Context context, final InputManagerService im, public static WindowManagerService main(final Context context, final InputManagerService im, final boolean showBootMsgs, final boolean onlyCore, WindowManagerPolicy policy, final boolean showBootMsgs, final boolean onlyCore, WindowManagerPolicy policy, ActivityTaskManagerService atm, Supplier<SurfaceControl.Transaction> transactionFactory, ActivityTaskManagerService atm, DisplayWindowSettingsProvider displayWindowSettingsProvider, Supplier<SurfaceControl.Transaction> transactionFactory, Supplier<Surface> surfaceFactory, Supplier<Surface> surfaceFactory, Function<SurfaceSession, SurfaceControl.Builder> surfaceControlFactory) { Function<SurfaceSession, SurfaceControl.Builder> surfaceControlFactory) { DisplayThread.getHandler().runWithScissors(() -> DisplayThread.getHandler().runWithScissors(() -> sInstance = new WindowManagerService(context, im, showBootMsgs, onlyCore, policy, sInstance = new WindowManagerService(context, im, showBootMsgs, onlyCore, policy, atm, transactionFactory, surfaceFactory, surfaceControlFactory), 0); atm, displayWindowSettingsProvider, transactionFactory, surfaceFactory, surfaceControlFactory), 0); return sInstance; return sInstance; } } Loading @@ -1220,7 +1223,8 @@ public class WindowManagerService extends IWindowManager.Stub private WindowManagerService(Context context, InputManagerService inputManager, private WindowManagerService(Context context, InputManagerService inputManager, boolean showBootMsgs, boolean onlyCore, WindowManagerPolicy policy, boolean showBootMsgs, boolean onlyCore, WindowManagerPolicy policy, ActivityTaskManagerService atm, Supplier<SurfaceControl.Transaction> transactionFactory, ActivityTaskManagerService atm, DisplayWindowSettingsProvider displayWindowSettingsProvider, Supplier<SurfaceControl.Transaction> transactionFactory, Supplier<Surface> surfaceFactory, Supplier<Surface> surfaceFactory, Function<SurfaceSession, SurfaceControl.Builder> surfaceControlFactory) { Function<SurfaceSession, SurfaceControl.Builder> surfaceControlFactory) { installLock(this, INDEX_WINDOW); installLock(this, INDEX_WINDOW); Loading Loading @@ -1370,7 +1374,7 @@ public class WindowManagerService extends IWindowManager.Stub final String displaySettingsPath = Settings.Global.getString(resolver, final String displaySettingsPath = Settings.Global.getString(resolver, DEVELOPMENT_WM_DISPLAY_SETTINGS_PATH); DEVELOPMENT_WM_DISPLAY_SETTINGS_PATH); mDisplayWindowSettingsProvider = new DisplayWindowSettingsProvider(); mDisplayWindowSettingsProvider = displayWindowSettingsProvider; if (displaySettingsPath != null) { if (displaySettingsPath != null) { mDisplayWindowSettingsProvider.setBaseSettingsFilePath(displaySettingsPath); mDisplayWindowSettingsProvider.setBaseSettingsFilePath(displaySettingsPath); } } Loading services/tests/wmtests/src/com/android/server/wm/SystemServicesTestRule.java +4 −1 Original line number Original line Diff line number Diff line Loading @@ -110,6 +110,7 @@ public class SystemServicesTestRule implements TestRule { private ActivityTaskManagerService mAtmService; private ActivityTaskManagerService mAtmService; private WindowManagerService mWmService; private WindowManagerService mWmService; private TestWindowManagerPolicy mWMPolicy; private TestWindowManagerPolicy mWMPolicy; private TestDisplayWindowSettingsProvider mTestDisplayWindowSettingsProvider; private WindowState.PowerManagerWrapper mPowerManagerWrapper; private WindowState.PowerManagerWrapper mPowerManagerWrapper; private InputManagerService mImService; private InputManagerService mImService; private InputChannel mInputChannel; private InputChannel mInputChannel; Loading Loading @@ -284,10 +285,12 @@ public class SystemServicesTestRule implements TestRule { mPowerManagerWrapper = mock(WindowState.PowerManagerWrapper.class); mPowerManagerWrapper = mock(WindowState.PowerManagerWrapper.class); mWMPolicy = new TestWindowManagerPolicy(this::getWindowManagerService, mWMPolicy = new TestWindowManagerPolicy(this::getWindowManagerService, mPowerManagerWrapper); mPowerManagerWrapper); mTestDisplayWindowSettingsProvider = new TestDisplayWindowSettingsProvider(); // Suppress StrictMode violation (DisplayWindowSettings) to avoid log flood. // Suppress StrictMode violation (DisplayWindowSettings) to avoid log flood. DisplayThread.getHandler().post(StrictMode::allowThreadDiskWritesMask); DisplayThread.getHandler().post(StrictMode::allowThreadDiskWritesMask); mWmService = WindowManagerService.main( mWmService = WindowManagerService.main( mContext, mImService, false, false, mWMPolicy, mAtmService, StubTransaction::new, mContext, mImService, false, false, mWMPolicy, mAtmService, mTestDisplayWindowSettingsProvider, StubTransaction::new, () -> mSurfaceFactory.get(), (unused) -> new MockSurfaceControlBuilder()); () -> mSurfaceFactory.get(), (unused) -> new MockSurfaceControlBuilder()); spyOn(mWmService); spyOn(mWmService); spyOn(mWmService.mRoot); spyOn(mWmService.mRoot); Loading services/tests/wmtests/src/com/android/server/wm/TestDisplayContent.java +0 −4 Original line number Original line Diff line number Diff line Loading @@ -147,10 +147,6 @@ class TestDisplayContent extends DisplayContent { final Display display = new Display(DisplayManagerGlobal.getInstance(), displayId, final Display display = new Display(DisplayManagerGlobal.getInstance(), displayId, mInfo, DEFAULT_DISPLAY_ADJUSTMENTS); mInfo, DEFAULT_DISPLAY_ADJUSTMENTS); final TestDisplayContent newDisplay = createInternal(display); final TestDisplayContent newDisplay = createInternal(display); // Ensure letterbox aspect ratio is not overridden on any device target. // {@link com.android.internal.R.dimen.config_taskLetterboxAspectRatio}, provided by // the below method, is set on some device form factors. mService.mWindowManager.setFixedOrientationLetterboxAspectRatio(0); // disable the normal system decorations // disable the normal system decorations final DisplayPolicy displayPolicy = newDisplay.getDisplayPolicy(); final DisplayPolicy displayPolicy = newDisplay.getDisplayPolicy(); spyOn(displayPolicy); spyOn(displayPolicy); Loading services/tests/wmtests/src/com/android/server/wm/TestDisplayWindowSettingsProvider.java 0 → 100644 +73 −0 Original line number Original line Diff line number Diff line /* * Copyright (C) 2021 The Android Open Source Project * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ package com.android.server.wm; import android.annotation.NonNull; import android.view.DisplayInfo; import java.util.HashMap; import java.util.Map; /** * In-memory DisplayWindowSettingsProvider used in tests. Ensures no settings are read from or * written to device-specific display settings files. */ public final class TestDisplayWindowSettingsProvider extends DisplayWindowSettingsProvider { private final Map<String, SettingsEntry> mOverrideSettingsMap = new HashMap<>(); @Override @NonNull public SettingsEntry getSettings(@NonNull DisplayInfo info) { // Because no settings are read from settings files, there is no need to store base // settings. Only override settings are necessary to track because they can be modified // during tests (e.g. display size, ignore orientation requests). return getOverrideSettings(info); } @Override @NonNull public SettingsEntry getOverrideSettings(@NonNull DisplayInfo info) { return new SettingsEntry(getOrCreateOverrideSettingsEntry(info)); } @Override public void updateOverrideSettings(@NonNull DisplayInfo info, @NonNull SettingsEntry overrides) { final SettingsEntry overrideSettings = getOrCreateOverrideSettingsEntry(info); overrideSettings.setTo(overrides); } @NonNull private SettingsEntry getOrCreateOverrideSettingsEntry(DisplayInfo info) { final String identifier = getIdentifier(info); SettingsEntry settings; if ((settings = mOverrideSettingsMap.get(identifier)) != null) { return settings; } settings = new SettingsEntry(); mOverrideSettingsMap.put(identifier, settings); return settings; } /** * In {@link TestDisplayWindowSettingsProvider}, always use uniqueId as the identifier. */ private static String getIdentifier(DisplayInfo displayInfo) { return displayInfo.uniqueId; } } services/tests/wmtests/src/com/android/server/wm/WindowTestsBase.java +40 −0 Original line number Original line Diff line number Diff line Loading @@ -55,6 +55,8 @@ import static com.android.server.wm.StartingSurfaceController.DEBUG_ENABLE_SHELL import static com.android.server.wm.WindowContainer.POSITION_BOTTOM; import static com.android.server.wm.WindowContainer.POSITION_BOTTOM; import static com.android.server.wm.WindowStateAnimator.HAS_DRAWN; import static com.android.server.wm.WindowStateAnimator.HAS_DRAWN; import static org.junit.Assert.assertEquals; import static org.junit.Assert.assertFalse; import static org.mockito.ArgumentMatchers.any; import static org.mockito.ArgumentMatchers.any; import static org.mockito.ArgumentMatchers.anyBoolean; import static org.mockito.ArgumentMatchers.anyBoolean; import static org.mockito.Mockito.mock; import static org.mockito.Mockito.mock; Loading Loading @@ -153,6 +155,22 @@ class WindowTestsBase extends SystemServiceTestsBase { */ */ Transaction mTransaction; Transaction mTransaction; /** * Whether device-specific global overrides have already been checked in * {@link WindowTestsBase#setUpBase()}. */ private static boolean sGlobalOverridesChecked; /** * Whether device-specific overrides have already been checked in * {@link WindowTestsBase#setUpBase()} when the default display is used. */ private static boolean sOverridesCheckedDefaultDisplay; /** * Whether device-specific overrides have already been checked in * {@link WindowTestsBase#setUpBase()} when a {@link TestDisplayContent} is used. */ private static boolean sOverridesCheckedTestDisplay; @BeforeClass @BeforeClass public static void setUpOnceBase() { public static void setUpOnceBase() { AttributeCache.init(getInstrumentation().getTargetContext()); AttributeCache.init(getInstrumentation().getTargetContext()); Loading Loading @@ -190,6 +208,28 @@ class WindowTestsBase extends SystemServiceTestsBase { // {@link com.android.internal.R.dimen.config_fixedOrientationLetterboxAspectRatio}, is set // {@link com.android.internal.R.dimen.config_fixedOrientationLetterboxAspectRatio}, is set // on some device form factors. // on some device form factors. mAtm.mWindowManager.setFixedOrientationLetterboxAspectRatio(0); mAtm.mWindowManager.setFixedOrientationLetterboxAspectRatio(0); checkDeviceSpecificOverridesNotApplied(); } /** * Check that device-specific overrides are not applied. Only need to check once during entire * test run for each case: global overrides, default display, and test display. */ private void checkDeviceSpecificOverridesNotApplied() { // Check global overrides if (!sGlobalOverridesChecked) { assertEquals(0, mWm.getFixedOrientationLetterboxAspectRatio(), 0 /* delta */); sGlobalOverridesChecked = true; } // Check display-specific overrides if (!sOverridesCheckedDefaultDisplay && mDisplayContent == mDefaultDisplay) { assertFalse(mDisplayContent.getIgnoreOrientationRequest()); sOverridesCheckedDefaultDisplay = true; } else if (!sOverridesCheckedTestDisplay && mDisplayContent instanceof TestDisplayContent) { assertFalse(mDisplayContent.getIgnoreOrientationRequest()); sOverridesCheckedTestDisplay = true; } } } private void createTestDisplay(UseTestDisplay annotation) { private void createTestDisplay(UseTestDisplay annotation) { Loading Loading
services/core/java/com/android/server/wm/WindowManagerService.java +9 −5 Original line number Original line Diff line number Diff line Loading @@ -1183,7 +1183,8 @@ public class WindowManagerService extends IWindowManager.Stub final boolean showBootMsgs, final boolean onlyCore, WindowManagerPolicy policy, final boolean showBootMsgs, final boolean onlyCore, WindowManagerPolicy policy, ActivityTaskManagerService atm) { ActivityTaskManagerService atm) { return main(context, im, showBootMsgs, onlyCore, policy, atm, return main(context, im, showBootMsgs, onlyCore, policy, atm, SurfaceControl.Transaction::new, Surface::new, SurfaceControl.Builder::new); new DisplayWindowSettingsProvider(), SurfaceControl.Transaction::new, Surface::new, SurfaceControl.Builder::new); } } /** /** Loading @@ -1193,12 +1194,14 @@ public class WindowManagerService extends IWindowManager.Stub @VisibleForTesting @VisibleForTesting public static WindowManagerService main(final Context context, final InputManagerService im, public static WindowManagerService main(final Context context, final InputManagerService im, final boolean showBootMsgs, final boolean onlyCore, WindowManagerPolicy policy, final boolean showBootMsgs, final boolean onlyCore, WindowManagerPolicy policy, ActivityTaskManagerService atm, Supplier<SurfaceControl.Transaction> transactionFactory, ActivityTaskManagerService atm, DisplayWindowSettingsProvider displayWindowSettingsProvider, Supplier<SurfaceControl.Transaction> transactionFactory, Supplier<Surface> surfaceFactory, Supplier<Surface> surfaceFactory, Function<SurfaceSession, SurfaceControl.Builder> surfaceControlFactory) { Function<SurfaceSession, SurfaceControl.Builder> surfaceControlFactory) { DisplayThread.getHandler().runWithScissors(() -> DisplayThread.getHandler().runWithScissors(() -> sInstance = new WindowManagerService(context, im, showBootMsgs, onlyCore, policy, sInstance = new WindowManagerService(context, im, showBootMsgs, onlyCore, policy, atm, transactionFactory, surfaceFactory, surfaceControlFactory), 0); atm, displayWindowSettingsProvider, transactionFactory, surfaceFactory, surfaceControlFactory), 0); return sInstance; return sInstance; } } Loading @@ -1220,7 +1223,8 @@ public class WindowManagerService extends IWindowManager.Stub private WindowManagerService(Context context, InputManagerService inputManager, private WindowManagerService(Context context, InputManagerService inputManager, boolean showBootMsgs, boolean onlyCore, WindowManagerPolicy policy, boolean showBootMsgs, boolean onlyCore, WindowManagerPolicy policy, ActivityTaskManagerService atm, Supplier<SurfaceControl.Transaction> transactionFactory, ActivityTaskManagerService atm, DisplayWindowSettingsProvider displayWindowSettingsProvider, Supplier<SurfaceControl.Transaction> transactionFactory, Supplier<Surface> surfaceFactory, Supplier<Surface> surfaceFactory, Function<SurfaceSession, SurfaceControl.Builder> surfaceControlFactory) { Function<SurfaceSession, SurfaceControl.Builder> surfaceControlFactory) { installLock(this, INDEX_WINDOW); installLock(this, INDEX_WINDOW); Loading Loading @@ -1370,7 +1374,7 @@ public class WindowManagerService extends IWindowManager.Stub final String displaySettingsPath = Settings.Global.getString(resolver, final String displaySettingsPath = Settings.Global.getString(resolver, DEVELOPMENT_WM_DISPLAY_SETTINGS_PATH); DEVELOPMENT_WM_DISPLAY_SETTINGS_PATH); mDisplayWindowSettingsProvider = new DisplayWindowSettingsProvider(); mDisplayWindowSettingsProvider = displayWindowSettingsProvider; if (displaySettingsPath != null) { if (displaySettingsPath != null) { mDisplayWindowSettingsProvider.setBaseSettingsFilePath(displaySettingsPath); mDisplayWindowSettingsProvider.setBaseSettingsFilePath(displaySettingsPath); } } Loading
services/tests/wmtests/src/com/android/server/wm/SystemServicesTestRule.java +4 −1 Original line number Original line Diff line number Diff line Loading @@ -110,6 +110,7 @@ public class SystemServicesTestRule implements TestRule { private ActivityTaskManagerService mAtmService; private ActivityTaskManagerService mAtmService; private WindowManagerService mWmService; private WindowManagerService mWmService; private TestWindowManagerPolicy mWMPolicy; private TestWindowManagerPolicy mWMPolicy; private TestDisplayWindowSettingsProvider mTestDisplayWindowSettingsProvider; private WindowState.PowerManagerWrapper mPowerManagerWrapper; private WindowState.PowerManagerWrapper mPowerManagerWrapper; private InputManagerService mImService; private InputManagerService mImService; private InputChannel mInputChannel; private InputChannel mInputChannel; Loading Loading @@ -284,10 +285,12 @@ public class SystemServicesTestRule implements TestRule { mPowerManagerWrapper = mock(WindowState.PowerManagerWrapper.class); mPowerManagerWrapper = mock(WindowState.PowerManagerWrapper.class); mWMPolicy = new TestWindowManagerPolicy(this::getWindowManagerService, mWMPolicy = new TestWindowManagerPolicy(this::getWindowManagerService, mPowerManagerWrapper); mPowerManagerWrapper); mTestDisplayWindowSettingsProvider = new TestDisplayWindowSettingsProvider(); // Suppress StrictMode violation (DisplayWindowSettings) to avoid log flood. // Suppress StrictMode violation (DisplayWindowSettings) to avoid log flood. DisplayThread.getHandler().post(StrictMode::allowThreadDiskWritesMask); DisplayThread.getHandler().post(StrictMode::allowThreadDiskWritesMask); mWmService = WindowManagerService.main( mWmService = WindowManagerService.main( mContext, mImService, false, false, mWMPolicy, mAtmService, StubTransaction::new, mContext, mImService, false, false, mWMPolicy, mAtmService, mTestDisplayWindowSettingsProvider, StubTransaction::new, () -> mSurfaceFactory.get(), (unused) -> new MockSurfaceControlBuilder()); () -> mSurfaceFactory.get(), (unused) -> new MockSurfaceControlBuilder()); spyOn(mWmService); spyOn(mWmService); spyOn(mWmService.mRoot); spyOn(mWmService.mRoot); Loading
services/tests/wmtests/src/com/android/server/wm/TestDisplayContent.java +0 −4 Original line number Original line Diff line number Diff line Loading @@ -147,10 +147,6 @@ class TestDisplayContent extends DisplayContent { final Display display = new Display(DisplayManagerGlobal.getInstance(), displayId, final Display display = new Display(DisplayManagerGlobal.getInstance(), displayId, mInfo, DEFAULT_DISPLAY_ADJUSTMENTS); mInfo, DEFAULT_DISPLAY_ADJUSTMENTS); final TestDisplayContent newDisplay = createInternal(display); final TestDisplayContent newDisplay = createInternal(display); // Ensure letterbox aspect ratio is not overridden on any device target. // {@link com.android.internal.R.dimen.config_taskLetterboxAspectRatio}, provided by // the below method, is set on some device form factors. mService.mWindowManager.setFixedOrientationLetterboxAspectRatio(0); // disable the normal system decorations // disable the normal system decorations final DisplayPolicy displayPolicy = newDisplay.getDisplayPolicy(); final DisplayPolicy displayPolicy = newDisplay.getDisplayPolicy(); spyOn(displayPolicy); spyOn(displayPolicy); Loading
services/tests/wmtests/src/com/android/server/wm/TestDisplayWindowSettingsProvider.java 0 → 100644 +73 −0 Original line number Original line Diff line number Diff line /* * Copyright (C) 2021 The Android Open Source Project * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ package com.android.server.wm; import android.annotation.NonNull; import android.view.DisplayInfo; import java.util.HashMap; import java.util.Map; /** * In-memory DisplayWindowSettingsProvider used in tests. Ensures no settings are read from or * written to device-specific display settings files. */ public final class TestDisplayWindowSettingsProvider extends DisplayWindowSettingsProvider { private final Map<String, SettingsEntry> mOverrideSettingsMap = new HashMap<>(); @Override @NonNull public SettingsEntry getSettings(@NonNull DisplayInfo info) { // Because no settings are read from settings files, there is no need to store base // settings. Only override settings are necessary to track because they can be modified // during tests (e.g. display size, ignore orientation requests). return getOverrideSettings(info); } @Override @NonNull public SettingsEntry getOverrideSettings(@NonNull DisplayInfo info) { return new SettingsEntry(getOrCreateOverrideSettingsEntry(info)); } @Override public void updateOverrideSettings(@NonNull DisplayInfo info, @NonNull SettingsEntry overrides) { final SettingsEntry overrideSettings = getOrCreateOverrideSettingsEntry(info); overrideSettings.setTo(overrides); } @NonNull private SettingsEntry getOrCreateOverrideSettingsEntry(DisplayInfo info) { final String identifier = getIdentifier(info); SettingsEntry settings; if ((settings = mOverrideSettingsMap.get(identifier)) != null) { return settings; } settings = new SettingsEntry(); mOverrideSettingsMap.put(identifier, settings); return settings; } /** * In {@link TestDisplayWindowSettingsProvider}, always use uniqueId as the identifier. */ private static String getIdentifier(DisplayInfo displayInfo) { return displayInfo.uniqueId; } }
services/tests/wmtests/src/com/android/server/wm/WindowTestsBase.java +40 −0 Original line number Original line Diff line number Diff line Loading @@ -55,6 +55,8 @@ import static com.android.server.wm.StartingSurfaceController.DEBUG_ENABLE_SHELL import static com.android.server.wm.WindowContainer.POSITION_BOTTOM; import static com.android.server.wm.WindowContainer.POSITION_BOTTOM; import static com.android.server.wm.WindowStateAnimator.HAS_DRAWN; import static com.android.server.wm.WindowStateAnimator.HAS_DRAWN; import static org.junit.Assert.assertEquals; import static org.junit.Assert.assertFalse; import static org.mockito.ArgumentMatchers.any; import static org.mockito.ArgumentMatchers.any; import static org.mockito.ArgumentMatchers.anyBoolean; import static org.mockito.ArgumentMatchers.anyBoolean; import static org.mockito.Mockito.mock; import static org.mockito.Mockito.mock; Loading Loading @@ -153,6 +155,22 @@ class WindowTestsBase extends SystemServiceTestsBase { */ */ Transaction mTransaction; Transaction mTransaction; /** * Whether device-specific global overrides have already been checked in * {@link WindowTestsBase#setUpBase()}. */ private static boolean sGlobalOverridesChecked; /** * Whether device-specific overrides have already been checked in * {@link WindowTestsBase#setUpBase()} when the default display is used. */ private static boolean sOverridesCheckedDefaultDisplay; /** * Whether device-specific overrides have already been checked in * {@link WindowTestsBase#setUpBase()} when a {@link TestDisplayContent} is used. */ private static boolean sOverridesCheckedTestDisplay; @BeforeClass @BeforeClass public static void setUpOnceBase() { public static void setUpOnceBase() { AttributeCache.init(getInstrumentation().getTargetContext()); AttributeCache.init(getInstrumentation().getTargetContext()); Loading Loading @@ -190,6 +208,28 @@ class WindowTestsBase extends SystemServiceTestsBase { // {@link com.android.internal.R.dimen.config_fixedOrientationLetterboxAspectRatio}, is set // {@link com.android.internal.R.dimen.config_fixedOrientationLetterboxAspectRatio}, is set // on some device form factors. // on some device form factors. mAtm.mWindowManager.setFixedOrientationLetterboxAspectRatio(0); mAtm.mWindowManager.setFixedOrientationLetterboxAspectRatio(0); checkDeviceSpecificOverridesNotApplied(); } /** * Check that device-specific overrides are not applied. Only need to check once during entire * test run for each case: global overrides, default display, and test display. */ private void checkDeviceSpecificOverridesNotApplied() { // Check global overrides if (!sGlobalOverridesChecked) { assertEquals(0, mWm.getFixedOrientationLetterboxAspectRatio(), 0 /* delta */); sGlobalOverridesChecked = true; } // Check display-specific overrides if (!sOverridesCheckedDefaultDisplay && mDisplayContent == mDefaultDisplay) { assertFalse(mDisplayContent.getIgnoreOrientationRequest()); sOverridesCheckedDefaultDisplay = true; } else if (!sOverridesCheckedTestDisplay && mDisplayContent instanceof TestDisplayContent) { assertFalse(mDisplayContent.getIgnoreOrientationRequest()); sOverridesCheckedTestDisplay = true; } } } private void createTestDisplay(UseTestDisplay annotation) { private void createTestDisplay(UseTestDisplay annotation) { Loading