Loading libs/WindowManager/Shell/tests/flicker/pip/src/com/android/wm/shell/flicker/pip/apps/NetflixEnterPipTest.kt +28 −0 Original line number Diff line number Diff line Loading @@ -26,6 +26,7 @@ import android.tools.flicker.junit.FlickerParametersRunnerFactory import android.tools.flicker.legacy.FlickerBuilder import android.tools.flicker.legacy.LegacyFlickerTest import android.tools.flicker.legacy.LegacyFlickerTestFactory import android.tools.helpers.WindowUtils import androidx.test.filters.RequiresDevice import com.android.server.wm.flicker.statusBarLayerPositionAtEnd import org.junit.Assume Loading Loading @@ -62,6 +63,8 @@ import org.junit.runners.Parameterized @FixMethodOrder(MethodSorters.NAME_ASCENDING) open class NetflixEnterPipTest(flicker: LegacyFlickerTest) : AppsEnterPipTransition(flicker) { override val standardAppHelper: NetflixAppHelper = NetflixAppHelper(instrumentation) private val startingBounds = WindowUtils.getDisplayBounds(Rotation.ROTATION_90) private val endingBounds = WindowUtils.getDisplayBounds(Rotation.ROTATION_0) override val permissions: Array<String> = arrayOf(Manifest.permission.POST_NOTIFICATIONS) Loading Loading @@ -134,6 +137,31 @@ open class NetflixEnterPipTest(flicker: LegacyFlickerTest) : AppsEnterPipTransit // Netflix plays in immersive fullscreen mode, so taskbar will be gone at some point } @Postsubmit @Test override fun pipWindowRemainInsideVisibleBounds() { // during the transition we assert the center point is within the display bounds, since it // might go outside of bounds as we resize from landscape fullscreen to destination bounds, // and once the animation is over we assert that it's fully within the display bounds, at // which point the device also performs orientation change from landscape to portrait flicker.assertWmVisibleRegion(standardAppHelper.packageNameMatcher) { regionsCenterPointInside(startingBounds).then().coversAtMost(endingBounds) } } @Postsubmit @Test override fun pipLayerOrOverlayRemainInsideVisibleBounds() { // during the transition we assert the center point is within the display bounds, since it // might go outside of bounds as we resize from landscape fullscreen to destination bounds, // and once the animation is over we assert that it's fully within the display bounds, at // which point the device also performs orientation change from landscape to portrait // since Netflix uses source rect hint, there is no PiP overlay present flicker.assertLayersVisibleRegion(standardAppHelper.packageNameMatcher) { regionsCenterPointInside(startingBounds).then().coversAtMost(endingBounds) } } companion object { /** * Creates the test configurations. Loading libs/WindowManager/Shell/tests/flicker/pip/src/com/android/wm/shell/flicker/pip/apps/YouTubeEnterPipToOtherOrientationTest.kt 0 → 100644 +165 −0 Original line number Diff line number Diff line /* * Copyright (C) 2024 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.wm.shell.flicker.pip.apps import android.Manifest import android.platform.test.annotations.Postsubmit import android.tools.NavBar import android.tools.Rotation import android.tools.traces.component.ComponentNameMatcher import android.tools.device.apphelpers.YouTubeAppHelper import android.tools.flicker.junit.FlickerParametersRunnerFactory import android.tools.flicker.legacy.FlickerBuilder import android.tools.flicker.legacy.LegacyFlickerTest import android.tools.flicker.legacy.LegacyFlickerTestFactory import android.tools.helpers.WindowUtils import androidx.test.filters.RequiresDevice import com.android.server.wm.flicker.statusBarLayerPositionAtEnd import org.junit.Assume import org.junit.FixMethodOrder import org.junit.Test import org.junit.runner.RunWith import org.junit.runners.MethodSorters import org.junit.runners.Parameterized /** * Test entering pip from YouTube app by interacting with the app UI * * To run this test: `atest WMShellFlickerTests:YouTubeEnterPipTest` * * Actions: * ``` * Launch YouTube and start playing a video * Make the video fullscreen, aka immersive mode * Go home to enter PiP * ``` * * Notes: * ``` * 1. Some default assertions (e.g., nav bar, status bar and screen covered) * are inherited from [PipTransition] * 2. Part of the test setup occurs automatically via * [android.tools.flicker.legacy.runner.TransitionRunner], * including configuring navigation mode, initial orientation and ensuring no * apps are running before setup * ``` */ @RequiresDevice @RunWith(Parameterized::class) @Parameterized.UseParametersRunnerFactory(FlickerParametersRunnerFactory::class) @FixMethodOrder(MethodSorters.NAME_ASCENDING) open class YouTubeEnterPipToOtherOrientationTest(flicker: LegacyFlickerTest) : YouTubeEnterPipTest(flicker) { override val standardAppHelper: YouTubeAppHelper = YouTubeAppHelper(instrumentation) private val startingBounds = WindowUtils.getDisplayBounds(Rotation.ROTATION_90) private val endingBounds = WindowUtils.getDisplayBounds(Rotation.ROTATION_0) override val permissions: Array<String> = arrayOf(Manifest.permission.POST_NOTIFICATIONS) override val defaultEnterPip: FlickerBuilder.() -> Unit = { setup { standardAppHelper.launchViaIntent( wmHelper, YouTubeAppHelper.getYoutubeVideoIntent("HPcEAtoXXLA"), ComponentNameMatcher(YouTubeAppHelper.PACKAGE_NAME, "") ) standardAppHelper.enterFullscreen() standardAppHelper.waitForVideoPlaying() } } override val thisTransition: FlickerBuilder.() -> Unit = { transitions { tapl.goHomeFromImmersiveFullscreenApp() } } @Postsubmit @Test override fun taskBarLayerIsVisibleAtStartAndEnd() { Assume.assumeTrue(flicker.scenario.isTablet) // YouTube starts in immersive fullscreen mode, so taskbar bar is not visible at start flicker.assertLayersStart { this.isInvisible(ComponentNameMatcher.TASK_BAR) } flicker.assertLayersEnd { this.isVisible(ComponentNameMatcher.TASK_BAR) } } @Postsubmit @Test override fun pipWindowRemainInsideVisibleBounds() { // during the transition we assert the center point is within the display bounds, since it // might go outside of bounds as we resize from landscape fullscreen to destination bounds, // and once the animation is over we assert that it's fully within the display bounds, at // which point the device also performs orientation change from landscape to portrait flicker.assertWmVisibleRegion(standardAppHelper.packageNameMatcher) { regionsCenterPointInside(startingBounds).then().coversAtMost(endingBounds) } } @Postsubmit @Test override fun pipLayerOrOverlayRemainInsideVisibleBounds() { // during the transition we assert the center point is within the display bounds, since it // might go outside of bounds as we resize from landscape fullscreen to destination bounds, // and once the animation is over we assert that it's fully within the display bounds, at // which point the device also performs orientation change from landscape to portrait // since YouTube uses source rect hint, there is no PiP overlay present flicker.assertLayersVisibleRegion(standardAppHelper.packageNameMatcher) { regionsCenterPointInside(startingBounds).then().coversAtMost(endingBounds) } } @Postsubmit @Test override fun taskBarWindowIsAlwaysVisible() { // YouTube plays in immersive fullscreen mode, so taskbar will be gone at some point } @Postsubmit @Test override fun statusBarLayerIsVisibleAtStartAndEnd() { // YouTube starts in immersive fullscreen mode, so status bar is not visible at start flicker.assertLayersStart { this.isInvisible(ComponentNameMatcher.STATUS_BAR) } flicker.assertLayersEnd { this.isVisible(ComponentNameMatcher.STATUS_BAR) } } @Postsubmit @Test override fun statusBarLayerPositionAtStartAndEnd() { // YouTube starts in immersive fullscreen mode, so status bar is not visible at start flicker.statusBarLayerPositionAtEnd() } @Postsubmit @Test override fun statusBarWindowIsAlwaysVisible() { // YouTube plays in immersive fullscreen mode, so taskbar will be gone at some point } companion object { /** * Creates the test configurations. * * See [LegacyFlickerTestFactory.nonRotationTests] for configuring repetitions, screen * orientation and navigation modes. */ @Parameterized.Parameters(name = "{0}") @JvmStatic fun getParams() = LegacyFlickerTestFactory.nonRotationTests( supportedRotations = listOf(Rotation.ROTATION_0), supportedNavigationModes = listOf(NavBar.MODE_GESTURAL) ) } } Loading
libs/WindowManager/Shell/tests/flicker/pip/src/com/android/wm/shell/flicker/pip/apps/NetflixEnterPipTest.kt +28 −0 Original line number Diff line number Diff line Loading @@ -26,6 +26,7 @@ import android.tools.flicker.junit.FlickerParametersRunnerFactory import android.tools.flicker.legacy.FlickerBuilder import android.tools.flicker.legacy.LegacyFlickerTest import android.tools.flicker.legacy.LegacyFlickerTestFactory import android.tools.helpers.WindowUtils import androidx.test.filters.RequiresDevice import com.android.server.wm.flicker.statusBarLayerPositionAtEnd import org.junit.Assume Loading Loading @@ -62,6 +63,8 @@ import org.junit.runners.Parameterized @FixMethodOrder(MethodSorters.NAME_ASCENDING) open class NetflixEnterPipTest(flicker: LegacyFlickerTest) : AppsEnterPipTransition(flicker) { override val standardAppHelper: NetflixAppHelper = NetflixAppHelper(instrumentation) private val startingBounds = WindowUtils.getDisplayBounds(Rotation.ROTATION_90) private val endingBounds = WindowUtils.getDisplayBounds(Rotation.ROTATION_0) override val permissions: Array<String> = arrayOf(Manifest.permission.POST_NOTIFICATIONS) Loading Loading @@ -134,6 +137,31 @@ open class NetflixEnterPipTest(flicker: LegacyFlickerTest) : AppsEnterPipTransit // Netflix plays in immersive fullscreen mode, so taskbar will be gone at some point } @Postsubmit @Test override fun pipWindowRemainInsideVisibleBounds() { // during the transition we assert the center point is within the display bounds, since it // might go outside of bounds as we resize from landscape fullscreen to destination bounds, // and once the animation is over we assert that it's fully within the display bounds, at // which point the device also performs orientation change from landscape to portrait flicker.assertWmVisibleRegion(standardAppHelper.packageNameMatcher) { regionsCenterPointInside(startingBounds).then().coversAtMost(endingBounds) } } @Postsubmit @Test override fun pipLayerOrOverlayRemainInsideVisibleBounds() { // during the transition we assert the center point is within the display bounds, since it // might go outside of bounds as we resize from landscape fullscreen to destination bounds, // and once the animation is over we assert that it's fully within the display bounds, at // which point the device also performs orientation change from landscape to portrait // since Netflix uses source rect hint, there is no PiP overlay present flicker.assertLayersVisibleRegion(standardAppHelper.packageNameMatcher) { regionsCenterPointInside(startingBounds).then().coversAtMost(endingBounds) } } companion object { /** * Creates the test configurations. Loading
libs/WindowManager/Shell/tests/flicker/pip/src/com/android/wm/shell/flicker/pip/apps/YouTubeEnterPipToOtherOrientationTest.kt 0 → 100644 +165 −0 Original line number Diff line number Diff line /* * Copyright (C) 2024 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.wm.shell.flicker.pip.apps import android.Manifest import android.platform.test.annotations.Postsubmit import android.tools.NavBar import android.tools.Rotation import android.tools.traces.component.ComponentNameMatcher import android.tools.device.apphelpers.YouTubeAppHelper import android.tools.flicker.junit.FlickerParametersRunnerFactory import android.tools.flicker.legacy.FlickerBuilder import android.tools.flicker.legacy.LegacyFlickerTest import android.tools.flicker.legacy.LegacyFlickerTestFactory import android.tools.helpers.WindowUtils import androidx.test.filters.RequiresDevice import com.android.server.wm.flicker.statusBarLayerPositionAtEnd import org.junit.Assume import org.junit.FixMethodOrder import org.junit.Test import org.junit.runner.RunWith import org.junit.runners.MethodSorters import org.junit.runners.Parameterized /** * Test entering pip from YouTube app by interacting with the app UI * * To run this test: `atest WMShellFlickerTests:YouTubeEnterPipTest` * * Actions: * ``` * Launch YouTube and start playing a video * Make the video fullscreen, aka immersive mode * Go home to enter PiP * ``` * * Notes: * ``` * 1. Some default assertions (e.g., nav bar, status bar and screen covered) * are inherited from [PipTransition] * 2. Part of the test setup occurs automatically via * [android.tools.flicker.legacy.runner.TransitionRunner], * including configuring navigation mode, initial orientation and ensuring no * apps are running before setup * ``` */ @RequiresDevice @RunWith(Parameterized::class) @Parameterized.UseParametersRunnerFactory(FlickerParametersRunnerFactory::class) @FixMethodOrder(MethodSorters.NAME_ASCENDING) open class YouTubeEnterPipToOtherOrientationTest(flicker: LegacyFlickerTest) : YouTubeEnterPipTest(flicker) { override val standardAppHelper: YouTubeAppHelper = YouTubeAppHelper(instrumentation) private val startingBounds = WindowUtils.getDisplayBounds(Rotation.ROTATION_90) private val endingBounds = WindowUtils.getDisplayBounds(Rotation.ROTATION_0) override val permissions: Array<String> = arrayOf(Manifest.permission.POST_NOTIFICATIONS) override val defaultEnterPip: FlickerBuilder.() -> Unit = { setup { standardAppHelper.launchViaIntent( wmHelper, YouTubeAppHelper.getYoutubeVideoIntent("HPcEAtoXXLA"), ComponentNameMatcher(YouTubeAppHelper.PACKAGE_NAME, "") ) standardAppHelper.enterFullscreen() standardAppHelper.waitForVideoPlaying() } } override val thisTransition: FlickerBuilder.() -> Unit = { transitions { tapl.goHomeFromImmersiveFullscreenApp() } } @Postsubmit @Test override fun taskBarLayerIsVisibleAtStartAndEnd() { Assume.assumeTrue(flicker.scenario.isTablet) // YouTube starts in immersive fullscreen mode, so taskbar bar is not visible at start flicker.assertLayersStart { this.isInvisible(ComponentNameMatcher.TASK_BAR) } flicker.assertLayersEnd { this.isVisible(ComponentNameMatcher.TASK_BAR) } } @Postsubmit @Test override fun pipWindowRemainInsideVisibleBounds() { // during the transition we assert the center point is within the display bounds, since it // might go outside of bounds as we resize from landscape fullscreen to destination bounds, // and once the animation is over we assert that it's fully within the display bounds, at // which point the device also performs orientation change from landscape to portrait flicker.assertWmVisibleRegion(standardAppHelper.packageNameMatcher) { regionsCenterPointInside(startingBounds).then().coversAtMost(endingBounds) } } @Postsubmit @Test override fun pipLayerOrOverlayRemainInsideVisibleBounds() { // during the transition we assert the center point is within the display bounds, since it // might go outside of bounds as we resize from landscape fullscreen to destination bounds, // and once the animation is over we assert that it's fully within the display bounds, at // which point the device also performs orientation change from landscape to portrait // since YouTube uses source rect hint, there is no PiP overlay present flicker.assertLayersVisibleRegion(standardAppHelper.packageNameMatcher) { regionsCenterPointInside(startingBounds).then().coversAtMost(endingBounds) } } @Postsubmit @Test override fun taskBarWindowIsAlwaysVisible() { // YouTube plays in immersive fullscreen mode, so taskbar will be gone at some point } @Postsubmit @Test override fun statusBarLayerIsVisibleAtStartAndEnd() { // YouTube starts in immersive fullscreen mode, so status bar is not visible at start flicker.assertLayersStart { this.isInvisible(ComponentNameMatcher.STATUS_BAR) } flicker.assertLayersEnd { this.isVisible(ComponentNameMatcher.STATUS_BAR) } } @Postsubmit @Test override fun statusBarLayerPositionAtStartAndEnd() { // YouTube starts in immersive fullscreen mode, so status bar is not visible at start flicker.statusBarLayerPositionAtEnd() } @Postsubmit @Test override fun statusBarWindowIsAlwaysVisible() { // YouTube plays in immersive fullscreen mode, so taskbar will be gone at some point } companion object { /** * Creates the test configurations. * * See [LegacyFlickerTestFactory.nonRotationTests] for configuring repetitions, screen * orientation and navigation modes. */ @Parameterized.Parameters(name = "{0}") @JvmStatic fun getParams() = LegacyFlickerTestFactory.nonRotationTests( supportedRotations = listOf(Rotation.ROTATION_0), supportedNavigationModes = listOf(NavBar.MODE_GESTURAL) ) } }