Skip to content

Commit

Permalink
For mozilla-mobile#27522 new search codes UI tests
Browse files Browse the repository at this point in the history
  • Loading branch information
AndiAJ committed Nov 2, 2022
1 parent e9ef7c2 commit e4b9452
Show file tree
Hide file tree
Showing 2 changed files with 79 additions and 10 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -21,4 +21,10 @@ object Constants {
const val LONG_CLICK_DURATION: Long = 5000
const val LISTS_MAXSWIPES: Int = 3
const val RETRY_COUNT = 3

val searchEngineCodes = mapOf(
"Google" to "client=firefox-b-m",
"Bing" to "firefox&pc=MOZB&form=MOZMBA",
"DuckDuckGo" to "t=fpas",
)
}
83 changes: 73 additions & 10 deletions app/src/androidTest/java/org/mozilla/fenix/ui/SearchTest.kt
Original file line number Diff line number Diff line change
Expand Up @@ -20,6 +20,7 @@ import org.junit.Rule
import org.junit.Test
import org.mozilla.fenix.customannotations.SmokeTest
import org.mozilla.fenix.helpers.Constants.PackageName.ANDROID_SETTINGS
import org.mozilla.fenix.helpers.Constants.searchEngineCodes
import org.mozilla.fenix.helpers.HomeActivityTestRule
import org.mozilla.fenix.helpers.SearchDispatcher
import org.mozilla.fenix.helpers.TestAssetHelper.getGenericAsset
Expand All @@ -45,6 +46,7 @@ import org.mozilla.fenix.ui.robots.multipleSelectionToolbar

class SearchTest {
lateinit var searchMockServer: MockWebServer
lateinit var queryString: String

@get:Rule
val activityTestRule = AndroidComposeTestRule(
Expand Down Expand Up @@ -117,6 +119,8 @@ class SearchTest {

@Test
fun setDefaultSearchEngineFromShortcutsTest() {
queryString = "firefox"

homeScreen {
}.openThreeDotMenu {
}.openSettings {
Expand All @@ -134,16 +138,18 @@ class SearchTest {

homeScreen {
}.openSearch {
}.submitQuery("firefox") {
}.submitQuery(queryString) {
verifyUrl("duckduckgo.com/?q=firefox")
}
}

@Test
fun clearSearchTest() {
queryString = "test"

homeScreen {
}.openSearch {
typeSearch("test")
typeSearch(queryString)
clickClearButton()
verifySearchBarEmpty()
}
Expand All @@ -153,6 +159,7 @@ class SearchTest {
@SmokeTest
@Test
fun searchGroupShowsInRecentlyVisitedTest() {
queryString = "test search"
val firstPage = getGenericAsset(searchMockServer, 1)
val secondPage = getGenericAsset(searchMockServer, 2)
// setting our custom mockWebServer search URL
Expand All @@ -168,7 +175,7 @@ class SearchTest {
// Performs a search and opens 2 dummy search results links to create a search group
homeScreen {
}.openSearch {
}.submitQuery("test search") {
}.submitQuery(queryString) {
longClickLink("Link 1")
clickContextOpenLinkInNewTab()
longClickLink("Link 2")
Expand All @@ -180,13 +187,14 @@ class SearchTest {
}.openTabDrawer {
}.openTabsListThreeDotMenu {
}.closeAllTabs {
verifyRecentlyVisitedSearchGroupDisplayed(true, "test search", 3)
verifyRecentlyVisitedSearchGroupDisplayed(true, queryString, 3)
}
}

@SmokeTest
@Test
fun noSearchGroupFromPrivateBrowsingTest() {
queryString = "test search"
// setting our custom mockWebServer search URL
val searchString = "http://localhost:${searchMockServer.port}/searchResults.html?search={searchTerms}"
val customSearchEngine = createSearchEngine(
Expand All @@ -199,7 +207,7 @@ class SearchTest {
// Performs a search and opens 2 dummy search results links to create a search group
homeScreen {
}.openSearch {
}.submitQuery("test search") {
}.submitQuery(queryString) {
longClickLink("Link 1")
clickContextOpenLinkInPrivateTab()
longClickLink("Link 2")
Expand All @@ -213,7 +221,7 @@ class SearchTest {
}.openTabsListThreeDotMenu {
}.closeAllTabs {
togglePrivateBrowsingModeOnOff()
verifyCurrentSearchGroupIsDisplayed(false, "test search", 3)
verifyCurrentSearchGroupIsDisplayed(false, queryString, 3)
}.openThreeDotMenu {
}.openHistory {
verifyHistoryItemExists(false, "3 sites")
Expand All @@ -224,6 +232,7 @@ class SearchTest {
@SmokeTest
@Test
fun deleteItemsFromSearchGroupsHistoryTest() {
queryString = "test search"
val firstPage = getGenericAsset(searchMockServer, 1)
val secondPage = getGenericAsset(searchMockServer, 2)
// setting our custom mockWebServer search URL
Expand All @@ -238,7 +247,7 @@ class SearchTest {
// Performs a search and opens 2 dummy search results links to create a search group
homeScreen {
}.openSearch {
}.submitQuery("test search") {
}.submitQuery(queryString) {
longClickLink("Link 1")
clickContextOpenLinkInNewTab()
longClickLink("Link 2")
Expand All @@ -250,8 +259,8 @@ class SearchTest {
}.openTabDrawer {
}.openTabsListThreeDotMenu {
}.closeAllTabs {
verifyRecentlyVisitedSearchGroupDisplayed(true, "test search", 3)
}.openRecentlyVisitedSearchGroupHistoryList("test search") {
verifyRecentlyVisitedSearchGroupDisplayed(true, queryString, 3)
}.openRecentlyVisitedSearchGroupHistoryList(queryString) {
clickDeleteHistoryButton(firstPage.url.toString())
longTapSelectItem(secondPage.url)
multipleSelectionToolbar {
Expand All @@ -262,7 +271,61 @@ class SearchTest {
}
homeScreen {
// checking that the group is removed when only 1 item is left
verifyRecentlyVisitedSearchGroupDisplayed(false, "test search", 1)
verifyRecentlyVisitedSearchGroupDisplayed(false, queryString, 1)
}
}

// Default search code for Google-US
@Test
fun defaultSearchCodeGoogleUS() {
queryString = "firefox"

homeScreen {
}.openSearch {
}.submitQuery(queryString) {
verifyUrl(searchEngineCodes["Google"]!!)
}
}

// Default search code for Bing-US
@Test
fun defaultSearchCodeBingUS() {
queryString = "firefox"

homeScreen {
}.openThreeDotMenu {
}.openSettings {
}.openSearchSubMenu {
changeDefaultSearchEngine("Bing")
}

exitMenu()

homeScreen {
}.openSearch {
}.submitQuery(queryString) {
verifyUrl(searchEngineCodes["Bing"]!!)
}
}

// Default search code for DuckDuckGo-US
@Test
fun defaultSearchCodeDuckDuckGoUS() {
queryString = "firefox"

homeScreen {
}.openThreeDotMenu {
}.openSettings {
}.openSearchSubMenu {
changeDefaultSearchEngine("DuckDuckGo")
}

exitMenu()

homeScreen {
}.openSearch {
}.submitQuery(queryString) {
verifyUrl(searchEngineCodes["DuckDuckGo"]!!)
}
}
}

0 comments on commit e4b9452

Please sign in to comment.