You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
123 lines
3.8 KiB
Kotlin
123 lines
3.8 KiB
Kotlin
package org.mozilla.fenix.ui
|
|
|
|
import android.content.res.Configuration
|
|
import okhttp3.mockwebserver.MockWebServer
|
|
import org.junit.After
|
|
import org.junit.Before
|
|
import org.junit.Rule
|
|
import org.junit.Test
|
|
import org.mozilla.fenix.helpers.AndroidAssetDispatcher
|
|
import org.mozilla.fenix.helpers.HomeActivityIntentTestRule
|
|
import org.mozilla.fenix.helpers.TestAssetHelper
|
|
import org.mozilla.fenix.helpers.TestHelper.exitMenu
|
|
import org.mozilla.fenix.ui.robots.homeScreen
|
|
import org.mozilla.fenix.ui.robots.navigationToolbar
|
|
|
|
class SettingsCustomizeTest {
|
|
private lateinit var mockWebServer: MockWebServer
|
|
|
|
@get:Rule
|
|
val activityIntentTestRule = HomeActivityIntentTestRule.withDefaultSettingsOverrides()
|
|
|
|
@Before
|
|
fun setUp() {
|
|
mockWebServer = MockWebServer().apply {
|
|
dispatcher = AndroidAssetDispatcher()
|
|
start()
|
|
}
|
|
}
|
|
|
|
@After
|
|
fun tearDown() {
|
|
mockWebServer.shutdown()
|
|
}
|
|
|
|
private fun getUiTheme(): Boolean {
|
|
val mode =
|
|
activityIntentTestRule.activity.resources?.configuration?.uiMode?.and(Configuration.UI_MODE_NIGHT_MASK)
|
|
|
|
return when (mode) {
|
|
Configuration.UI_MODE_NIGHT_YES -> true // dark theme is set
|
|
Configuration.UI_MODE_NIGHT_NO -> false // dark theme is not set, using light theme
|
|
else -> false // default option is light theme
|
|
}
|
|
}
|
|
|
|
@Test
|
|
fun changeThemeSettingTest() {
|
|
// Goes through the settings and changes the default search engine, then verifies it changes.
|
|
homeScreen {
|
|
}.openThreeDotMenu {
|
|
}.openSettings {
|
|
}.openCustomizeSubMenu {
|
|
verifyThemes()
|
|
selectDarkMode()
|
|
verifyDarkThemeApplied(getUiTheme())
|
|
selectLightMode()
|
|
verifyLightThemeApplied(getUiTheme())
|
|
}
|
|
}
|
|
|
|
@Test
|
|
fun setToolbarPositionTest() {
|
|
homeScreen {
|
|
}.openThreeDotMenu {
|
|
}.openSettings {
|
|
}.openCustomizeSubMenu {
|
|
verifyToolbarPositionPreference("Bottom")
|
|
clickTopToolbarToggle()
|
|
verifyToolbarPositionPreference("Top")
|
|
}.goBack {
|
|
}.goBack {
|
|
verifyToolbarPosition(defaultPosition = false)
|
|
}.openThreeDotMenu {
|
|
}.openSettings {
|
|
}.openCustomizeSubMenu {
|
|
clickBottomToolbarToggle()
|
|
verifyToolbarPositionPreference("Bottom")
|
|
exitMenu()
|
|
}
|
|
homeScreen {
|
|
verifyToolbarPosition(defaultPosition = true)
|
|
}
|
|
}
|
|
|
|
@Test
|
|
fun swipeToolbarGesturePreferenceOffTest() {
|
|
val firstWebPage = TestAssetHelper.getGenericAsset(mockWebServer, 1)
|
|
val secondWebPage = TestAssetHelper.getGenericAsset(mockWebServer, 2)
|
|
|
|
homeScreen {
|
|
}.openThreeDotMenu {
|
|
}.openSettings {
|
|
}.openCustomizeSubMenu {
|
|
verifySwipeToolbarGesturePrefState(true)
|
|
clickSwipeToolbarToSwitchTabToggle()
|
|
verifySwipeToolbarGesturePrefState(false)
|
|
exitMenu()
|
|
}
|
|
navigationToolbar {
|
|
}.enterURLAndEnterToBrowser(firstWebPage.url) {
|
|
}.openTabDrawer {
|
|
}.openNewTab {
|
|
}.submitQuery(secondWebPage.url.toString()) {
|
|
swipeNavBarRight(secondWebPage.url.toString())
|
|
verifyUrl(secondWebPage.url.toString())
|
|
swipeNavBarLeft(secondWebPage.url.toString())
|
|
verifyUrl(secondWebPage.url.toString())
|
|
}
|
|
}
|
|
|
|
@Test
|
|
fun pullToRefreshPreferenceTest() {
|
|
homeScreen {
|
|
}.openThreeDotMenu {
|
|
}.openSettings {
|
|
}.openCustomizeSubMenu {
|
|
verifyPullToRefreshGesturePrefState(isEnabled = true)
|
|
clickPullToRefreshToggle()
|
|
verifyPullToRefreshGesturePrefState(isEnabled = false)
|
|
}
|
|
}
|
|
}
|