diff --git a/components/feature/tabs/src/main/java/mozilla/components/feature/tabs/tabstray/TabsFeature.kt b/components/feature/tabs/src/main/java/mozilla/components/feature/tabs/tabstray/TabsFeature.kt index 618cf9c1472..316e4d1f675 100644 --- a/components/feature/tabs/src/main/java/mozilla/components/feature/tabs/tabstray/TabsFeature.kt +++ b/components/feature/tabs/src/main/java/mozilla/components/feature/tabs/tabstray/TabsFeature.kt @@ -24,17 +24,17 @@ class TabsFeature( tabsTray: TabsTray, private val store: BrowserStore, tabsUseCases: TabsUseCases, - thumbnailsUseCases: ThumbnailsUseCases, private val defaultTabsFilter: (TabSessionState) -> Boolean = { true }, - closeTabsTray: () -> Unit + closeTabsTray: () -> Unit, + thumbnailsUseCases: ThumbnailsUseCases? = null ) : LifecycleAwareFeature { @VisibleForTesting internal var presenter = TabsTrayPresenter( tabsTray, store, - thumbnailsUseCases, defaultTabsFilter, - closeTabsTray + closeTabsTray, + thumbnailsUseCases ) @VisibleForTesting diff --git a/components/feature/tabs/src/main/java/mozilla/components/feature/tabs/tabstray/TabsTrayPresenter.kt b/components/feature/tabs/src/main/java/mozilla/components/feature/tabs/tabstray/TabsTrayPresenter.kt index 2e29c1935b6..20a8a3ec058 100644 --- a/components/feature/tabs/src/main/java/mozilla/components/feature/tabs/tabstray/TabsTrayPresenter.kt +++ b/components/feature/tabs/src/main/java/mozilla/components/feature/tabs/tabstray/TabsTrayPresenter.kt @@ -28,9 +28,9 @@ import mozilla.components.support.ktx.kotlinx.coroutines.flow.ifChanged class TabsTrayPresenter( private val tabsTray: TabsTray, private val store: BrowserStore, - private val thumbnailsUseCases: ThumbnailsUseCases, internal var tabsFilter: (TabSessionState) -> Boolean, - private val closeTabsTray: () -> Unit + private val closeTabsTray: () -> Unit, + private val thumbnailsUseCases: ThumbnailsUseCases? = null ) { private var tabs: Tabs? = null private var scope: CoroutineScope? = null @@ -46,10 +46,14 @@ class TabsTrayPresenter( private suspend fun collect(flow: Flow) { flow.map { it.toTabs(tabsFilter) } .map { tabs -> - // Load the tab thumbnail from the memory or disk caches. - tabs.copy(list = tabs.list.map { tab -> - tab.copy(thumbnail = thumbnailsUseCases.loadThumbnail(tab.id)) - }) + if (thumbnailsUseCases != null) { + // Load the tab thumbnail from the memory or disk caches. + tabs.copy(list = tabs.list.map { tab -> + tab.copy(thumbnail = thumbnailsUseCases.loadThumbnail(tab.id)) + }) + } else { + tabs + } } .ifChanged() .collect { tabs -> diff --git a/components/feature/tabs/src/test/java/mozilla/components/feature/tabs/tabstray/TabsFeatureTest.kt b/components/feature/tabs/src/test/java/mozilla/components/feature/tabs/tabstray/TabsFeatureTest.kt index da06c454328..f7525a4cd47 100644 --- a/components/feature/tabs/src/test/java/mozilla/components/feature/tabs/tabstray/TabsFeatureTest.kt +++ b/components/feature/tabs/src/test/java/mozilla/components/feature/tabs/tabstray/TabsFeatureTest.kt @@ -99,7 +99,7 @@ class TabsFeatureTest { val filter: (TabSessionState) -> Boolean = { false } val sessionManager = SessionManager(engine = mock()) val useCases = TabsUseCases(sessionManager) - val tabsFeature = spy(TabsFeature(mock(), store, useCases, mock(), filter, mock())) + val tabsFeature = spy(TabsFeature(mock(), store, useCases, filter, mock())) val presenter: TabsTrayPresenter = mock() val interactor: TabsTrayInteractor = mock() diff --git a/components/feature/tabs/src/test/java/mozilla/components/feature/tabs/tabstray/TabsTrayPresenterTest.kt b/components/feature/tabs/src/test/java/mozilla/components/feature/tabs/tabstray/TabsTrayPresenterTest.kt index 14c06e07e76..e7ce4f46fd0 100644 --- a/components/feature/tabs/src/test/java/mozilla/components/feature/tabs/tabstray/TabsTrayPresenterTest.kt +++ b/components/feature/tabs/src/test/java/mozilla/components/feature/tabs/tabstray/TabsTrayPresenterTest.kt @@ -18,15 +18,12 @@ import mozilla.components.browser.state.state.BrowserState import mozilla.components.browser.state.state.MediaState import mozilla.components.browser.state.state.createTab import mozilla.components.browser.state.store.BrowserStore -import mozilla.components.browser.thumbnails.ThumbnailsUseCases -import mozilla.components.browser.thumbnails.storage.ThumbnailStorage import mozilla.components.concept.tabstray.Tabs import mozilla.components.concept.tabstray.TabsTray import mozilla.components.feature.tabs.ext.toTabs import mozilla.components.support.test.any import mozilla.components.support.test.ext.joinBlocking import mozilla.components.support.test.mock -import mozilla.components.support.test.robolectric.testContext import org.junit.After import org.junit.Assert.assertEquals import org.junit.Assert.assertFalse @@ -61,16 +58,15 @@ class TabsTrayPresenterTest { val store = BrowserStore( BrowserState( tabs = listOf( - createTab("https://www.mozilla.org", id = "a", thumbnail = mock()), - createTab("https://getpocket.com", id = "b", thumbnail = mock()) + createTab("https://www.mozilla.org", id = "a"), + createTab("https://getpocket.com", id = "b") ), selectedTabId = "a" ) ) val tabsTray: MockedTabsTray = spy(MockedTabsTray()) - val thumbnailsUseCases = ThumbnailsUseCases(store, ThumbnailStorage(testContext)) - val presenter = TabsTrayPresenter(tabsTray, store, thumbnailsUseCases, { true }, mock()) + val presenter = TabsTrayPresenter(tabsTray, store, { true }, mock()) verifyNoMoreInteractions(tabsTray) @@ -93,16 +89,15 @@ class TabsTrayPresenterTest { val store = BrowserStore( BrowserState( tabs = listOf( - createTab("https://www.mozilla.org", id = "a", thumbnail = mock()), - createTab("https://getpocket.com", id = "b", thumbnail = mock()) + createTab("https://www.mozilla.org", id = "a"), + createTab("https://getpocket.com", id = "b") ), selectedTabId = "a" ) ) val tabsTray: MockedTabsTray = spy(MockedTabsTray()) - val thumbnailsUseCases = ThumbnailsUseCases(store, ThumbnailStorage(testContext)) - val presenter = TabsTrayPresenter(tabsTray, store, thumbnailsUseCases, { true }, mock()) + val presenter = TabsTrayPresenter(tabsTray, store, { true }, mock()) presenter.start() @@ -112,7 +107,7 @@ class TabsTrayPresenterTest { store.dispatch( TabListAction.AddTabAction( - createTab("https://developer.mozilla.org/", thumbnail = mock()) + createTab("https://developer.mozilla.org/") ) ).joinBlocking() @@ -128,16 +123,15 @@ class TabsTrayPresenterTest { val store = BrowserStore( BrowserState( tabs = listOf( - createTab("https://www.mozilla.org", id = "a", thumbnail = mock()), - createTab("https://getpocket.com", id = "b", thumbnail = mock()) + createTab("https://www.mozilla.org", id = "a"), + createTab("https://getpocket.com", id = "b") ), selectedTabId = "a" ) ) val tabsTray: MockedTabsTray = spy(MockedTabsTray()) - val thumbnailsUseCases = ThumbnailsUseCases(store, ThumbnailStorage(testContext)) - val presenter = TabsTrayPresenter(tabsTray, store, thumbnailsUseCases, { true }, mock()) + val presenter = TabsTrayPresenter(tabsTray, store, { true }, mock()) presenter.start() @@ -165,16 +159,15 @@ class TabsTrayPresenterTest { val store = BrowserStore( BrowserState( tabs = listOf( - createTab("https://www.mozilla.org", id = "a", thumbnail = mock()), - createTab("https://getpocket.com", id = "b", thumbnail = mock()) + createTab("https://www.mozilla.org", id = "a"), + createTab("https://getpocket.com", id = "b") ), selectedTabId = "a" ) ) val tabsTray: MockedTabsTray = spy(MockedTabsTray()) - val thumbnailsUseCases = ThumbnailsUseCases(store, ThumbnailStorage(testContext)) - val presenter = TabsTrayPresenter(tabsTray, store, thumbnailsUseCases, { true }, mock()) + val presenter = TabsTrayPresenter(tabsTray, store, { true }, mock()) presenter.start() @@ -197,19 +190,18 @@ class TabsTrayPresenterTest { val store = BrowserStore( BrowserState( tabs = listOf( - createTab("https://www.mozilla.org", id = "a", thumbnail = mock()), - createTab("https://getpocket.com", id = "b", thumbnail = mock()), - createTab("https://developer.mozilla.org", id = "c", thumbnail = mock()), - createTab("https://www.firefox.com", id = "d", thumbnail = mock()), - createTab("https://www.google.com", id = "e", thumbnail = mock()) + createTab("https://www.mozilla.org", id = "a"), + createTab("https://getpocket.com", id = "b"), + createTab("https://developer.mozilla.org", id = "c"), + createTab("https://www.firefox.com", id = "d"), + createTab("https://www.google.com", id = "e") ), selectedTabId = "a" ) ) val tabsTray: MockedTabsTray = spy(MockedTabsTray()) - val thumbnailsUseCases = ThumbnailsUseCases(store, ThumbnailStorage(testContext)) - val presenter = TabsTrayPresenter(tabsTray, store, thumbnailsUseCases, { true }, mock()) + val presenter = TabsTrayPresenter(tabsTray, store, { true }, mock()) presenter.start() testDispatcher.advanceUntilIdle() @@ -232,29 +224,25 @@ class TabsTrayPresenterTest { val store = BrowserStore( BrowserState( tabs = listOf( - createTab("https://www.mozilla.org", id = "a", thumbnail = mock()), - createTab("https://getpocket.com", id = "b", thumbnail = mock()), - createTab("https://developer.mozilla.org", id = "c", thumbnail = mock()), - createTab("https://www.firefox.com", id = "d", thumbnail = mock()), - createTab("https://www.google.com", id = "e", thumbnail = mock()) + createTab("https://www.mozilla.org", id = "a"), + createTab("https://getpocket.com", id = "b"), + createTab("https://developer.mozilla.org", id = "c"), + createTab("https://www.firefox.com", id = "d"), + createTab("https://www.google.com", id = "e") ), selectedTabId = "a" ) ) val tabsTray: MockedTabsTray = spy(MockedTabsTray()) - val thumbnailsUseCases = ThumbnailsUseCases(store, ThumbnailStorage(testContext)) - val presenter = TabsTrayPresenter(tabsTray, store, thumbnailsUseCases, { true }, mock()) + val presenter = TabsTrayPresenter(tabsTray, store, { true }, mock()) presenter.start() testDispatcher.advanceUntilIdle() store.dispatch( MediaAction.UpdateMediaAggregateAction( - store.state.media.aggregate.copy( - activeTabId = "a", - state = MediaState.State.PLAYING - ) + store.state.media.aggregate.copy(activeTabId = "a", state = MediaState.State.PLAYING) ) ).joinBlocking() @@ -268,11 +256,11 @@ class TabsTrayPresenterTest { val store = BrowserStore( BrowserState( tabs = listOf( - createTab("https://www.mozilla.org", id = "a", thumbnail = mock()), - createTab("https://getpocket.com", id = "b", thumbnail = mock()), - createTab("https://developer.mozilla.org", id = "c", thumbnail = mock()), - createTab("https://www.firefox.com", id = "d", thumbnail = mock()), - createTab("https://www.google.com", id = "e", thumbnail = mock()) + createTab("https://www.mozilla.org", id = "a"), + createTab("https://getpocket.com", id = "b"), + createTab("https://developer.mozilla.org", id = "c"), + createTab("https://www.firefox.com", id = "d"), + createTab("https://www.google.com", id = "e") ), selectedTabId = "a" ) @@ -281,13 +269,7 @@ class TabsTrayPresenterTest { var closed = false val tabsTray: MockedTabsTray = spy(MockedTabsTray()) - val thumbnailsUseCases = ThumbnailsUseCases(store, ThumbnailStorage(testContext)) - val presenter = TabsTrayPresenter( - tabsTray, - store, - thumbnailsUseCases, - tabsFilter = { true }, - closeTabsTray = { closed = true }) + val presenter = TabsTrayPresenter(tabsTray, store, tabsFilter = { true }, closeTabsTray = { closed = true }) presenter.start() testDispatcher.advanceUntilIdle() @@ -307,8 +289,8 @@ class TabsTrayPresenterTest { val store = BrowserStore( BrowserState( tabs = listOf( - createTab("https://www.mozilla.org", id = "a", thumbnail = mock()), - createTab("https://getpocket.com", id = "b", thumbnail = mock()) + createTab("https://www.mozilla.org", id = "a"), + createTab("https://getpocket.com", id = "b") ), selectedTabId = "a" ) @@ -317,13 +299,7 @@ class TabsTrayPresenterTest { var closed = false val tabsTray: MockedTabsTray = spy(MockedTabsTray()) - val thumbnailsUseCases = ThumbnailsUseCases(store, ThumbnailStorage(testContext)) - val presenter = TabsTrayPresenter( - tabsTray, - store, - thumbnailsUseCases, - tabsFilter = { true }, - closeTabsTray = { closed = true }) + val presenter = TabsTrayPresenter(tabsTray, store, tabsFilter = { true }, closeTabsTray = { closed = true }) presenter.start() testDispatcher.advanceUntilIdle() @@ -348,16 +324,15 @@ class TabsTrayPresenterTest { val store = BrowserStore( BrowserState( tabs = listOf( - createTab("https://www.mozilla.org", id = "a", thumbnail = mock()), - createTab("https://getpocket.com", id = "b", thumbnail = mock()) + createTab("https://www.mozilla.org", id = "a"), + createTab("https://getpocket.com", id = "b") ), selectedTabId = "a" ) ) val tabsTray: MockedTabsTray = spy(MockedTabsTray()) - val thumbnailsUseCases = ThumbnailsUseCases(store, ThumbnailStorage(testContext)) - val presenter = TabsTrayPresenter(tabsTray, store, thumbnailsUseCases, { true }, mock()) + val presenter = TabsTrayPresenter(tabsTray, store, { true }, mock()) presenter.start() testDispatcher.advanceUntilIdle() @@ -379,17 +354,15 @@ class TabsTrayPresenterTest { val store = BrowserStore( BrowserState( tabs = listOf( - createTab("https://www.mozilla.org", id = "a", thumbnail = mock()), - createTab("https://getpocket.com", id = "b", private = true, thumbnail = mock()) + createTab("https://www.mozilla.org", id = "a"), + createTab("https://getpocket.com", id = "b", private = true) ), selectedTabId = "a" ) ) val tabsTray: MockedTabsTray = spy(MockedTabsTray()) - val thumbnailsUseCases = ThumbnailsUseCases(store, ThumbnailStorage(testContext)) - val presenter = - TabsTrayPresenter(tabsTray, store, thumbnailsUseCases, { it.content.private }, mock()) + val presenter = TabsTrayPresenter(tabsTray, store, { it.content.private }, mock()) presenter.start() testDispatcher.advanceUntilIdle() @@ -408,8 +381,7 @@ class TabsTrayPresenterTest { var invoked = false val tabsTray: MockedTabsTray = spy(MockedTabsTray()) - val presenter = - TabsTrayPresenter(tabsTray, store, mock(), { it.content.private }, { invoked = true }) + val presenter = TabsTrayPresenter(tabsTray, store, { it.content.private }, { invoked = true }) presenter.start() testDispatcher.advanceUntilIdle() @@ -447,8 +419,7 @@ private class MockedTabsTray : TabsTray { override fun notifyAtLeastOneObserver(block: TabsTray.Observer.() -> Unit) {} - override fun wrapConsumers(block: TabsTray.Observer.(R) -> Boolean): List<(R) -> Boolean> = - emptyList() + override fun wrapConsumers(block: TabsTray.Observer.(R) -> Boolean): List<(R) -> Boolean> = emptyList() override fun isObserved(): Boolean = false diff --git a/docs/changelog.md b/docs/changelog.md index d04306c86f4..0a8666075b9 100644 --- a/docs/changelog.md +++ b/docs/changelog.md @@ -16,8 +16,8 @@ permalink: /changelog/ * Added support for [onbeforeunload prompt](https://developer.mozilla.org/en-US/docs/Web/API/WindowEventHandlers/onbeforeunload) * **feature-tabs** - * ⚠️ **This is a breaking change**: Added a dependency on `ThumbnailsUseCases` to `TabsFeature` and `TabsTrayPresenter` - for loading a tab's thumbnail. + * Added an optional `ThumbnailsUseCases` to `TabsFeature` and `TabsTrayPresenter` for loading a + tab's thumbnail. * **browser-thumbnails** * Adds `LoadThumbnailUseCase` in `ThumbnailsUseCases` for loading the thumbnail of a tab. diff --git a/samples/browser/src/main/java/org/mozilla/samples/browser/TabsTrayFragment.kt b/samples/browser/src/main/java/org/mozilla/samples/browser/TabsTrayFragment.kt index df19fcc78f0..c54cc0a61fe 100644 --- a/samples/browser/src/main/java/org/mozilla/samples/browser/TabsTrayFragment.kt +++ b/samples/browser/src/main/java/org/mozilla/samples/browser/TabsTrayFragment.kt @@ -47,8 +47,8 @@ class TabsTrayFragment : Fragment(), UserInteractionHandler { tabsTray, components.store, components.tabsUseCases, - components.thumbnailsUseCases, - closeTabsTray = ::closeTabsTray + closeTabsTray = ::closeTabsTray, + thumbnailsUseCases = components.thumbnailsUseCases ).also { lifecycle.addObserver(it) } }