From 80eded9a64f7d6b3a5aff34c551ec0ad4d21457d Mon Sep 17 00:00:00 2001 From: Paige McAuliffe Date: Wed, 23 Aug 2023 12:17:20 -0700 Subject: [PATCH] Add gradle tests for setting screen orientation with Espresso Device PiperOrigin-RevId: 559505415 --- gradle-tests/espresso-device/.gitignore | 10 +++ gradle-tests/espresso-device/build.gradle | 51 +++++++++++ .../espresso-device/ScreenOrientationTest.kt | 87 +++++++++++++++++++ .../src/main/AndroidManifest.xml | 13 +++ .../ScreenOrientationActivity.kt | 66 ++++++++++++++ .../layout/activity_screen_orientation.xml | 29 +++++++ .../src/main/res/values/strings.xml | 23 +++++ gradle-tests/gradle.properties | 3 +- gradle-tests/settings.gradle | 2 + 9 files changed, 283 insertions(+), 1 deletion(-) create mode 100644 gradle-tests/espresso-device/.gitignore create mode 100644 gradle-tests/espresso-device/build.gradle create mode 100644 gradle-tests/espresso-device/src/androidTest/java/androidx/test/gradletests/espresso-device/ScreenOrientationTest.kt create mode 100644 gradle-tests/espresso-device/src/main/AndroidManifest.xml create mode 100644 gradle-tests/espresso-device/src/main/java/androidx/test/gradletests/espresso-device/ScreenOrientationActivity.kt create mode 100644 gradle-tests/espresso-device/src/main/res/layout/activity_screen_orientation.xml create mode 100644 gradle-tests/espresso-device/src/main/res/values/strings.xml diff --git a/gradle-tests/espresso-device/.gitignore b/gradle-tests/espresso-device/.gitignore new file mode 100644 index 000000000..10cfdbfaf --- /dev/null +++ b/gradle-tests/espresso-device/.gitignore @@ -0,0 +1,10 @@ +*.iml +.gradle +/local.properties +/.idea +.DS_Store +/build +/captures +.externalNativeBuild +.cxx +local.properties diff --git a/gradle-tests/espresso-device/build.gradle b/gradle-tests/espresso-device/build.gradle new file mode 100644 index 000000000..9621c5405 --- /dev/null +++ b/gradle-tests/espresso-device/build.gradle @@ -0,0 +1,51 @@ +plugins { + id 'com.android.library' + id 'org.jetbrains.kotlin.android' +} + +android { + namespace 'androidx.test.gradletests.espresso.device' + compileSdk 33 + + defaultConfig { + minSdk 14 + targetSdk 33 + + testInstrumentationRunner "androidx.test.runner.AndroidJUnitRunner" + multiDexEnabled true + } + + buildTypes { + + } + compileOptions { + sourceCompatibility JavaVersion.VERSION_17 + targetCompatibility JavaVersion.VERSION_17 + } + testOptions { + animationsDisabled = true + managedDevices { + devices { + // run with ../gradlew nexusOneApi30DebugAndroidTest + nexusOneApi30(com.android.build.api.dsl.ManagedVirtualDevice) { + // A lower resolution device is used here for better emulator performance + device = "Nexus One" + apiLevel = 30 + // Also use the AOSP Automated Test Device image for better emulator performance + systemImageSource = "aosp-atd" + } + } + } + emulatorControl { + enable = true + } + } +} + +dependencies { + androidTestImplementation libs.ext.junit + androidTestImplementation libs.ext.truth + androidTestImplementation libs.espresso.core + androidTestImplementation libs.espresso.device + +} \ No newline at end of file diff --git a/gradle-tests/espresso-device/src/androidTest/java/androidx/test/gradletests/espresso-device/ScreenOrientationTest.kt b/gradle-tests/espresso-device/src/androidTest/java/androidx/test/gradletests/espresso-device/ScreenOrientationTest.kt new file mode 100644 index 000000000..142fb404c --- /dev/null +++ b/gradle-tests/espresso-device/src/androidTest/java/androidx/test/gradletests/espresso-device/ScreenOrientationTest.kt @@ -0,0 +1,87 @@ +/* + * Copyright (C) 2023 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 androidx.test.gradletests.espresso.device + +import androidx.test.espresso.Espresso.onView +import androidx.test.espresso.action.ViewActions.click +import androidx.test.espresso.assertion.ViewAssertions.matches +import androidx.test.espresso.device.EspressoDevice.Companion.onDevice +import androidx.test.espresso.device.action.ScreenOrientation +import androidx.test.espresso.device.action.setScreenOrientation +import androidx.test.espresso.device.rules.ScreenOrientationRule +import androidx.test.espresso.matcher.ViewMatchers.withId +import androidx.test.espresso.matcher.ViewMatchers.withText +import androidx.test.ext.junit.rules.ActivityScenarioRule +import org.junit.Rule +import org.junit.Test +import org.junit.rules.RuleChain +import org.junit.runner.RunWith +import org.junit.runners.JUnit4 + +@RunWith(JUnit4::class) +class ScreenOrientationTest { + private val activityRule: ActivityScenarioRule = + ActivityScenarioRule(ScreenOrientationActivity::class.java) + + private val screenOrientationRule: ScreenOrientationRule = + ScreenOrientationRule(ScreenOrientation.PORTRAIT) + + @get:Rule + val ruleChain: RuleChain = RuleChain.outerRule(activityRule).around(screenOrientationRule) + + @Test + fun onDevice_setScreenOrientationToLandscape() { + onDevice().perform(setScreenOrientation(ScreenOrientation.LANDSCAPE)) + + onView(withId(R.id.current_screen_orientation)).check(matches(withText("landscape"))) + } + + @Test + fun onDevice_setScreenOrientationToPortrait() { + onDevice().perform(setScreenOrientation(ScreenOrientation.PORTRAIT)) + + onView(withId(R.id.current_screen_orientation)).check(matches(withText("portrait"))) + } + + @Test + fun onDevice_setScreenOrientationToLandscapeAndThenToPortrait() { + onDevice().perform(setScreenOrientation(ScreenOrientation.LANDSCAPE)) + + onView(withId(R.id.current_screen_orientation)).check(matches(withText("landscape"))) + + onDevice().perform(setScreenOrientation(ScreenOrientation.PORTRAIT)) + + onView(withId(R.id.current_screen_orientation)).check(matches(withText("portrait"))) + } + + @Test + fun onDevice_clickAndThenSetScreenOrientationToLandscape() { + onView(withId(R.id.current_screen_orientation)).perform(click()) + + onDevice().perform(setScreenOrientation(ScreenOrientation.LANDSCAPE)) + + onView(withId(R.id.current_screen_orientation)).check(matches(withText("landscape"))) + } + + @Test + fun onDevice_setScreenOrientationToLandscapeThenClick() { + onDevice().perform(setScreenOrientation(ScreenOrientation.LANDSCAPE)) + + onView(withId(R.id.current_screen_orientation)).perform(click()) + onView(withId(R.id.current_screen_orientation)).check(matches(withText("landscape"))) + } +} diff --git a/gradle-tests/espresso-device/src/main/AndroidManifest.xml b/gradle-tests/espresso-device/src/main/AndroidManifest.xml new file mode 100644 index 000000000..bbc5ef20f --- /dev/null +++ b/gradle-tests/espresso-device/src/main/AndroidManifest.xml @@ -0,0 +1,13 @@ + + + + + + + \ No newline at end of file diff --git a/gradle-tests/espresso-device/src/main/java/androidx/test/gradletests/espresso-device/ScreenOrientationActivity.kt b/gradle-tests/espresso-device/src/main/java/androidx/test/gradletests/espresso-device/ScreenOrientationActivity.kt new file mode 100644 index 000000000..0f0391aa3 --- /dev/null +++ b/gradle-tests/espresso-device/src/main/java/androidx/test/gradletests/espresso-device/ScreenOrientationActivity.kt @@ -0,0 +1,66 @@ +/* + * Copyright (C) 2023 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 androidx.test.gradletests.espresso.device + +import android.app.Activity +import android.content.res.Configuration +import android.os.Bundle +import android.util.Log +import android.widget.TextView + +/** Activity that updates a TextView when its screen orientation is changed. */ +class ScreenOrientationActivity : Activity() { + companion object { + private val TAG = "ScreenOrientationActivity" + } + + override fun onCreate(savedInstanceState: Bundle?) { + super.onCreate(savedInstanceState) + setContentView(R.layout.activity_screen_orientation) + + // Set orientation in onCreate the first time it's called. + val textView: TextView = findViewById(R.id.current_screen_orientation) + if ( + textView + .getText() + .toString() + .equals(getResources().getString(R.string.screen_orientation_text)) + ) { + val orientation = setOrientationString(getResources().getConfiguration().orientation) + Log.d(TAG, "onCreate. Orientation set to " + orientation) + } + } + + override fun onConfigurationChanged(newConfig: Configuration) { + super.onConfigurationChanged(newConfig) + val newOrientation = setOrientationString(newConfig.orientation) + Log.d(TAG, "onConfigurationChanged. New orientation is " + newOrientation) + } + + private fun setOrientationString(orientation: Int): String { + val orientationString = + if (orientation == Configuration.ORIENTATION_LANDSCAPE) { + "landscape" + } else { + "portrait" + } + + val textView: TextView = findViewById(R.id.current_screen_orientation) + textView.setText(orientationString) + return orientationString + } +} diff --git a/gradle-tests/espresso-device/src/main/res/layout/activity_screen_orientation.xml b/gradle-tests/espresso-device/src/main/res/layout/activity_screen_orientation.xml new file mode 100644 index 000000000..cd1dc75d0 --- /dev/null +++ b/gradle-tests/espresso-device/src/main/res/layout/activity_screen_orientation.xml @@ -0,0 +1,29 @@ + + + + + + + + \ No newline at end of file diff --git a/gradle-tests/espresso-device/src/main/res/values/strings.xml b/gradle-tests/espresso-device/src/main/res/values/strings.xml new file mode 100644 index 000000000..f4bbf81c6 --- /dev/null +++ b/gradle-tests/espresso-device/src/main/res/values/strings.xml @@ -0,0 +1,23 @@ + + + + + + screen orientation has not been set + + \ No newline at end of file diff --git a/gradle-tests/gradle.properties b/gradle-tests/gradle.properties index 3e927b11e..ad500c0da 100644 --- a/gradle-tests/gradle.properties +++ b/gradle-tests/gradle.properties @@ -18,4 +18,5 @@ android.useAndroidX=true # Enables namespacing of each library's R class so that its R class includes only the # resources declared in the library itself and none from the library's dependencies, # thereby reducing the size of the R class for that library -android.nonTransitiveRClass=true \ No newline at end of file +android.nonTransitiveRClass=true +android.experimental.androidTest.enableEmulatorControl=true \ No newline at end of file diff --git a/gradle-tests/settings.gradle b/gradle-tests/settings.gradle index 0de023046..b925edb9e 100644 --- a/gradle-tests/settings.gradle +++ b/gradle-tests/settings.gradle @@ -22,6 +22,7 @@ dependencyResolutionManagement { library('espresso.accessibility', 'androidx.test.espresso:espresso-accessibility:3.6.0-alpha03') library('espresso.contrib', 'androidx.test.espresso:espresso-contrib:3.6.0-alpha03') library('espresso.core', 'androidx.test.espresso:espresso-core:3.6.0-alpha03') + library('espresso.device', 'androidx.test.espresso:espresso-device:1.0.0-alpha08') library('espresso.idlingresource', 'androidx.test.espresso:espresso-idling-resource:3.6.0-alpha03') library('espresso.intents', 'androidx.test.espresso:espresso-intents:3.6.0-alpha03') library('espresso.web', 'androidx.test.espresso:espresso-web:3.6.0-alpha03') @@ -36,6 +37,7 @@ include ':runner' include ':espresso' include ':espresso:accessibility' include ':espresso:contrib' +include ':espresso:device' include ':espresso:idling_resource' include ':espresso:web' include ':orchestrator'