|
|
|
@ -6,9 +6,12 @@ package org.mozilla.fenix.tabstray.browser
|
|
|
|
|
|
|
|
|
|
import android.view.LayoutInflater
|
|
|
|
|
import android.view.View
|
|
|
|
|
import android.widget.ImageButton
|
|
|
|
|
import io.mockk.every
|
|
|
|
|
import io.mockk.mockk
|
|
|
|
|
import io.mockk.verify
|
|
|
|
|
import mozilla.components.browser.state.state.BrowserState
|
|
|
|
|
import mozilla.components.browser.state.state.MediaSessionState
|
|
|
|
|
import mozilla.components.browser.state.state.TabSessionState
|
|
|
|
|
import mozilla.components.browser.state.store.BrowserStore
|
|
|
|
|
import mozilla.components.concept.base.images.ImageLoader
|
|
|
|
@ -17,16 +20,25 @@ import org.junit.Assert.assertTrue
|
|
|
|
|
import org.junit.Test
|
|
|
|
|
import org.junit.runner.RunWith
|
|
|
|
|
import org.mozilla.fenix.R
|
|
|
|
|
import org.mozilla.fenix.components.metrics.MetricController
|
|
|
|
|
import org.mozilla.fenix.helpers.FenixRobolectricTestRunner
|
|
|
|
|
import org.mozilla.fenix.selection.SelectionHolder
|
|
|
|
|
import org.mozilla.fenix.tabstray.TabsTrayStore
|
|
|
|
|
import mozilla.components.browser.state.state.createTab
|
|
|
|
|
import mozilla.components.concept.engine.mediasession.MediaSession
|
|
|
|
|
import mozilla.components.lib.publicsuffixlist.PublicSuffixList
|
|
|
|
|
import mozilla.telemetry.glean.testing.GleanTestRule
|
|
|
|
|
import org.junit.Assert.assertEquals
|
|
|
|
|
import org.junit.Assert.assertFalse
|
|
|
|
|
import org.junit.Assert.assertNull
|
|
|
|
|
import org.junit.Rule
|
|
|
|
|
import org.mozilla.fenix.GleanMetrics.Tab
|
|
|
|
|
import org.mozilla.fenix.ext.components
|
|
|
|
|
|
|
|
|
|
@RunWith(FenixRobolectricTestRunner::class)
|
|
|
|
|
class AbstractBrowserTabViewHolderTest {
|
|
|
|
|
@get:Rule
|
|
|
|
|
val gleanTestRule = GleanTestRule(testContext)
|
|
|
|
|
|
|
|
|
|
val store = TabsTrayStore()
|
|
|
|
|
val browserStore = BrowserStore()
|
|
|
|
|
val interactor = mockk<BrowserTrayInteractor>(relaxed = true)
|
|
|
|
@ -41,7 +53,6 @@ class AbstractBrowserTabViewHolderTest {
|
|
|
|
|
store,
|
|
|
|
|
null,
|
|
|
|
|
browserStore,
|
|
|
|
|
mockk(relaxed = true),
|
|
|
|
|
interactor
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
@ -63,7 +74,6 @@ class AbstractBrowserTabViewHolderTest {
|
|
|
|
|
store,
|
|
|
|
|
selectionHolder,
|
|
|
|
|
browserStore,
|
|
|
|
|
mockk(relaxed = true),
|
|
|
|
|
interactor
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
@ -75,6 +85,80 @@ class AbstractBrowserTabViewHolderTest {
|
|
|
|
|
assertTrue(selectionHolder.invoked)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@Test
|
|
|
|
|
fun `WHEN the current media state is paused AND playPause button is clicked THEN the media is played AND the right metric is recorded`() {
|
|
|
|
|
every { testContext.components.publicSuffixList } returns PublicSuffixList(testContext)
|
|
|
|
|
val view = LayoutInflater.from(testContext).inflate(R.layout.tab_tray_item, null)
|
|
|
|
|
val mediaSessionController = mockk<MediaSession.Controller>(relaxed = true)
|
|
|
|
|
val mediaTab = createTab(
|
|
|
|
|
url = "url",
|
|
|
|
|
mediaSessionState = MediaSessionState(
|
|
|
|
|
mediaSessionController,
|
|
|
|
|
playbackState = MediaSession.PlaybackState.PAUSED
|
|
|
|
|
)
|
|
|
|
|
)
|
|
|
|
|
val mediaBrowserStore = BrowserStore(
|
|
|
|
|
initialState =
|
|
|
|
|
BrowserState(listOf(mediaTab))
|
|
|
|
|
)
|
|
|
|
|
val holder = TestTabTrayViewHolder(
|
|
|
|
|
view,
|
|
|
|
|
mockk(relaxed = true),
|
|
|
|
|
store,
|
|
|
|
|
TestSelectionHolder(emptySet()),
|
|
|
|
|
mediaBrowserStore,
|
|
|
|
|
interactor
|
|
|
|
|
)
|
|
|
|
|
assertFalse(Tab.mediaPlay.testHasValue())
|
|
|
|
|
|
|
|
|
|
holder.bind(mediaTab, false, mockk(), mockk())
|
|
|
|
|
|
|
|
|
|
holder.itemView.findViewById<ImageButton>(R.id.play_pause_button).performClick()
|
|
|
|
|
|
|
|
|
|
assertTrue(Tab.mediaPlay.testHasValue())
|
|
|
|
|
assertEquals(1, Tab.mediaPlay.testGetValue().size)
|
|
|
|
|
assertNull(Tab.mediaPlay.testGetValue().single().extra)
|
|
|
|
|
|
|
|
|
|
verify { mediaSessionController.play() }
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@Test
|
|
|
|
|
fun `WHEN the current media state is playing AND playPause button is clicked THEN the media is paused AND the right metric is recorded`() {
|
|
|
|
|
every { testContext.components.publicSuffixList } returns PublicSuffixList(testContext)
|
|
|
|
|
val view = LayoutInflater.from(testContext).inflate(R.layout.tab_tray_item, null)
|
|
|
|
|
val mediaSessionController = mockk<MediaSession.Controller>(relaxed = true)
|
|
|
|
|
val mediaTab = createTab(
|
|
|
|
|
url = "url",
|
|
|
|
|
mediaSessionState = MediaSessionState(
|
|
|
|
|
mediaSessionController,
|
|
|
|
|
playbackState = MediaSession.PlaybackState.PLAYING
|
|
|
|
|
)
|
|
|
|
|
)
|
|
|
|
|
val mediaBrowserStore = BrowserStore(
|
|
|
|
|
initialState =
|
|
|
|
|
BrowserState(listOf(mediaTab))
|
|
|
|
|
)
|
|
|
|
|
val holder = TestTabTrayViewHolder(
|
|
|
|
|
view,
|
|
|
|
|
mockk(relaxed = true),
|
|
|
|
|
store,
|
|
|
|
|
TestSelectionHolder(emptySet()),
|
|
|
|
|
mediaBrowserStore,
|
|
|
|
|
interactor
|
|
|
|
|
)
|
|
|
|
|
assertFalse(Tab.mediaPause.testHasValue())
|
|
|
|
|
|
|
|
|
|
holder.bind(mediaTab, false, mockk(), mockk())
|
|
|
|
|
|
|
|
|
|
holder.itemView.findViewById<ImageButton>(R.id.play_pause_button).performClick()
|
|
|
|
|
|
|
|
|
|
assertTrue(Tab.mediaPause.testHasValue())
|
|
|
|
|
assertEquals(1, Tab.mediaPause.testGetValue().size)
|
|
|
|
|
assertNull(Tab.mediaPause.testGetValue().single().extra)
|
|
|
|
|
|
|
|
|
|
verify { mediaSessionController.pause() }
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@Suppress("LongParameterList")
|
|
|
|
|
class TestTabTrayViewHolder(
|
|
|
|
|
itemView: View,
|
|
|
|
@ -82,10 +166,9 @@ class AbstractBrowserTabViewHolderTest {
|
|
|
|
|
trayStore: TabsTrayStore,
|
|
|
|
|
selectionHolder: SelectionHolder<TabSessionState>?,
|
|
|
|
|
store: BrowserStore,
|
|
|
|
|
metrics: MetricController,
|
|
|
|
|
override val browserTrayInteractor: BrowserTrayInteractor,
|
|
|
|
|
featureName: String = "Test"
|
|
|
|
|
) : AbstractBrowserTabViewHolder(itemView, imageLoader, trayStore, selectionHolder, featureName, store, metrics) {
|
|
|
|
|
) : AbstractBrowserTabViewHolder(itemView, imageLoader, trayStore, selectionHolder, featureName, store) {
|
|
|
|
|
override val thumbnailSize: Int
|
|
|
|
|
get() = 30
|
|
|
|
|
|
|
|
|
|