parent
5d13c53706
commit
091778a4b9
|
@ -0,0 +1,58 @@
|
||||||
|
/*
|
||||||
|
* 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.library.history
|
||||||
|
|
||||||
|
interface HistoryController {
|
||||||
|
fun handleOpen(item: HistoryItem)
|
||||||
|
fun handleSelect(item: HistoryItem)
|
||||||
|
fun handleDeselect(item: HistoryItem)
|
||||||
|
fun handleBackPressed(): Boolean
|
||||||
|
fun handleModeSwitched()
|
||||||
|
fun handleDeleteAll()
|
||||||
|
fun handleDeleteSome(items: Set<HistoryItem>)
|
||||||
|
}
|
||||||
|
|
||||||
|
class DefaultHistoryController(
|
||||||
|
private val store: HistoryStore,
|
||||||
|
private val openToBrowser: (item: HistoryItem) -> Unit,
|
||||||
|
private val displayDeleteAll: () -> Unit,
|
||||||
|
private val invalidateOptionsMenu: () -> Unit,
|
||||||
|
private val deleteHistoryItems: (Set<HistoryItem>) -> Unit
|
||||||
|
) : HistoryController {
|
||||||
|
override fun handleOpen(item: HistoryItem) {
|
||||||
|
openToBrowser(item)
|
||||||
|
}
|
||||||
|
|
||||||
|
override fun handleSelect(item: HistoryItem) {
|
||||||
|
store.dispatch(HistoryAction.AddItemForRemoval(item))
|
||||||
|
}
|
||||||
|
|
||||||
|
override fun handleDeselect(item: HistoryItem) {
|
||||||
|
store.dispatch(HistoryAction.RemoveItemForRemoval(item))
|
||||||
|
}
|
||||||
|
|
||||||
|
override fun handleBackPressed(): Boolean {
|
||||||
|
return if (store.state.mode is HistoryState.Mode.Editing) {
|
||||||
|
store.dispatch(HistoryAction.ExitEditMode)
|
||||||
|
true
|
||||||
|
} else {
|
||||||
|
false
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
override fun handleModeSwitched() {
|
||||||
|
invalidateOptionsMenu.invoke()
|
||||||
|
}
|
||||||
|
|
||||||
|
override fun handleDeleteAll() {
|
||||||
|
displayDeleteAll.invoke()
|
||||||
|
}
|
||||||
|
|
||||||
|
override fun handleDeleteSome(items: Set<HistoryItem>) {
|
||||||
|
deleteHistoryItems.invoke(items)
|
||||||
|
}
|
||||||
|
}
|
|
@ -60,13 +60,16 @@ class HistoryFragment : LibraryPageFragment<HistoryItem>(), BackHandler {
|
||||||
)
|
)
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
historyInteractor = HistoryInteractor(
|
val historyController: HistoryController = DefaultHistoryController(
|
||||||
historyStore,
|
historyStore,
|
||||||
::openItem,
|
::openItem,
|
||||||
::displayDeleteAllDialog,
|
::displayDeleteAllDialog,
|
||||||
::invalidateOptionsMenu,
|
::invalidateOptionsMenu,
|
||||||
::deleteHistoryItems
|
::deleteHistoryItems
|
||||||
)
|
)
|
||||||
|
historyInteractor = HistoryInteractor(
|
||||||
|
historyController
|
||||||
|
)
|
||||||
historyView = HistoryView(view.historyLayout, historyInteractor)
|
historyView = HistoryView(view.historyLayout, historyInteractor)
|
||||||
|
|
||||||
return view
|
return view
|
||||||
|
|
|
@ -9,42 +9,33 @@ package org.mozilla.fenix.library.history
|
||||||
* Provides implementations for the HistoryViewInteractor
|
* Provides implementations for the HistoryViewInteractor
|
||||||
*/
|
*/
|
||||||
class HistoryInteractor(
|
class HistoryInteractor(
|
||||||
private val store: HistoryStore,
|
private val historyController: HistoryController
|
||||||
private val openToBrowser: (item: HistoryItem) -> Unit,
|
|
||||||
private val displayDeleteAll: () -> Unit,
|
|
||||||
private val invalidateOptionsMenu: () -> Unit,
|
|
||||||
private val deleteHistoryItems: (Set<HistoryItem>) -> Unit
|
|
||||||
) : HistoryViewInteractor {
|
) : HistoryViewInteractor {
|
||||||
override fun open(item: HistoryItem) {
|
override fun open(item: HistoryItem) {
|
||||||
openToBrowser(item)
|
historyController.handleOpen(item)
|
||||||
}
|
}
|
||||||
|
|
||||||
override fun select(item: HistoryItem) {
|
override fun select(item: HistoryItem) {
|
||||||
store.dispatch(HistoryAction.AddItemForRemoval(item))
|
historyController.handleSelect(item)
|
||||||
}
|
}
|
||||||
|
|
||||||
override fun deselect(item: HistoryItem) {
|
override fun deselect(item: HistoryItem) {
|
||||||
store.dispatch(HistoryAction.RemoveItemForRemoval(item))
|
historyController.handleDeselect(item)
|
||||||
}
|
}
|
||||||
|
|
||||||
override fun onBackPressed(): Boolean {
|
override fun onBackPressed(): Boolean {
|
||||||
return if (store.state.mode is HistoryState.Mode.Editing) {
|
return historyController.handleBackPressed()
|
||||||
store.dispatch(HistoryAction.ExitEditMode)
|
|
||||||
true
|
|
||||||
} else {
|
|
||||||
false
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
override fun onModeSwitched() {
|
override fun onModeSwitched() {
|
||||||
invalidateOptionsMenu.invoke()
|
historyController.handleModeSwitched()
|
||||||
}
|
}
|
||||||
|
|
||||||
override fun onDeleteAll() {
|
override fun onDeleteAll() {
|
||||||
displayDeleteAll.invoke()
|
historyController.handleDeleteAll()
|
||||||
}
|
}
|
||||||
|
|
||||||
override fun onDeleteSome(items: Set<HistoryItem>) {
|
override fun onDeleteSome(items: Set<HistoryItem>) {
|
||||||
deleteHistoryItems.invoke(items)
|
historyController.handleDeleteSome(items)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -10,20 +10,27 @@ import io.mockk.verify
|
||||||
import org.junit.Assert.assertEquals
|
import org.junit.Assert.assertEquals
|
||||||
import org.junit.Assert.assertFalse
|
import org.junit.Assert.assertFalse
|
||||||
import org.junit.Assert.assertTrue
|
import org.junit.Assert.assertTrue
|
||||||
|
import org.junit.Before
|
||||||
import org.junit.Test
|
import org.junit.Test
|
||||||
|
|
||||||
class HistoryInteractorTest {
|
class HistoryControllerTest {
|
||||||
|
|
||||||
|
private val historyItem = HistoryItem(0, "title", "url", 0.toLong())
|
||||||
|
private val store: HistoryStore = mockk(relaxed = true)
|
||||||
|
private val state: HistoryState = mockk(relaxed = true)
|
||||||
|
|
||||||
|
@Before
|
||||||
|
fun setUp() {
|
||||||
|
every { store.state } returns state
|
||||||
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
fun onPressHistoryItemInNormalMode() {
|
fun onPressHistoryItemInNormalMode() {
|
||||||
var historyItemReceived: HistoryItem? = null
|
var historyItemReceived: HistoryItem? = null
|
||||||
val historyItem = HistoryItem(0, "title", "url", 0.toLong())
|
|
||||||
val store: HistoryStore = mockk()
|
|
||||||
val state: HistoryState = mockk()
|
|
||||||
every { store.state } returns state
|
|
||||||
every { state.mode } returns HistoryState.Mode.Normal
|
every { state.mode } returns HistoryState.Mode.Normal
|
||||||
|
|
||||||
val interactor = HistoryInteractor(
|
val controller = DefaultHistoryController(
|
||||||
store,
|
store,
|
||||||
{ historyItemReceived = it },
|
{ historyItemReceived = it },
|
||||||
mockk(),
|
mockk(),
|
||||||
|
@ -31,19 +38,15 @@ class HistoryInteractorTest {
|
||||||
mockk()
|
mockk()
|
||||||
)
|
)
|
||||||
|
|
||||||
interactor.open(historyItem)
|
controller.handleOpen(historyItem)
|
||||||
assertEquals(historyItem, historyItemReceived)
|
assertEquals(historyItem, historyItemReceived)
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
fun onPressHistoryItemInEditMode() {
|
fun onPressHistoryItemInEditMode() {
|
||||||
val historyItem = HistoryItem(0, "title", "url", 0.toLong())
|
|
||||||
val store: HistoryStore = mockk(relaxed = true)
|
|
||||||
val state: HistoryState = mockk()
|
|
||||||
every { store.state } returns state
|
|
||||||
every { state.mode } returns HistoryState.Mode.Editing(setOf())
|
every { state.mode } returns HistoryState.Mode.Editing(setOf())
|
||||||
|
|
||||||
val interactor = HistoryInteractor(
|
val controller = DefaultHistoryController(
|
||||||
store,
|
store,
|
||||||
{ },
|
{ },
|
||||||
mockk(),
|
mockk(),
|
||||||
|
@ -51,7 +54,7 @@ class HistoryInteractorTest {
|
||||||
mockk()
|
mockk()
|
||||||
)
|
)
|
||||||
|
|
||||||
interactor.select(historyItem)
|
controller.handleSelect(historyItem)
|
||||||
|
|
||||||
verify {
|
verify {
|
||||||
store.dispatch(HistoryAction.AddItemForRemoval(historyItem))
|
store.dispatch(HistoryAction.AddItemForRemoval(historyItem))
|
||||||
|
@ -60,13 +63,9 @@ class HistoryInteractorTest {
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
fun onPressSelectedHistoryItemInEditMode() {
|
fun onPressSelectedHistoryItemInEditMode() {
|
||||||
val historyItem = HistoryItem(0, "title", "url", 0.toLong())
|
|
||||||
val store: HistoryStore = mockk(relaxed = true)
|
|
||||||
val state: HistoryState = mockk()
|
|
||||||
every { store.state } returns state
|
|
||||||
every { state.mode } returns HistoryState.Mode.Editing(setOf(historyItem))
|
every { state.mode } returns HistoryState.Mode.Editing(setOf(historyItem))
|
||||||
|
|
||||||
val interactor = HistoryInteractor(
|
val controller = DefaultHistoryController(
|
||||||
store,
|
store,
|
||||||
{ },
|
{ },
|
||||||
mockk(),
|
mockk(),
|
||||||
|
@ -74,7 +73,7 @@ class HistoryInteractorTest {
|
||||||
mockk()
|
mockk()
|
||||||
)
|
)
|
||||||
|
|
||||||
interactor.deselect(historyItem)
|
controller.handleDeselect(historyItem)
|
||||||
|
|
||||||
verify {
|
verify {
|
||||||
store.dispatch(HistoryAction.RemoveItemForRemoval(historyItem))
|
store.dispatch(HistoryAction.RemoveItemForRemoval(historyItem))
|
||||||
|
@ -83,24 +82,18 @@ class HistoryInteractorTest {
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
fun onBackPressedInNormalMode() {
|
fun onBackPressedInNormalMode() {
|
||||||
val store: HistoryStore = mockk(relaxed = true)
|
|
||||||
val state: HistoryState = mockk()
|
|
||||||
every { store.state } returns state
|
|
||||||
every { state.mode } returns HistoryState.Mode.Normal
|
every { state.mode } returns HistoryState.Mode.Normal
|
||||||
|
|
||||||
val interactor = HistoryInteractor(store, mockk(), mockk(), mockk(), mockk())
|
val controller = DefaultHistoryController(store, mockk(), mockk(), mockk(), mockk())
|
||||||
assertFalse(interactor.onBackPressed())
|
assertFalse(controller.handleBackPressed())
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
fun onBackPressedInEditMode() {
|
fun onBackPressedInEditMode() {
|
||||||
val store: HistoryStore = mockk(relaxed = true)
|
|
||||||
val state: HistoryState = mockk()
|
|
||||||
every { store.state } returns state
|
|
||||||
every { state.mode } returns HistoryState.Mode.Editing(setOf())
|
every { state.mode } returns HistoryState.Mode.Editing(setOf())
|
||||||
|
|
||||||
val interactor = HistoryInteractor(store, mockk(), mockk(), mockk(), mockk())
|
val controller = DefaultHistoryController(store, mockk(), mockk(), mockk(), mockk())
|
||||||
assertTrue(interactor.onBackPressed())
|
assertTrue(controller.handleBackPressed())
|
||||||
|
|
||||||
verify {
|
verify {
|
||||||
store.dispatch(HistoryAction.ExitEditMode)
|
store.dispatch(HistoryAction.ExitEditMode)
|
||||||
|
@ -110,28 +103,28 @@ class HistoryInteractorTest {
|
||||||
@Test
|
@Test
|
||||||
fun onModeSwitched() {
|
fun onModeSwitched() {
|
||||||
var menuInvalidated = false
|
var menuInvalidated = false
|
||||||
val interactor = HistoryInteractor(
|
val controller = DefaultHistoryController(
|
||||||
mockk(),
|
mockk(),
|
||||||
mockk(),
|
mockk(),
|
||||||
mockk(),
|
mockk(),
|
||||||
{ menuInvalidated = true },
|
{ menuInvalidated = true },
|
||||||
mockk()
|
mockk()
|
||||||
)
|
)
|
||||||
interactor.onModeSwitched()
|
controller.handleModeSwitched()
|
||||||
assertEquals(true, menuInvalidated)
|
assertEquals(true, menuInvalidated)
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
fun onDeleteAll() {
|
fun onDeleteAll() {
|
||||||
var deleteAllDialogShown = false
|
var deleteAllDialogShown = false
|
||||||
val interactor = HistoryInteractor(
|
val controller = DefaultHistoryController(
|
||||||
mockk(),
|
mockk(),
|
||||||
mockk(),
|
mockk(),
|
||||||
{ deleteAllDialogShown = true },
|
{ deleteAllDialogShown = true },
|
||||||
mockk(),
|
mockk(),
|
||||||
mockk()
|
mockk()
|
||||||
)
|
)
|
||||||
interactor.onDeleteAll()
|
controller.handleDeleteAll()
|
||||||
assertEquals(true, deleteAllDialogShown)
|
assertEquals(true, deleteAllDialogShown)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -140,15 +133,14 @@ class HistoryInteractorTest {
|
||||||
var itemsToDelete: Set<HistoryItem>? = null
|
var itemsToDelete: Set<HistoryItem>? = null
|
||||||
val historyItem = HistoryItem(0, "title", "url", 0.toLong())
|
val historyItem = HistoryItem(0, "title", "url", 0.toLong())
|
||||||
val newHistoryItem = HistoryItem(1, "title", "url", 0.toLong())
|
val newHistoryItem = HistoryItem(1, "title", "url", 0.toLong())
|
||||||
val interactor =
|
val controller = DefaultHistoryController(
|
||||||
HistoryInteractor(
|
|
||||||
mockk(),
|
mockk(),
|
||||||
mockk(),
|
mockk(),
|
||||||
mockk(),
|
mockk(),
|
||||||
mockk(),
|
mockk(),
|
||||||
{ itemsToDelete = it }
|
{ itemsToDelete = it }
|
||||||
)
|
)
|
||||||
interactor.onDeleteSome(setOf(historyItem, newHistoryItem))
|
controller.handleDeleteSome(setOf(historyItem, newHistoryItem))
|
||||||
assertEquals(itemsToDelete, setOf(historyItem, newHistoryItem))
|
assertEquals(itemsToDelete, setOf(historyItem, newHistoryItem))
|
||||||
}
|
}
|
||||||
}
|
}
|
Loading…
Reference in New Issue