You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
iceraven-browser/app/src/test/java/org/mozilla/fenix/addons/ExtensionsProcessDisabledFo...

155 lines
6.1 KiB
Kotlin

/* 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.addons
import android.view.View
import android.widget.Button
import androidx.appcompat.app.AlertDialog
import mozilla.components.browser.state.action.ExtensionsProcessAction
import mozilla.components.browser.state.store.BrowserStore
import mozilla.components.support.test.argumentCaptor
import mozilla.components.support.test.libstate.ext.waitUntilIdle
import mozilla.components.support.test.robolectric.testContext
import mozilla.components.support.test.rule.MainCoroutineRule
import mozilla.components.support.test.whenever
import org.junit.Assert.assertFalse
import org.junit.Assert.assertTrue
import org.junit.Rule
import org.junit.Test
import org.junit.runner.RunWith
import org.mockito.Mockito.mock
import org.mockito.Mockito.times
import org.mockito.Mockito.verify
import org.mozilla.fenix.R
import org.mozilla.fenix.components.AppStore
import org.mozilla.fenix.components.appstate.AppState
import org.mozilla.fenix.helpers.FenixRobolectricTestRunner
@RunWith(FenixRobolectricTestRunner::class)
class ExtensionsProcessDisabledForegroundControllerTest {
@get:Rule
val coroutinesTestRule = MainCoroutineRule()
private val dispatcher = coroutinesTestRule.testDispatcher
@Test
fun `WHEN showExtensionsProcessDisabledPrompt is true AND positive button clicked then enable extension process spawning`() {
val browserStore = BrowserStore()
val dialog: AlertDialog = mock()
val builder: AlertDialog.Builder = mock()
val controller = ExtensionsProcessDisabledForegroundController(
context = testContext,
appStore = AppStore(AppState(isForeground = true)),
browserStore = browserStore,
builder = builder,
appName = "TestApp",
)
val buttonsContainerCaptor = argumentCaptor<View>()
controller.start()
whenever(builder.show()).thenReturn(dialog)
assertFalse(browserStore.state.showExtensionsProcessDisabledPrompt)
assertFalse(browserStore.state.extensionsProcessDisabled)
// Pretend the process has been disabled and we show the dialog.
browserStore.dispatch(ExtensionsProcessAction.DisabledAction)
browserStore.dispatch(ExtensionsProcessAction.ShowPromptAction(show = true))
dispatcher.scheduler.advanceUntilIdle()
browserStore.waitUntilIdle()
assertTrue(browserStore.state.showExtensionsProcessDisabledPrompt)
assertTrue(browserStore.state.extensionsProcessDisabled)
verify(builder).setView(buttonsContainerCaptor.capture())
verify(builder).show()
buttonsContainerCaptor.value.findViewById<Button>(R.id.positive).performClick()
browserStore.waitUntilIdle()
assertFalse(browserStore.state.showExtensionsProcessDisabledPrompt)
assertFalse(browserStore.state.extensionsProcessDisabled)
verify(dialog).dismiss()
}
@Test
fun `WHEN showExtensionsProcessDisabledPrompt is true AND negative button clicked then dismiss without enabling extension process spawning`() {
val browserStore = BrowserStore()
val dialog: AlertDialog = mock()
val builder: AlertDialog.Builder = mock()
val controller = ExtensionsProcessDisabledForegroundController(
context = testContext,
appStore = AppStore(AppState(isForeground = true)),
browserStore = browserStore,
builder = builder,
appName = "TestApp",
)
val buttonsContainerCaptor = argumentCaptor<View>()
controller.start()
whenever(builder.show()).thenReturn(dialog)
assertFalse(browserStore.state.showExtensionsProcessDisabledPrompt)
assertFalse(browserStore.state.extensionsProcessDisabled)
// Pretend the process has been disabled and we show the dialog.
browserStore.dispatch(ExtensionsProcessAction.DisabledAction)
browserStore.dispatch(ExtensionsProcessAction.ShowPromptAction(show = true))
dispatcher.scheduler.advanceUntilIdle()
browserStore.waitUntilIdle()
assertTrue(browserStore.state.showExtensionsProcessDisabledPrompt)
assertTrue(browserStore.state.extensionsProcessDisabled)
verify(builder).setView(buttonsContainerCaptor.capture())
verify(builder).show()
buttonsContainerCaptor.value.findViewById<Button>(R.id.negative).performClick()
browserStore.waitUntilIdle()
assertFalse(browserStore.state.showExtensionsProcessDisabledPrompt)
assertTrue(browserStore.state.extensionsProcessDisabled)
verify(dialog).dismiss()
}
@Test
fun `WHEN dispatching the same event twice THEN the dialog should only be created once`() {
val browserStore = BrowserStore()
val dialog: AlertDialog = mock()
val builder: AlertDialog.Builder = mock()
val controller = ExtensionsProcessDisabledForegroundController(
context = testContext,
appStore = AppStore(AppState(isForeground = true)),
browserStore = browserStore,
builder = builder,
appName = "TestApp",
)
val buttonsContainerCaptor = argumentCaptor<View>()
controller.start()
whenever(builder.show()).thenReturn(dialog)
// First dispatch...
browserStore.dispatch(ExtensionsProcessAction.ShowPromptAction(show = true))
dispatcher.scheduler.advanceUntilIdle()
browserStore.waitUntilIdle()
// Second dispatch... without having dismissed the dialog before!
browserStore.dispatch(ExtensionsProcessAction.ShowPromptAction(show = true))
dispatcher.scheduler.advanceUntilIdle()
browserStore.waitUntilIdle()
verify(builder).setView(buttonsContainerCaptor.capture())
verify(builder, times(1)).show()
// Click a button to dismiss the dialog.
buttonsContainerCaptor.value.findViewById<Button>(R.id.negative).performClick()
browserStore.waitUntilIdle()
}
}