diff --git a/app/src/main/java/org/mozilla/fenix/exceptions/trackingprotection/ExceptionsFragmentStore.kt b/app/src/main/java/org/mozilla/fenix/exceptions/trackingprotection/ExceptionsFragmentStore.kt index 6fa287e6d190..6b8d7c14d804 100644 --- a/app/src/main/java/org/mozilla/fenix/exceptions/trackingprotection/ExceptionsFragmentStore.kt +++ b/app/src/main/java/org/mozilla/fenix/exceptions/trackingprotection/ExceptionsFragmentStore.kt @@ -6,14 +6,21 @@ package org.mozilla.fenix.exceptions.trackingprotection import mozilla.components.concept.engine.content.blocking.TrackingProtectionException import mozilla.components.lib.state.Action +import mozilla.components.lib.state.Middleware import mozilla.components.lib.state.State import mozilla.components.lib.state.Store /** * The [Store] for holding the [ExceptionsFragmentState] and applying [ExceptionsFragmentAction]s. */ -class ExceptionsFragmentStore(initialState: ExceptionsFragmentState) : - Store(initialState, ::exceptionsStateReducer) +class ExceptionsFragmentStore( + initialState: ExceptionsFragmentState = ExceptionsFragmentState(), + middlewares: List> = emptyList() +) : Store( + initialState, + ::exceptionsStateReducer, + middlewares +) /** * Actions to dispatch through the `ExceptionsStore` to modify `ExceptionsState` through the reducer. diff --git a/app/src/test/java/org/mozilla/fenix/exceptions/trackingprotection/TrackingProtectionExceptionsInteractorTest.kt b/app/src/test/java/org/mozilla/fenix/exceptions/trackingprotection/TrackingProtectionExceptionsInteractorTest.kt index a4a774728741..7e1a69b5c74d 100644 --- a/app/src/test/java/org/mozilla/fenix/exceptions/trackingprotection/TrackingProtectionExceptionsInteractorTest.kt +++ b/app/src/test/java/org/mozilla/fenix/exceptions/trackingprotection/TrackingProtectionExceptionsInteractorTest.kt @@ -10,10 +10,15 @@ import io.mockk.impl.annotations.MockK import io.mockk.mockk import io.mockk.verify import io.mockk.verifySequence +import mozilla.components.browser.state.store.BrowserStore +import mozilla.components.concept.engine.Engine import mozilla.components.concept.engine.content.blocking.TrackingProtectionException +import mozilla.components.concept.engine.content.blocking.TrackingProtectionExceptionStorage import mozilla.components.feature.session.TrackingProtectionUseCases +import mozilla.components.support.test.libstate.ext.waitUntilIdle +import mozilla.components.support.test.middleware.CaptureActionsMiddleware +import org.junit.Assert.assertEquals import org.junit.Before -import org.junit.Ignore import org.junit.Test import org.mozilla.fenix.BrowserDirection import org.mozilla.fenix.HomeActivity @@ -22,10 +27,15 @@ import org.mozilla.fenix.settings.SupportUtils class TrackingProtectionExceptionsInteractorTest { @MockK(relaxed = true) private lateinit var activity: HomeActivity - @MockK(relaxed = true) private lateinit var exceptionsStore: ExceptionsFragmentStore - @MockK(relaxed = true) private lateinit var trackingProtectionUseCases: TrackingProtectionUseCases private lateinit var interactor: TrackingProtectionExceptionsInteractor - private lateinit var results: List + + private val results: List = emptyList() + private val engine: Engine = mockk(relaxed = true) + private val store = BrowserStore() + private val capture = CaptureActionsMiddleware() + private val exceptionsStore = ExceptionsFragmentStore(middlewares = listOf(capture)) + private val trackingProtectionUseCases = TrackingProtectionUseCases(store, engine) + private val trackingStorage: TrackingProtectionExceptionStorage = mockk(relaxed = true) @Before fun setup() { @@ -36,8 +46,8 @@ class TrackingProtectionExceptionsInteractorTest { trackingProtectionUseCases = trackingProtectionUseCases ) - results = emptyList() - every { trackingProtectionUseCases.fetchExceptions(any()) } answers { + every { engine.trackingProtectionExceptionStore } returns trackingStorage + every { trackingStorage.fetchAll(any()) } answers { firstArg<(List) -> Unit>()(results) } } @@ -57,27 +67,36 @@ class TrackingProtectionExceptionsInteractorTest { ) } } - @Ignore("See https://github.com/mozilla-mobile/fenix/issues/20796") @Test fun onDeleteAll() { interactor.onDeleteAll() + verifySequence { - trackingProtectionUseCases.removeAllExceptions() - trackingProtectionUseCases.fetchExceptions(any()) + trackingStorage.removeAll(any()) + trackingStorage.fetchAll(any()) } - verify { exceptionsStore.dispatch(ExceptionsFragmentAction.Change(results)) } + exceptionsStore.waitUntilIdle() + + capture.assertLastAction(ExceptionsFragmentAction.Change::class) { + assertEquals(results, it.list) + } } @Test fun onDeleteOne() { val exceptionsItem = mockk() interactor.onDeleteOne(exceptionsItem) + verifySequence { - trackingProtectionUseCases.removeException(exceptionsItem) - trackingProtectionUseCases.fetchExceptions(any()) + trackingStorage.remove(exceptionsItem) + trackingStorage.fetchAll(any()) } - verify { exceptionsStore.dispatch(ExceptionsFragmentAction.Change(results)) } + exceptionsStore.waitUntilIdle() + + capture.assertLastAction(ExceptionsFragmentAction.Change::class) { + assertEquals(results, it.list) + } } }