Issue #19809: Remove Grid layout info banner in tabs tray
parent
85c438798e
commit
27280e6683
@ -0,0 +1,109 @@
|
||||
/* This Source Code Form is subject to the terms of the Mozilla Public
|
||||
* License, v. 2.0. If a copy of the MPL was not distributed with this
|
||||
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
|
||||
|
||||
package org.mozilla.fenix.tabstray
|
||||
|
||||
import android.view.View.GONE
|
||||
import android.view.View.VISIBLE
|
||||
import android.view.ViewGroup
|
||||
import androidx.coordinatorlayout.widget.CoordinatorLayout
|
||||
import io.mockk.mockk
|
||||
import io.mockk.verify
|
||||
import kotlinx.coroutines.ExperimentalCoroutinesApi
|
||||
import kotlinx.coroutines.test.TestCoroutineDispatcher
|
||||
import mozilla.components.browser.state.action.TabListAction
|
||||
import mozilla.components.browser.state.state.createTab
|
||||
import mozilla.components.browser.state.store.BrowserStore
|
||||
import mozilla.components.support.test.libstate.ext.waitUntilIdle
|
||||
import mozilla.components.support.test.robolectric.testContext
|
||||
import mozilla.components.support.test.rule.MainCoroutineRule
|
||||
import org.junit.Before
|
||||
import org.junit.Rule
|
||||
import org.junit.Test
|
||||
import org.junit.runner.RunWith
|
||||
import org.mozilla.fenix.components.metrics.Event
|
||||
import org.mozilla.fenix.components.metrics.MetricController
|
||||
import org.mozilla.fenix.helpers.FenixRobolectricTestRunner
|
||||
import org.mozilla.fenix.tabstray.TabsTrayInfoBannerBinding.Companion.TAB_COUNT_SHOW_CFR
|
||||
import org.mozilla.fenix.utils.Settings
|
||||
|
||||
@RunWith(FenixRobolectricTestRunner::class)
|
||||
@OptIn(ExperimentalCoroutinesApi::class)
|
||||
class TabsTrayInfoBannerBindingTest {
|
||||
|
||||
private lateinit var store: BrowserStore
|
||||
private lateinit var view: ViewGroup
|
||||
private lateinit var interactor: NavigationInteractor
|
||||
private lateinit var metrics: MetricController
|
||||
private lateinit var settings: Settings
|
||||
|
||||
@get:Rule
|
||||
val coroutinesTestRule = MainCoroutineRule(TestCoroutineDispatcher())
|
||||
|
||||
@Before
|
||||
fun setUp() {
|
||||
store = BrowserStore()
|
||||
view = CoordinatorLayout(testContext)
|
||||
interactor = mockk(relaxed = true)
|
||||
metrics = mockk(relaxed = true)
|
||||
settings = Settings(testContext)
|
||||
}
|
||||
|
||||
@Test
|
||||
fun `WHEN tab number reaches CFR count THEN banner is shown`() {
|
||||
view.visibility = GONE
|
||||
|
||||
val binding =
|
||||
TabsTrayInfoBannerBinding(
|
||||
context = testContext,
|
||||
store = store,
|
||||
infoBannerView = view,
|
||||
settings = settings,
|
||||
navigationInteractor = interactor,
|
||||
metrics = metrics
|
||||
)
|
||||
|
||||
binding.start()
|
||||
for (i in 1 until TAB_COUNT_SHOW_CFR) {
|
||||
store.dispatch(TabListAction.AddTabAction(createTab("https://mozilla.org")))
|
||||
store.waitUntilIdle()
|
||||
|
||||
assert(view.visibility == GONE)
|
||||
}
|
||||
|
||||
store.dispatch(TabListAction.AddTabAction(createTab("https://mozilla.org")))
|
||||
store.waitUntilIdle()
|
||||
assert(view.visibility == VISIBLE)
|
||||
}
|
||||
|
||||
@Test
|
||||
fun `WHEN dismiss THEN auto close tabs info banner will not open tab settings`() {
|
||||
view.visibility = GONE
|
||||
settings.listTabView = false
|
||||
|
||||
val binding =
|
||||
TabsTrayInfoBannerBinding(
|
||||
context = testContext,
|
||||
store = store,
|
||||
infoBannerView = view,
|
||||
settings = settings,
|
||||
navigationInteractor = interactor,
|
||||
metrics = metrics
|
||||
)
|
||||
|
||||
binding.start()
|
||||
for (i in 1..TAB_COUNT_SHOW_CFR) {
|
||||
store.dispatch(TabListAction.AddTabAction(createTab("https://mozilla.org")))
|
||||
store.waitUntilIdle()
|
||||
}
|
||||
|
||||
assert(view.visibility == VISIBLE)
|
||||
binding.banner?.dismissAction?.invoke()
|
||||
|
||||
verify(exactly = 0) { interactor.onTabSettingsClicked() }
|
||||
assert(!settings.shouldShowAutoCloseTabsBanner)
|
||||
verify(exactly = 0) { metrics.track(Event.TabsTrayCfrTapped) }
|
||||
verify(exactly = 1) { metrics.track(Event.TabsTrayCfrDismissed) }
|
||||
}
|
||||
}
|
@ -1,230 +0,0 @@
|
||||
/* This Source Code Form is subject to the terms of the Mozilla Public
|
||||
* License, v. 2.0. If a copy of the MPL was not distributed with this
|
||||
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
|
||||
|
||||
package org.mozilla.fenix.tabstray
|
||||
|
||||
import android.view.View.GONE
|
||||
import android.view.View.VISIBLE
|
||||
import android.view.ViewGroup
|
||||
import androidx.coordinatorlayout.widget.CoordinatorLayout
|
||||
import io.mockk.mockk
|
||||
import io.mockk.verify
|
||||
import kotlinx.coroutines.ExperimentalCoroutinesApi
|
||||
import kotlinx.coroutines.test.TestCoroutineDispatcher
|
||||
import mozilla.components.browser.state.action.TabListAction
|
||||
import mozilla.components.browser.state.state.createTab
|
||||
import mozilla.components.browser.state.store.BrowserStore
|
||||
import mozilla.components.support.test.libstate.ext.waitUntilIdle
|
||||
import mozilla.components.support.test.robolectric.testContext
|
||||
import mozilla.components.support.test.rule.MainCoroutineRule
|
||||
import org.junit.Before
|
||||
import org.junit.Rule
|
||||
import org.junit.Test
|
||||
import org.junit.runner.RunWith
|
||||
import org.mozilla.fenix.components.metrics.Event
|
||||
import org.mozilla.fenix.components.metrics.MetricController
|
||||
import org.mozilla.fenix.helpers.FenixRobolectricTestRunner
|
||||
import org.mozilla.fenix.tabstray.TabsTrayInfoBannerBinding.Companion.TAB_COUNT_SHOW_CFR
|
||||
import org.mozilla.fenix.utils.Settings
|
||||
|
||||
@RunWith(FenixRobolectricTestRunner::class)
|
||||
@OptIn(ExperimentalCoroutinesApi::class)
|
||||
class TabsTrayInfoBannerTest {
|
||||
|
||||
private lateinit var store: BrowserStore
|
||||
private lateinit var view: ViewGroup
|
||||
private lateinit var interactor: NavigationInteractor
|
||||
private lateinit var metrics: MetricController
|
||||
private lateinit var settings: Settings
|
||||
|
||||
@get:Rule
|
||||
val coroutinesTestRule = MainCoroutineRule(TestCoroutineDispatcher())
|
||||
|
||||
@Before
|
||||
fun setUp() {
|
||||
store = BrowserStore()
|
||||
view = CoordinatorLayout(testContext)
|
||||
interactor = mockk(relaxed = true)
|
||||
metrics = mockk(relaxed = true)
|
||||
settings = Settings(testContext)
|
||||
}
|
||||
|
||||
@Test
|
||||
fun `WHEN tab number reaches CFR count THEN banner is shown`() {
|
||||
view.visibility = GONE
|
||||
|
||||
val binding =
|
||||
TabsTrayInfoBannerBinding(
|
||||
context = testContext,
|
||||
store = store,
|
||||
infoBannerView = view,
|
||||
settings = settings,
|
||||
navigationInteractor = interactor,
|
||||
metrics = metrics
|
||||
)
|
||||
|
||||
binding.start()
|
||||
for (i in 1 until TAB_COUNT_SHOW_CFR) {
|
||||
store.dispatch(TabListAction.AddTabAction(createTab("https://mozilla.org")))
|
||||
store.waitUntilIdle()
|
||||
|
||||
assert(view.visibility == GONE)
|
||||
}
|
||||
|
||||
store.dispatch(TabListAction.AddTabAction(createTab("https://mozilla.org")))
|
||||
store.waitUntilIdle()
|
||||
assert(view.visibility == VISIBLE)
|
||||
}
|
||||
|
||||
@Test
|
||||
fun `WHEN in list view THEN grid view banner info banner should be shown`() {
|
||||
view.visibility = GONE
|
||||
settings.listTabView = true
|
||||
|
||||
val binding =
|
||||
TabsTrayInfoBannerBinding(
|
||||
context = testContext,
|
||||
store = store,
|
||||
infoBannerView = view,
|
||||
settings = settings,
|
||||
navigationInteractor = interactor,
|
||||
metrics = metrics
|
||||
)
|
||||
|
||||
binding.start()
|
||||
for (i in 1..TAB_COUNT_SHOW_CFR) {
|
||||
store.dispatch(TabListAction.AddTabAction(createTab("https://mozilla.org")))
|
||||
store.waitUntilIdle()
|
||||
}
|
||||
|
||||
assert(view.visibility == VISIBLE)
|
||||
binding.banner?.actionToPerform?.invoke()
|
||||
|
||||
verify(exactly = 1) { interactor.onTabSettingsClicked() }
|
||||
assert(!settings.shouldShowGridViewBanner)
|
||||
assert(settings.shouldShowAutoCloseTabsBanner)
|
||||
verify(exactly = 1) { metrics.track(Event.TabsTrayCfrTapped) }
|
||||
verify(exactly = 0) { metrics.track(Event.TabsTrayCfrDismissed) }
|
||||
}
|
||||
|
||||
@Test
|
||||
fun `WHEN grid view banner already shown THEN auto close tabs info banner should be shown`() {
|
||||
view.visibility = GONE
|
||||
settings.listTabView = true
|
||||
settings.shouldShowGridViewBanner = false
|
||||
|
||||
val binding =
|
||||
TabsTrayInfoBannerBinding(
|
||||
context = testContext,
|
||||
store = store,
|
||||
infoBannerView = view,
|
||||
settings = settings,
|
||||
navigationInteractor = interactor,
|
||||
metrics = metrics
|
||||
)
|
||||
|
||||
binding.start()
|
||||
for (i in 1..TAB_COUNT_SHOW_CFR) {
|
||||
store.dispatch(TabListAction.AddTabAction(createTab("https://mozilla.org")))
|
||||
store.waitUntilIdle()
|
||||
}
|
||||
|
||||
assert(view.visibility == VISIBLE)
|
||||
binding.banner?.actionToPerform?.invoke()
|
||||
|
||||
verify(exactly = 1) { interactor.onTabSettingsClicked() }
|
||||
assert(!settings.shouldShowGridViewBanner)
|
||||
assert(!settings.shouldShowAutoCloseTabsBanner)
|
||||
verify(exactly = 1) { metrics.track(Event.TabsTrayCfrTapped) }
|
||||
verify(exactly = 0) { metrics.track(Event.TabsTrayCfrDismissed) }
|
||||
}
|
||||
|
||||
@Test
|
||||
fun `WHEN dismiss THEN grid view info banner will not open tab settings`() {
|
||||
view.visibility = GONE
|
||||
settings.listTabView = true
|
||||
|
||||
val binding =
|
||||
TabsTrayInfoBannerBinding(
|
||||
context = testContext,
|
||||
store = store,
|
||||
infoBannerView = view,
|
||||
settings = settings,
|
||||
navigationInteractor = interactor,
|
||||
metrics = metrics
|
||||
)
|
||||
|
||||
binding.start()
|
||||
for (i in 1..TAB_COUNT_SHOW_CFR) {
|
||||
store.dispatch(TabListAction.AddTabAction(createTab("https://mozilla.org")))
|
||||
store.waitUntilIdle()
|
||||
}
|
||||
|
||||
assert(view.visibility == VISIBLE)
|
||||
binding.banner?.dismissAction?.invoke()
|
||||
|
||||
verify(exactly = 0) { interactor.onTabSettingsClicked() }
|
||||
assert(!settings.shouldShowGridViewBanner)
|
||||
assert(settings.shouldShowAutoCloseTabsBanner)
|
||||
verify(exactly = 0) { metrics.track(Event.TabsTrayCfrTapped) }
|
||||
verify(exactly = 1) { metrics.track(Event.TabsTrayCfrDismissed) }
|
||||
}
|
||||
|
||||
@Test
|
||||
fun `WHEN dismiss THEN auto close tabs info banner will not open tab settings`() {
|
||||
view.visibility = GONE
|
||||
settings.listTabView = false
|
||||
|
||||
val binding =
|
||||
TabsTrayInfoBannerBinding(
|
||||
context = testContext,
|
||||
store = store,
|
||||
infoBannerView = view,
|
||||
settings = settings,
|
||||
navigationInteractor = interactor,
|
||||
metrics = metrics
|
||||
)
|
||||
|
||||
binding.start()
|
||||
for (i in 1..TAB_COUNT_SHOW_CFR) {
|
||||
store.dispatch(TabListAction.AddTabAction(createTab("https://mozilla.org")))
|
||||
store.waitUntilIdle()
|
||||
}
|
||||
|
||||
assert(view.visibility == VISIBLE)
|
||||
binding.banner?.dismissAction?.invoke()
|
||||
|
||||
verify(exactly = 0) { interactor.onTabSettingsClicked() }
|
||||
assert(settings.shouldShowGridViewBanner)
|
||||
assert(!settings.shouldShowAutoCloseTabsBanner)
|
||||
verify(exactly = 0) { metrics.track(Event.TabsTrayCfrTapped) }
|
||||
verify(exactly = 1) { metrics.track(Event.TabsTrayCfrDismissed) }
|
||||
}
|
||||
|
||||
@Test
|
||||
fun `WHEN both banners were already shown THEN no info banner should be shown`() {
|
||||
view.visibility = GONE
|
||||
settings.listTabView = true
|
||||
settings.shouldShowGridViewBanner = false
|
||||
settings.shouldShowAutoCloseTabsBanner = false
|
||||
|
||||
val binding =
|
||||
TabsTrayInfoBannerBinding(
|
||||
context = testContext,
|
||||
store = store,
|
||||
infoBannerView = view,
|
||||
settings = settings,
|
||||
navigationInteractor = interactor,
|
||||
metrics = metrics
|
||||
)
|
||||
|
||||
binding.start()
|
||||
for (i in 1..TAB_COUNT_SHOW_CFR) {
|
||||
store.dispatch(TabListAction.AddTabAction(createTab("https://mozilla.org")))
|
||||
store.waitUntilIdle()
|
||||
}
|
||||
|
||||
assert(view.visibility == GONE)
|
||||
}
|
||||
}
|
Loading…
Reference in New Issue