Bug 1881250 - Add logs to SettingsSubMenuLanguageRobot

fenix/125.0
AndiAJ 4 months ago committed by mergify[bot]
parent 875e7ac399
commit fc0b206d1f

@ -4,6 +4,7 @@
package org.mozilla.fenix.ui.robots package org.mozilla.fenix.ui.robots
import android.util.Log
import androidx.test.espresso.Espresso.onView import androidx.test.espresso.Espresso.onView
import androidx.test.espresso.action.ViewActions import androidx.test.espresso.action.ViewActions
import androidx.test.espresso.matcher.ViewMatchers import androidx.test.espresso.matcher.ViewMatchers
@ -12,6 +13,7 @@ import androidx.test.uiautomator.UiScrollable
import androidx.test.uiautomator.UiSelector import androidx.test.uiautomator.UiSelector
import org.hamcrest.CoreMatchers import org.hamcrest.CoreMatchers
import org.mozilla.fenix.R import org.mozilla.fenix.R
import org.mozilla.fenix.helpers.Constants.TAG
import org.mozilla.fenix.helpers.MatcherHelper.assertUIObjectExists import org.mozilla.fenix.helpers.MatcherHelper.assertUIObjectExists
import org.mozilla.fenix.helpers.MatcherHelper.itemWithText import org.mozilla.fenix.helpers.MatcherHelper.itemWithText
import org.mozilla.fenix.helpers.TestAssetHelper.waitingTime import org.mozilla.fenix.helpers.TestAssetHelper.waitingTime
@ -21,21 +23,31 @@ import org.mozilla.fenix.helpers.click
class SettingsSubMenuLanguageRobot { class SettingsSubMenuLanguageRobot {
fun selectLanguage(language: String) { fun selectLanguage(language: String) {
Log.i(TAG, "selectLanguage: Waiting for $waitingTime ms for language list to exist")
languagesList().waitForExists(waitingTime) languagesList().waitForExists(waitingTime)
Log.i(TAG, "selectLanguage: Waited for $waitingTime ms for language list to exist")
Log.i(TAG, "selectLanguage: Trying to click language: $language")
languagesList() languagesList()
.getChildByText(UiSelector().text(language), language) .getChildByText(UiSelector().text(language), language)
.click() .click()
Log.i(TAG, "selectLanguage: Clicked language: $language")
} }
fun selectLanguageSearchResult(languageName: String) { fun selectLanguageSearchResult(languageName: String) {
Log.i(TAG, "selectLanguageSearchResult: Waiting for $waitingTime ms for language list to exist")
language(languageName).waitForExists(waitingTime) language(languageName).waitForExists(waitingTime)
Log.i(TAG, "selectLanguageSearchResult: Waited for $waitingTime ms for language list to exist")
Log.i(TAG, "selectLanguageSearchResult: Trying to click language: $languageName")
language(languageName).click() language(languageName).click()
Log.i(TAG, "selectLanguageSearchResult: Clicked language: $languageName")
} }
fun verifyLanguageHeaderIsTranslated(translation: String) = assertUIObjectExists(itemWithText(translation)) fun verifyLanguageHeaderIsTranslated(translation: String) = assertUIObjectExists(itemWithText(translation))
fun verifySelectedLanguage(language: String) { fun verifySelectedLanguage(language: String) {
Log.i(TAG, "verifySelectedLanguage: Waiting for $waitingTime ms for language list to exist")
languagesList().waitForExists(waitingTime) languagesList().waitForExists(waitingTime)
Log.i(TAG, "verifySelectedLanguage: Waited for $waitingTime ms for language list to exist")
assertUIObjectExists( assertUIObjectExists(
languagesList() languagesList()
.getChildByText(UiSelector().text(language), language, true) .getChildByText(UiSelector().text(language), language, true)
@ -44,19 +56,27 @@ class SettingsSubMenuLanguageRobot {
} }
fun openSearchBar() { fun openSearchBar() {
Log.i(TAG, "openSearchBar: Trying to click the search bar")
onView(withId(R.id.search)).click() onView(withId(R.id.search)).click()
Log.i(TAG, "openSearchBar: Clicked the search bar")
} }
fun typeInSearchBar(text: String) { fun typeInSearchBar(text: String) {
Log.i(TAG, "typeInSearchBar: Waiting for $waitingTime ms for search bar to exist")
searchBar().waitForExists(waitingTime) searchBar().waitForExists(waitingTime)
Log.i(TAG, "typeInSearchBar: Waited for $waitingTime ms for search bar to exist")
Log.i(TAG, "typeInSearchBar: Trying to set search bar text to: $text")
searchBar().text = text searchBar().text = text
Log.i(TAG, "typeInSearchBar: Search bar text was set to: $text")
} }
fun verifySearchResultsContains(languageName: String) = fun verifySearchResultsContains(languageName: String) =
assertUIObjectExists(language(languageName)) assertUIObjectExists(language(languageName))
fun clearSearchBar() { fun clearSearchBar() {
Log.i(TAG, "clearSearchBar: Trying to click the clear search bar button")
onView(withId(R.id.search_close_btn)).click() onView(withId(R.id.search_close_btn)).click()
Log.i(TAG, "clearSearchBar: Clicked the clear search bar button")
} }
fun verifyLanguageListIsDisplayed() = assertUIObjectExists(languagesList()) fun verifyLanguageListIsDisplayed() = assertUIObjectExists(languagesList())
@ -64,8 +84,12 @@ class SettingsSubMenuLanguageRobot {
class Transition { class Transition {
fun goBack(interact: SettingsRobot.() -> Unit): SettingsRobot.Transition { fun goBack(interact: SettingsRobot.() -> Unit): SettingsRobot.Transition {
Log.i(TAG, "goBack: Waiting for device to be idle")
mDevice.waitForIdle() mDevice.waitForIdle()
Log.i(TAG, "goBack: Waited for device to be idle")
Log.i(TAG, "goBack: Trying to click the navigate up button")
goBackButton().perform(ViewActions.click()) goBackButton().perform(ViewActions.click())
Log.i(TAG, "goBack: Clicked the navigate up button")
SettingsRobot().interact() SettingsRobot().interact()
return SettingsRobot.Transition() return SettingsRobot.Transition()

Loading…
Cancel
Save