|
|
@ -20,6 +20,7 @@ import org.junit.Rule
|
|
|
|
import org.junit.Test
|
|
|
|
import org.junit.Test
|
|
|
|
import org.mozilla.fenix.customannotations.SmokeTest
|
|
|
|
import org.mozilla.fenix.customannotations.SmokeTest
|
|
|
|
import org.mozilla.fenix.helpers.Constants.PackageName.ANDROID_SETTINGS
|
|
|
|
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.HomeActivityTestRule
|
|
|
|
import org.mozilla.fenix.helpers.SearchDispatcher
|
|
|
|
import org.mozilla.fenix.helpers.SearchDispatcher
|
|
|
|
import org.mozilla.fenix.helpers.TestAssetHelper.getGenericAsset
|
|
|
|
import org.mozilla.fenix.helpers.TestAssetHelper.getGenericAsset
|
|
|
@ -45,6 +46,7 @@ import org.mozilla.fenix.ui.robots.multipleSelectionToolbar
|
|
|
|
|
|
|
|
|
|
|
|
class SearchTest {
|
|
|
|
class SearchTest {
|
|
|
|
lateinit var searchMockServer: MockWebServer
|
|
|
|
lateinit var searchMockServer: MockWebServer
|
|
|
|
|
|
|
|
lateinit var queryString: String
|
|
|
|
|
|
|
|
|
|
|
|
@get:Rule
|
|
|
|
@get:Rule
|
|
|
|
val activityTestRule = AndroidComposeTestRule(
|
|
|
|
val activityTestRule = AndroidComposeTestRule(
|
|
|
@ -117,6 +119,8 @@ class SearchTest {
|
|
|
|
|
|
|
|
|
|
|
|
@Test
|
|
|
|
@Test
|
|
|
|
fun setDefaultSearchEngineFromShortcutsTest() {
|
|
|
|
fun setDefaultSearchEngineFromShortcutsTest() {
|
|
|
|
|
|
|
|
queryString = "firefox"
|
|
|
|
|
|
|
|
|
|
|
|
homeScreen {
|
|
|
|
homeScreen {
|
|
|
|
}.openThreeDotMenu {
|
|
|
|
}.openThreeDotMenu {
|
|
|
|
}.openSettings {
|
|
|
|
}.openSettings {
|
|
|
@ -134,16 +138,18 @@ class SearchTest {
|
|
|
|
|
|
|
|
|
|
|
|
homeScreen {
|
|
|
|
homeScreen {
|
|
|
|
}.openSearch {
|
|
|
|
}.openSearch {
|
|
|
|
}.submitQuery("firefox") {
|
|
|
|
}.submitQuery(queryString) {
|
|
|
|
verifyUrl("duckduckgo.com/?q=firefox")
|
|
|
|
verifyUrl("duckduckgo.com/?q=firefox")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
@Test
|
|
|
|
@Test
|
|
|
|
fun clearSearchTest() {
|
|
|
|
fun clearSearchTest() {
|
|
|
|
|
|
|
|
queryString = "test"
|
|
|
|
|
|
|
|
|
|
|
|
homeScreen {
|
|
|
|
homeScreen {
|
|
|
|
}.openSearch {
|
|
|
|
}.openSearch {
|
|
|
|
typeSearch("test")
|
|
|
|
typeSearch(queryString)
|
|
|
|
clickClearButton()
|
|
|
|
clickClearButton()
|
|
|
|
verifySearchBarEmpty()
|
|
|
|
verifySearchBarEmpty()
|
|
|
|
}
|
|
|
|
}
|
|
|
@ -153,6 +159,7 @@ class SearchTest {
|
|
|
|
@SmokeTest
|
|
|
|
@SmokeTest
|
|
|
|
@Test
|
|
|
|
@Test
|
|
|
|
fun searchGroupShowsInRecentlyVisitedTest() {
|
|
|
|
fun searchGroupShowsInRecentlyVisitedTest() {
|
|
|
|
|
|
|
|
queryString = "test search"
|
|
|
|
val firstPage = getGenericAsset(searchMockServer, 1)
|
|
|
|
val firstPage = getGenericAsset(searchMockServer, 1)
|
|
|
|
val secondPage = getGenericAsset(searchMockServer, 2)
|
|
|
|
val secondPage = getGenericAsset(searchMockServer, 2)
|
|
|
|
// setting our custom mockWebServer search URL
|
|
|
|
// setting our custom mockWebServer search URL
|
|
|
@ -168,7 +175,7 @@ class SearchTest {
|
|
|
|
// Performs a search and opens 2 dummy search results links to create a search group
|
|
|
|
// Performs a search and opens 2 dummy search results links to create a search group
|
|
|
|
homeScreen {
|
|
|
|
homeScreen {
|
|
|
|
}.openSearch {
|
|
|
|
}.openSearch {
|
|
|
|
}.submitQuery("test search") {
|
|
|
|
}.submitQuery(queryString) {
|
|
|
|
longClickLink("Link 1")
|
|
|
|
longClickLink("Link 1")
|
|
|
|
clickContextOpenLinkInNewTab()
|
|
|
|
clickContextOpenLinkInNewTab()
|
|
|
|
longClickLink("Link 2")
|
|
|
|
longClickLink("Link 2")
|
|
|
@ -180,13 +187,14 @@ class SearchTest {
|
|
|
|
}.openTabDrawer {
|
|
|
|
}.openTabDrawer {
|
|
|
|
}.openTabsListThreeDotMenu {
|
|
|
|
}.openTabsListThreeDotMenu {
|
|
|
|
}.closeAllTabs {
|
|
|
|
}.closeAllTabs {
|
|
|
|
verifyRecentlyVisitedSearchGroupDisplayed(true, "test search", 3)
|
|
|
|
verifyRecentlyVisitedSearchGroupDisplayed(true, queryString, 3)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
@SmokeTest
|
|
|
|
@SmokeTest
|
|
|
|
@Test
|
|
|
|
@Test
|
|
|
|
fun noSearchGroupFromPrivateBrowsingTest() {
|
|
|
|
fun noSearchGroupFromPrivateBrowsingTest() {
|
|
|
|
|
|
|
|
queryString = "test search"
|
|
|
|
// setting our custom mockWebServer search URL
|
|
|
|
// setting our custom mockWebServer search URL
|
|
|
|
val searchString = "http://localhost:${searchMockServer.port}/searchResults.html?search={searchTerms}"
|
|
|
|
val searchString = "http://localhost:${searchMockServer.port}/searchResults.html?search={searchTerms}"
|
|
|
|
val customSearchEngine = createSearchEngine(
|
|
|
|
val customSearchEngine = createSearchEngine(
|
|
|
@ -199,7 +207,7 @@ class SearchTest {
|
|
|
|
// Performs a search and opens 2 dummy search results links to create a search group
|
|
|
|
// Performs a search and opens 2 dummy search results links to create a search group
|
|
|
|
homeScreen {
|
|
|
|
homeScreen {
|
|
|
|
}.openSearch {
|
|
|
|
}.openSearch {
|
|
|
|
}.submitQuery("test search") {
|
|
|
|
}.submitQuery(queryString) {
|
|
|
|
longClickLink("Link 1")
|
|
|
|
longClickLink("Link 1")
|
|
|
|
clickContextOpenLinkInPrivateTab()
|
|
|
|
clickContextOpenLinkInPrivateTab()
|
|
|
|
longClickLink("Link 2")
|
|
|
|
longClickLink("Link 2")
|
|
|
@ -213,7 +221,7 @@ class SearchTest {
|
|
|
|
}.openTabsListThreeDotMenu {
|
|
|
|
}.openTabsListThreeDotMenu {
|
|
|
|
}.closeAllTabs {
|
|
|
|
}.closeAllTabs {
|
|
|
|
togglePrivateBrowsingModeOnOff()
|
|
|
|
togglePrivateBrowsingModeOnOff()
|
|
|
|
verifyCurrentSearchGroupIsDisplayed(false, "test search", 3)
|
|
|
|
verifyCurrentSearchGroupIsDisplayed(false, queryString, 3)
|
|
|
|
}.openThreeDotMenu {
|
|
|
|
}.openThreeDotMenu {
|
|
|
|
}.openHistory {
|
|
|
|
}.openHistory {
|
|
|
|
verifyHistoryItemExists(false, "3 sites")
|
|
|
|
verifyHistoryItemExists(false, "3 sites")
|
|
|
@ -224,6 +232,7 @@ class SearchTest {
|
|
|
|
@SmokeTest
|
|
|
|
@SmokeTest
|
|
|
|
@Test
|
|
|
|
@Test
|
|
|
|
fun deleteItemsFromSearchGroupsHistoryTest() {
|
|
|
|
fun deleteItemsFromSearchGroupsHistoryTest() {
|
|
|
|
|
|
|
|
queryString = "test search"
|
|
|
|
val firstPage = getGenericAsset(searchMockServer, 1)
|
|
|
|
val firstPage = getGenericAsset(searchMockServer, 1)
|
|
|
|
val secondPage = getGenericAsset(searchMockServer, 2)
|
|
|
|
val secondPage = getGenericAsset(searchMockServer, 2)
|
|
|
|
// setting our custom mockWebServer search URL
|
|
|
|
// setting our custom mockWebServer search URL
|
|
|
@ -238,7 +247,7 @@ class SearchTest {
|
|
|
|
// Performs a search and opens 2 dummy search results links to create a search group
|
|
|
|
// Performs a search and opens 2 dummy search results links to create a search group
|
|
|
|
homeScreen {
|
|
|
|
homeScreen {
|
|
|
|
}.openSearch {
|
|
|
|
}.openSearch {
|
|
|
|
}.submitQuery("test search") {
|
|
|
|
}.submitQuery(queryString) {
|
|
|
|
longClickLink("Link 1")
|
|
|
|
longClickLink("Link 1")
|
|
|
|
clickContextOpenLinkInNewTab()
|
|
|
|
clickContextOpenLinkInNewTab()
|
|
|
|
longClickLink("Link 2")
|
|
|
|
longClickLink("Link 2")
|
|
|
@ -250,8 +259,8 @@ class SearchTest {
|
|
|
|
}.openTabDrawer {
|
|
|
|
}.openTabDrawer {
|
|
|
|
}.openTabsListThreeDotMenu {
|
|
|
|
}.openTabsListThreeDotMenu {
|
|
|
|
}.closeAllTabs {
|
|
|
|
}.closeAllTabs {
|
|
|
|
verifyRecentlyVisitedSearchGroupDisplayed(true, "test search", 3)
|
|
|
|
verifyRecentlyVisitedSearchGroupDisplayed(true, queryString, 3)
|
|
|
|
}.openRecentlyVisitedSearchGroupHistoryList("test search") {
|
|
|
|
}.openRecentlyVisitedSearchGroupHistoryList(queryString) {
|
|
|
|
clickDeleteHistoryButton(firstPage.url.toString())
|
|
|
|
clickDeleteHistoryButton(firstPage.url.toString())
|
|
|
|
longTapSelectItem(secondPage.url)
|
|
|
|
longTapSelectItem(secondPage.url)
|
|
|
|
multipleSelectionToolbar {
|
|
|
|
multipleSelectionToolbar {
|
|
|
@ -262,7 +271,61 @@ class SearchTest {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
homeScreen {
|
|
|
|
homeScreen {
|
|
|
|
// checking that the group is removed when only 1 item is left
|
|
|
|
// 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"]!!)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|