From fffb7c1d17f5a7cdd5f4f4f6c34425295c17af80 Mon Sep 17 00:00:00 2001 From: Oana Horvath Date: Thu, 25 Jun 2020 15:34:18 +0300 Subject: [PATCH] fixes #11764: delay single-click duration to avoid long-clicks --- .../org/mozilla/fenix/ui/ThreeDotMenuMainTest.kt | 12 +++++++++++- .../java/org/mozilla/fenix/ui/robots/BrowserRobot.kt | 2 +- .../org/mozilla/fenix/ui/robots/SettingsRobot.kt | 7 +++---- 3 files changed, 15 insertions(+), 6 deletions(-) diff --git a/app/src/androidTest/java/org/mozilla/fenix/ui/ThreeDotMenuMainTest.kt b/app/src/androidTest/java/org/mozilla/fenix/ui/ThreeDotMenuMainTest.kt index e59e2a77e40f..3d86476c561d 100644 --- a/app/src/androidTest/java/org/mozilla/fenix/ui/ThreeDotMenuMainTest.kt +++ b/app/src/androidTest/java/org/mozilla/fenix/ui/ThreeDotMenuMainTest.kt @@ -9,6 +9,7 @@ import androidx.test.uiautomator.UiDevice import okhttp3.mockwebserver.MockWebServer import org.junit.After import org.junit.Before +import org.junit.BeforeClass import org.junit.Ignore import org.junit.Rule import org.junit.Test @@ -24,7 +25,6 @@ import org.mozilla.fenix.ui.robots.homeScreen class ThreeDotMenuMainTest { /* ktlint-disable no-blank-line-before-rbrace */ // This imposes unreadable grouping. - private val mDevice = UiDevice.getInstance(InstrumentationRegistry.getInstrumentation()) private lateinit var mockWebServer: MockWebServer @get:Rule @@ -38,6 +38,16 @@ class ThreeDotMenuMainTest { } } + // changing the device preference for Touch and Hold delay, to avoid long-clicks instead of a single-click + companion object { + @BeforeClass + @JvmStatic + fun setDevicePreference() { + val mDevice = UiDevice.getInstance(InstrumentationRegistry.getInstrumentation()) + mDevice.executeShellCommand("settings put secure long_press_timeout 1500") + } + } + @After fun tearDown() { mockWebServer.shutdown() diff --git a/app/src/androidTest/java/org/mozilla/fenix/ui/robots/BrowserRobot.kt b/app/src/androidTest/java/org/mozilla/fenix/ui/robots/BrowserRobot.kt index 77acf3b61b43..91cbb12c6df2 100644 --- a/app/src/androidTest/java/org/mozilla/fenix/ui/robots/BrowserRobot.kt +++ b/app/src/androidTest/java/org/mozilla/fenix/ui/robots/BrowserRobot.kt @@ -17,8 +17,8 @@ import androidx.test.espresso.intent.Intents import androidx.test.espresso.intent.matcher.BundleMatchers import androidx.test.espresso.intent.matcher.IntentMatchers import androidx.test.espresso.matcher.ViewMatchers -import androidx.test.espresso.matcher.ViewMatchers.isCompletelyDisplayed import androidx.test.espresso.matcher.ViewMatchers.Visibility +import androidx.test.espresso.matcher.ViewMatchers.isCompletelyDisplayed import androidx.test.espresso.matcher.ViewMatchers.withEffectiveVisibility import androidx.test.espresso.matcher.ViewMatchers.withId import androidx.test.espresso.matcher.ViewMatchers.withText diff --git a/app/src/androidTest/java/org/mozilla/fenix/ui/robots/SettingsRobot.kt b/app/src/androidTest/java/org/mozilla/fenix/ui/robots/SettingsRobot.kt index fe2db165c7ee..2087f7c6254a 100644 --- a/app/src/androidTest/java/org/mozilla/fenix/ui/robots/SettingsRobot.kt +++ b/app/src/androidTest/java/org/mozilla/fenix/ui/robots/SettingsRobot.kt @@ -19,7 +19,6 @@ import androidx.test.espresso.intent.matcher.IntentMatchers.toPackage import androidx.test.espresso.matcher.ViewMatchers import androidx.test.espresso.matcher.ViewMatchers.Visibility import androidx.test.espresso.matcher.ViewMatchers.hasDescendant -import androidx.test.espresso.matcher.ViewMatchers.isCompletelyDisplayed import androidx.test.espresso.matcher.ViewMatchers.withEffectiveVisibility import androidx.test.espresso.matcher.ViewMatchers.withId import androidx.test.espresso.matcher.ViewMatchers.withText @@ -369,19 +368,19 @@ private fun assertLeakCanaryButton() { private fun assertAboutHeading(): ViewInteraction { scrollToElementByText("About") return onView(withText("About")) - .check(matches(isCompletelyDisplayed())) + .check(matches(withEffectiveVisibility(Visibility.VISIBLE))) } private fun assertRateOnGooglePlay(): ViewInteraction { scrollToElementByText("About Firefox Preview") return onView(withText("Rate on Google Play")) - .check(matches(isCompletelyDisplayed())) + .check(matches(withEffectiveVisibility(Visibility.VISIBLE))) } private fun assertAboutFirefoxPreview(): ViewInteraction { scrollToElementByText("About Firefox Preview") return onView(withText("About Firefox Preview")) - .check(matches(isCompletelyDisplayed())) + .check(matches(withEffectiveVisibility(Visibility.VISIBLE))) } fun swipeToBottom() = onView(withId(R.id.recycler_view)).perform(ViewActions.swipeUp())