|
|
|
@ -23,7 +23,6 @@ import mozilla.components.browser.state.state.createTab as createStateTab
|
|
|
|
|
import mozilla.components.browser.state.store.BrowserStore
|
|
|
|
|
import mozilla.components.browser.storage.sync.TabEntry
|
|
|
|
|
import mozilla.components.browser.storage.sync.Tab as SyncTab
|
|
|
|
|
import mozilla.components.concept.tabstray.Tab
|
|
|
|
|
import mozilla.components.service.fxa.manager.FxaAccountManager
|
|
|
|
|
import mozilla.components.support.test.rule.MainCoroutineRule
|
|
|
|
|
import org.junit.Assert.assertTrue
|
|
|
|
@ -44,17 +43,12 @@ import org.mozilla.fenix.tabstray.browser.createTab as createTrayTab
|
|
|
|
|
class NavigationInteractorTest {
|
|
|
|
|
private lateinit var store: BrowserStore
|
|
|
|
|
private lateinit var tabsTrayStore: TabsTrayStore
|
|
|
|
|
private lateinit var navigationInteractor: NavigationInteractor
|
|
|
|
|
private val testTab: TabSessionState = createStateTab(url = "https://mozilla.org")
|
|
|
|
|
private val navController: NavController = mockk(relaxed = true)
|
|
|
|
|
private val metrics: MetricController = mockk(relaxed = true)
|
|
|
|
|
private val dismissTabTray: () -> Unit = mockk(relaxed = true)
|
|
|
|
|
private val dismissTabTrayAndNavigateHome: (String) -> Unit = mockk(relaxed = true)
|
|
|
|
|
private val bookmarksUseCase: BookmarksUseCase = mockk(relaxed = true)
|
|
|
|
|
private val context: Context = mockk(relaxed = true)
|
|
|
|
|
private val collectionStorage: TabCollectionStorage = mockk(relaxed = true)
|
|
|
|
|
private val showCollectionSnackbar: (Int, Boolean, Long?) -> Unit = mockk(relaxed = true)
|
|
|
|
|
private val showBookmarkSnackbar: (Int) -> Unit = mockk(relaxed = true)
|
|
|
|
|
private val accountManager: FxaAccountManager = mockk(relaxed = true)
|
|
|
|
|
private val activity: HomeActivity = mockk(relaxed = true)
|
|
|
|
|
|
|
|
|
@ -67,111 +61,18 @@ class NavigationInteractorTest {
|
|
|
|
|
fun setup() {
|
|
|
|
|
store = BrowserStore(initialState = BrowserState(tabs = listOf(testTab)))
|
|
|
|
|
tabsTrayStore = TabsTrayStore()
|
|
|
|
|
navigationInteractor = DefaultNavigationInteractor(
|
|
|
|
|
context,
|
|
|
|
|
activity,
|
|
|
|
|
store,
|
|
|
|
|
navController,
|
|
|
|
|
metrics,
|
|
|
|
|
dismissTabTray,
|
|
|
|
|
dismissTabTrayAndNavigateHome,
|
|
|
|
|
bookmarksUseCase,
|
|
|
|
|
tabsTrayStore,
|
|
|
|
|
collectionStorage,
|
|
|
|
|
showCollectionSnackbar,
|
|
|
|
|
showBookmarkSnackbar,
|
|
|
|
|
accountManager,
|
|
|
|
|
testDispatcher
|
|
|
|
|
)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@Test
|
|
|
|
|
fun `navigation interactor calls the overridden functions`() {
|
|
|
|
|
var tabTrayDismissed = false
|
|
|
|
|
var accountSettingsClicked = false
|
|
|
|
|
var tabSettingsClicked = false
|
|
|
|
|
var openRecentlyClosedClicked = false
|
|
|
|
|
var shareTabsOfTypeClicked = false
|
|
|
|
|
var closeAllTabsClicked = false
|
|
|
|
|
var onShareTabs = false
|
|
|
|
|
var onSaveToCollections = false
|
|
|
|
|
var onBookmarkTabs = false
|
|
|
|
|
var onSyncedTabsClicked = false
|
|
|
|
|
|
|
|
|
|
class TestNavigationInteractor : NavigationInteractor {
|
|
|
|
|
|
|
|
|
|
override fun onTabTrayDismissed() {
|
|
|
|
|
tabTrayDismissed = true
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
override fun onShareTabs(tabs: Collection<Tab>) {
|
|
|
|
|
onShareTabs = true
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
override fun onAccountSettingsClicked() {
|
|
|
|
|
accountSettingsClicked = true
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
override fun onTabSettingsClicked() {
|
|
|
|
|
tabSettingsClicked = true
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
override fun onOpenRecentlyClosedClicked() {
|
|
|
|
|
openRecentlyClosedClicked = true
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
override fun onSaveToCollections(tabs: Collection<Tab>) {
|
|
|
|
|
onSaveToCollections = true
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
override fun onSaveToBookmarks(tabs: Collection<Tab>) {
|
|
|
|
|
onBookmarkTabs = true
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
override fun onSyncedTabClicked(tab: mozilla.components.browser.storage.sync.Tab) {
|
|
|
|
|
onSyncedTabsClicked = true
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
override fun onShareTabsOfTypeClicked(private: Boolean) {
|
|
|
|
|
shareTabsOfTypeClicked = true
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
override fun onCloseAllTabsClicked(private: Boolean) {
|
|
|
|
|
closeAllTabsClicked = true
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
val navigationInteractor: NavigationInteractor = TestNavigationInteractor()
|
|
|
|
|
navigationInteractor.onTabTrayDismissed()
|
|
|
|
|
assertTrue(tabTrayDismissed)
|
|
|
|
|
navigationInteractor.onAccountSettingsClicked()
|
|
|
|
|
assertTrue(accountSettingsClicked)
|
|
|
|
|
navigationInteractor.onTabSettingsClicked()
|
|
|
|
|
assertTrue(tabSettingsClicked)
|
|
|
|
|
navigationInteractor.onOpenRecentlyClosedClicked()
|
|
|
|
|
assertTrue(openRecentlyClosedClicked)
|
|
|
|
|
navigationInteractor.onShareTabsOfTypeClicked(true)
|
|
|
|
|
assertTrue(shareTabsOfTypeClicked)
|
|
|
|
|
navigationInteractor.onCloseAllTabsClicked(true)
|
|
|
|
|
assertTrue(closeAllTabsClicked)
|
|
|
|
|
navigationInteractor.onShareTabs(emptyList())
|
|
|
|
|
assertTrue(onShareTabs)
|
|
|
|
|
navigationInteractor.onSaveToCollections(emptyList())
|
|
|
|
|
assertTrue(onSaveToCollections)
|
|
|
|
|
navigationInteractor.onSaveToBookmarks(emptyList())
|
|
|
|
|
assertTrue(onBookmarkTabs)
|
|
|
|
|
navigationInteractor.onSyncedTabClicked(mockk())
|
|
|
|
|
assertTrue(onSyncedTabsClicked)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@Test
|
|
|
|
|
fun `onTabTrayDismissed calls dismissTabTray on DefaultNavigationInteractor`() {
|
|
|
|
|
navigationInteractor.onTabTrayDismissed()
|
|
|
|
|
var dismissTabTrayInvoked = false
|
|
|
|
|
createInteractor(dismissTabTray = {
|
|
|
|
|
dismissTabTrayInvoked = true
|
|
|
|
|
}).onTabTrayDismissed()
|
|
|
|
|
|
|
|
|
|
// We care about the order here; anything after `dismissTabTray` is not guaranteed.
|
|
|
|
|
verifyOrder {
|
|
|
|
|
assertTrue(dismissTabTrayInvoked)
|
|
|
|
|
verify {
|
|
|
|
|
metrics.track(Event.TabsTrayClosed)
|
|
|
|
|
dismissTabTray()
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
@ -179,7 +80,7 @@ class NavigationInteractorTest {
|
|
|
|
|
fun `onAccountSettingsClicked calls navigation on DefaultNavigationInteractor`() {
|
|
|
|
|
every { accountManager.authenticatedAccount() }.answers { mockk(relaxed = true) }
|
|
|
|
|
|
|
|
|
|
navigationInteractor.onAccountSettingsClicked()
|
|
|
|
|
createInteractor().onAccountSettingsClicked()
|
|
|
|
|
|
|
|
|
|
verify(exactly = 1) { navController.navigate(TabsTrayFragmentDirections.actionGlobalAccountSettingsFragment()) }
|
|
|
|
|
}
|
|
|
|
@ -188,38 +89,42 @@ class NavigationInteractorTest {
|
|
|
|
|
fun `onAccountSettingsClicked when not logged in calls navigation to turn on sync`() {
|
|
|
|
|
every { accountManager.authenticatedAccount() }.answers { null }
|
|
|
|
|
|
|
|
|
|
navigationInteractor.onAccountSettingsClicked()
|
|
|
|
|
createInteractor().onAccountSettingsClicked()
|
|
|
|
|
|
|
|
|
|
verify(exactly = 1) { navController.navigate(TabsTrayFragmentDirections.actionGlobalTurnOnSync()) }
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@Test
|
|
|
|
|
fun `onTabSettingsClicked calls navigation on DefaultNavigationInteractor`() {
|
|
|
|
|
navigationInteractor.onTabSettingsClicked()
|
|
|
|
|
createInteractor().onTabSettingsClicked()
|
|
|
|
|
verify(exactly = 1) { navController.navigate(TabsTrayFragmentDirections.actionGlobalTabSettingsFragment()) }
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@Test
|
|
|
|
|
fun `onOpenRecentlyClosedClicked calls navigation on DefaultNavigationInteractor`() {
|
|
|
|
|
navigationInteractor.onOpenRecentlyClosedClicked()
|
|
|
|
|
createInteractor().onOpenRecentlyClosedClicked()
|
|
|
|
|
verify(exactly = 1) { navController.navigate(TabsTrayFragmentDirections.actionGlobalRecentlyClosed()) }
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@Test
|
|
|
|
|
fun `onCloseAllTabsClicked calls navigation on DefaultNavigationInteractor`() {
|
|
|
|
|
navigationInteractor.onCloseAllTabsClicked(false)
|
|
|
|
|
verify(exactly = 1) { dismissTabTrayAndNavigateHome(any()) }
|
|
|
|
|
var dismissTabTrayAndNavigateHomeInvoked = false
|
|
|
|
|
createInteractor(dismissTabTrayAndNavigateHome = {
|
|
|
|
|
dismissTabTrayAndNavigateHomeInvoked = true
|
|
|
|
|
}).onCloseAllTabsClicked(false)
|
|
|
|
|
|
|
|
|
|
assertTrue(dismissTabTrayAndNavigateHomeInvoked)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@Test
|
|
|
|
|
fun `onShareTabsOfType calls navigation on DefaultNavigationInteractor`() {
|
|
|
|
|
navigationInteractor.onShareTabsOfTypeClicked(false)
|
|
|
|
|
createInteractor().onShareTabsOfTypeClicked(false)
|
|
|
|
|
verify(exactly = 1) { navController.navigate(any<NavDirections>()) }
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@Test
|
|
|
|
|
fun `onShareTabs calls navigation on DefaultNavigationInteractor`() {
|
|
|
|
|
navigationInteractor.onShareTabs(emptyList())
|
|
|
|
|
createInteractor().onShareTabs(emptyList())
|
|
|
|
|
verify(exactly = 1) { navController.navigate(any<NavDirections>()) }
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
@ -228,7 +133,7 @@ class NavigationInteractorTest {
|
|
|
|
|
mockkStatic("org.mozilla.fenix.collections.CollectionsDialogKt")
|
|
|
|
|
|
|
|
|
|
every { any<CollectionsDialog>().show(any()) } answers { }
|
|
|
|
|
navigationInteractor.onSaveToCollections(emptyList())
|
|
|
|
|
createInteractor().onSaveToCollections(emptyList())
|
|
|
|
|
verify(exactly = 1) { metrics.track(Event.TabsTraySaveToCollectionPressed) }
|
|
|
|
|
|
|
|
|
|
unmockkStatic("org.mozilla.fenix.collections.CollectionsDialogKt")
|
|
|
|
@ -236,9 +141,13 @@ class NavigationInteractorTest {
|
|
|
|
|
|
|
|
|
|
@Test
|
|
|
|
|
fun `onBookmarkTabs calls navigation on DefaultNavigationInteractor`() = runBlockingTest {
|
|
|
|
|
navigationInteractor.onSaveToBookmarks(listOf(createTrayTab()))
|
|
|
|
|
var showBookmarkSnackbarInvoked = false
|
|
|
|
|
createInteractor(showBookmarkSnackbar = {
|
|
|
|
|
showBookmarkSnackbarInvoked = true
|
|
|
|
|
}).onSaveToBookmarks(listOf(createTrayTab()))
|
|
|
|
|
|
|
|
|
|
coVerify(exactly = 1) { bookmarksUseCase.addBookmark(any(), any(), any()) }
|
|
|
|
|
coVerify(exactly = 1) { showBookmarkSnackbar(1) }
|
|
|
|
|
assertTrue(showBookmarkSnackbarInvoked)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@Test
|
|
|
|
@ -249,12 +158,15 @@ class NavigationInteractorTest {
|
|
|
|
|
every { tab.active() }.answers { entry }
|
|
|
|
|
every { entry.url }.answers { "https://mozilla.org" }
|
|
|
|
|
|
|
|
|
|
navigationInteractor.onSyncedTabClicked(tab)
|
|
|
|
|
var dismissTabTrayInvoked = false
|
|
|
|
|
createInteractor(dismissTabTray = {
|
|
|
|
|
dismissTabTrayInvoked = true
|
|
|
|
|
}).onSyncedTabClicked(tab)
|
|
|
|
|
|
|
|
|
|
assertTrue(dismissTabTrayInvoked)
|
|
|
|
|
verifyOrder {
|
|
|
|
|
metrics.track(Event.SyncedTabOpened)
|
|
|
|
|
|
|
|
|
|
dismissTabTray()
|
|
|
|
|
activity.openToBrowserAndLoad(
|
|
|
|
|
searchTermOrURL = "https://mozilla.org",
|
|
|
|
|
newTab = true,
|
|
|
|
@ -262,4 +174,29 @@ class NavigationInteractorTest {
|
|
|
|
|
)
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@Suppress("LongParameterList")
|
|
|
|
|
private fun createInteractor(
|
|
|
|
|
dismissTabTray: () -> Unit = { },
|
|
|
|
|
dismissTabTrayAndNavigateHome: (String) -> Unit = { _ -> },
|
|
|
|
|
showCollectionSnackbar: (Int, Boolean, Long?) -> Unit = { _, _, _ -> },
|
|
|
|
|
showBookmarkSnackbar: (Int) -> Unit = { _ -> }
|
|
|
|
|
): NavigationInteractor {
|
|
|
|
|
return DefaultNavigationInteractor(
|
|
|
|
|
context,
|
|
|
|
|
activity,
|
|
|
|
|
store,
|
|
|
|
|
navController,
|
|
|
|
|
metrics,
|
|
|
|
|
dismissTabTray,
|
|
|
|
|
dismissTabTrayAndNavigateHome,
|
|
|
|
|
bookmarksUseCase,
|
|
|
|
|
tabsTrayStore,
|
|
|
|
|
collectionStorage,
|
|
|
|
|
showCollectionSnackbar,
|
|
|
|
|
showBookmarkSnackbar,
|
|
|
|
|
accountManager,
|
|
|
|
|
testDispatcher
|
|
|
|
|
)
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|