|
|
|
@ -6,25 +6,37 @@ package org.mozilla.fenix.search
|
|
|
|
|
|
|
|
|
|
import androidx.navigation.NavController
|
|
|
|
|
import androidx.navigation.NavDirections
|
|
|
|
|
import androidx.test.ext.junit.runners.AndroidJUnit4
|
|
|
|
|
import io.mockk.every
|
|
|
|
|
import io.mockk.mockk
|
|
|
|
|
import io.mockk.verify
|
|
|
|
|
import kotlinx.coroutines.ObsoleteCoroutinesApi
|
|
|
|
|
import mozilla.components.browser.search.SearchEngine
|
|
|
|
|
import mozilla.components.browser.session.Session
|
|
|
|
|
import mozilla.components.browser.session.SessionManager
|
|
|
|
|
import org.junit.Assert.assertTrue
|
|
|
|
|
import mozilla.components.support.test.robolectric.testContext
|
|
|
|
|
import org.junit.Assert.assertFalse
|
|
|
|
|
import org.junit.Before
|
|
|
|
|
import org.junit.Test
|
|
|
|
|
import org.junit.runner.RunWith
|
|
|
|
|
import org.mozilla.fenix.BrowserDirection
|
|
|
|
|
import org.mozilla.fenix.HomeActivity
|
|
|
|
|
import org.mozilla.fenix.R
|
|
|
|
|
import org.mozilla.fenix.TestApplication
|
|
|
|
|
import org.mozilla.fenix.components.metrics.Event
|
|
|
|
|
import org.mozilla.fenix.components.metrics.MetricController
|
|
|
|
|
import org.mozilla.fenix.ext.components
|
|
|
|
|
import org.mozilla.fenix.ext.metrics
|
|
|
|
|
import org.mozilla.fenix.ext.nav
|
|
|
|
|
import org.mozilla.fenix.ext.searchEngineManager
|
|
|
|
|
|
|
|
|
|
import org.mozilla.fenix.ext.settings
|
|
|
|
|
import org.mozilla.fenix.utils.Settings
|
|
|
|
|
import org.mozilla.fenix.whatsnew.clear
|
|
|
|
|
import org.robolectric.annotation.Config
|
|
|
|
|
|
|
|
|
|
@ObsoleteCoroutinesApi
|
|
|
|
|
@RunWith(AndroidJUnit4::class)
|
|
|
|
|
@Config(application = TestApplication::class)
|
|
|
|
|
class DefaultSearchControllerTest {
|
|
|
|
|
|
|
|
|
|
private val context: HomeActivity = mockk(relaxed = true)
|
|
|
|
@ -37,10 +49,10 @@ class DefaultSearchControllerTest {
|
|
|
|
|
private val sessionManager: SessionManager = mockk(relaxed = true)
|
|
|
|
|
|
|
|
|
|
private lateinit var controller: DefaultSearchController
|
|
|
|
|
private lateinit var settings: Settings
|
|
|
|
|
|
|
|
|
|
@Before
|
|
|
|
|
fun setUp() {
|
|
|
|
|
every { store.state.showShortcutEnginePicker } returns false
|
|
|
|
|
every { context.searchEngineManager.defaultSearchEngine } returns defaultSearchEngine
|
|
|
|
|
every { store.state.session } returns session
|
|
|
|
|
every { store.state.searchEngineSource.searchEngine } returns searchEngine
|
|
|
|
@ -52,6 +64,8 @@ class DefaultSearchControllerTest {
|
|
|
|
|
store = store,
|
|
|
|
|
navController = navController
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
settings = testContext.settings().apply { testContext.settings().clear() }
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@Test
|
|
|
|
@ -77,16 +91,71 @@ class DefaultSearchControllerTest {
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@Test
|
|
|
|
|
fun handleTextChanged() {
|
|
|
|
|
fun handleTextChangedNonEmpty() {
|
|
|
|
|
val text = "fenix"
|
|
|
|
|
|
|
|
|
|
controller.handleTextChanged(text)
|
|
|
|
|
|
|
|
|
|
verify { store.dispatch(SearchFragmentAction.UpdateQuery(text)) }
|
|
|
|
|
verify(inverse = true) {
|
|
|
|
|
store.dispatch(SearchFragmentAction.ShowSearchShortcutEnginePicker(false))
|
|
|
|
|
}
|
|
|
|
|
assertTrue(controller.userTypingCheck.ranOnTextChanged)
|
|
|
|
|
|
|
|
|
|
@Test
|
|
|
|
|
fun handleTextChangedEmpty() {
|
|
|
|
|
val text = ""
|
|
|
|
|
|
|
|
|
|
controller.handleTextChanged(text)
|
|
|
|
|
|
|
|
|
|
verify { store.dispatch(SearchFragmentAction.UpdateQuery(text)) }
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@Test
|
|
|
|
|
fun `show search shortcuts when setting enabled AND query empty`() {
|
|
|
|
|
val text = ""
|
|
|
|
|
|
|
|
|
|
controller.handleTextChanged(text)
|
|
|
|
|
|
|
|
|
|
verify { store.dispatch(SearchFragmentAction.ShowSearchShortcutEnginePicker(true)) }
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@Test
|
|
|
|
|
fun `do not show search shortcuts when setting enabled AND query non-empty`() {
|
|
|
|
|
val text = "mozilla"
|
|
|
|
|
|
|
|
|
|
controller.handleTextChanged(text)
|
|
|
|
|
|
|
|
|
|
verify { store.dispatch(SearchFragmentAction.ShowSearchShortcutEnginePicker(false)) }
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@Test
|
|
|
|
|
fun `do not show search shortcuts when setting disabled AND query empty`() {
|
|
|
|
|
testContext.settings().preferences
|
|
|
|
|
.edit()
|
|
|
|
|
.putBoolean(testContext.getString(R.string.pref_key_show_search_shortcuts), false)
|
|
|
|
|
.apply()
|
|
|
|
|
|
|
|
|
|
assertFalse(testContext.settings().shouldShowSearchShortcuts)
|
|
|
|
|
|
|
|
|
|
val text = ""
|
|
|
|
|
|
|
|
|
|
controller.handleTextChanged(text)
|
|
|
|
|
|
|
|
|
|
verify { store.dispatch(SearchFragmentAction.ShowSearchShortcutEnginePicker(false)) }
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@Test
|
|
|
|
|
fun `do not show search shortcuts when setting disabled AND query non-empty`() {
|
|
|
|
|
testContext.settings().preferences
|
|
|
|
|
.edit()
|
|
|
|
|
.putBoolean(testContext.getString(R.string.pref_key_show_search_shortcuts), false)
|
|
|
|
|
.apply()
|
|
|
|
|
|
|
|
|
|
assertFalse(testContext.settings().shouldShowSearchShortcuts)
|
|
|
|
|
|
|
|
|
|
val text = "mozilla"
|
|
|
|
|
|
|
|
|
|
controller.handleTextChanged(text)
|
|
|
|
|
|
|
|
|
|
verify { store.dispatch(SearchFragmentAction.ShowSearchShortcutEnginePicker(false)) }
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@Test
|
|
|
|
@ -137,14 +206,6 @@ class DefaultSearchControllerTest {
|
|
|
|
|
verify { navController.navigate(directions) }
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@Test
|
|
|
|
|
fun handleTurnOnStartedTyping() {
|
|
|
|
|
controller.handleTurnOnStartedTyping()
|
|
|
|
|
|
|
|
|
|
assertTrue(controller.userTypingCheck.ranOnTextChanged)
|
|
|
|
|
assertTrue(controller.userTypingCheck.userHasTyped)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@Test
|
|
|
|
|
fun handleExistingSessionSelected() {
|
|
|
|
|
val session: Session = mockk(relaxed = true)
|
|
|
|
|