|
|
@ -5,22 +5,21 @@
|
|
|
|
package org.mozilla.fenix.ext
|
|
|
|
package org.mozilla.fenix.ext
|
|
|
|
|
|
|
|
|
|
|
|
import mozilla.components.concept.storage.BookmarkNode
|
|
|
|
import mozilla.components.concept.storage.BookmarkNode
|
|
|
|
import mozilla.components.concept.storage.BookmarkNodeType
|
|
|
|
|
|
|
|
import org.junit.Assert.assertEquals
|
|
|
|
import org.junit.Assert.assertEquals
|
|
|
|
import org.junit.Test
|
|
|
|
import org.junit.Test
|
|
|
|
|
|
|
|
import org.mozilla.fenix.library.bookmarks.testBookmarkItem
|
|
|
|
|
|
|
|
import org.mozilla.fenix.library.bookmarks.testFolder
|
|
|
|
|
|
|
|
|
|
|
|
class BookmarkNodeTest {
|
|
|
|
class BookmarkNodeTest {
|
|
|
|
|
|
|
|
|
|
|
|
private val bookmarkChild1 = newBookmarkNode("Child 1", 1, null)
|
|
|
|
private val bookmarkChild1 = testBookmarkItem("someFolder", "http://www.mockurl.com/1", "Child 1")
|
|
|
|
private val bookmarkChild2 = newBookmarkNode("Child 2", 2, null)
|
|
|
|
private val bookmarkChild2 = testBookmarkItem("someFolder", "http://www.mockurl.com/2", "Child 2")
|
|
|
|
private val bookmarkChild3 = newBookmarkNode("Child 3", 3, null)
|
|
|
|
private val bookmarkChild3 = testBookmarkItem("someFolder", "http://www.mockurl.com/3", "Child 3")
|
|
|
|
private val allChildren = listOf(bookmarkChild1, bookmarkChild2)
|
|
|
|
private val allChildren = listOf(bookmarkChild1, bookmarkChild2)
|
|
|
|
|
|
|
|
|
|
|
|
private var uniqueId = 0
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@Test
|
|
|
|
@Test
|
|
|
|
fun `GIVEN a bookmark node with children WHEN minusing a sub set of children THEN the children subset is removed and rest remains`() {
|
|
|
|
fun `GIVEN a bookmark node with children WHEN minusing a sub set of children THEN the children subset is removed and rest remains`() {
|
|
|
|
val bookmarkNode = newBookmarkNode("Parent 1", 0, allChildren)
|
|
|
|
val bookmarkNode = testFolder("parent1", "root", allChildren)
|
|
|
|
val subsetToSubtract = setOf(bookmarkChild1)
|
|
|
|
val subsetToSubtract = setOf(bookmarkChild1)
|
|
|
|
val expectedRemainingSubset = listOf(bookmarkChild2)
|
|
|
|
val expectedRemainingSubset = listOf(bookmarkChild2)
|
|
|
|
val bookmarkNodeSubsetRemoved = bookmarkNode.minus(subsetToSubtract)
|
|
|
|
val bookmarkNodeSubsetRemoved = bookmarkNode.minus(subsetToSubtract)
|
|
|
@ -29,7 +28,7 @@ class BookmarkNodeTest {
|
|
|
|
|
|
|
|
|
|
|
|
@Test
|
|
|
|
@Test
|
|
|
|
fun `GIVEN a bookmark node with children WHEN minusing a set of all children THEN all children are removed and empty list remains`() {
|
|
|
|
fun `GIVEN a bookmark node with children WHEN minusing a set of all children THEN all children are removed and empty list remains`() {
|
|
|
|
val bookmarkNode = newBookmarkNode("Parent 1", 0, allChildren)
|
|
|
|
val bookmarkNode = testFolder("parent1", "root", allChildren)
|
|
|
|
val setofAllChildren = setOf(bookmarkChild1, bookmarkChild2)
|
|
|
|
val setofAllChildren = setOf(bookmarkChild1, bookmarkChild2)
|
|
|
|
val bookmarkNodeAllChildrenRemoved = bookmarkNode.minus(setofAllChildren)
|
|
|
|
val bookmarkNodeAllChildrenRemoved = bookmarkNode.minus(setofAllChildren)
|
|
|
|
assertEquals(emptyList<BookmarkNode>(), bookmarkNodeAllChildrenRemoved.children)
|
|
|
|
assertEquals(emptyList<BookmarkNode>(), bookmarkNodeAllChildrenRemoved.children)
|
|
|
@ -38,21 +37,21 @@ class BookmarkNodeTest {
|
|
|
|
@Test
|
|
|
|
@Test
|
|
|
|
fun `GIVEN a bookmark node with children WHEN minusing a set of non-children THEN no children are removed`() {
|
|
|
|
fun `GIVEN a bookmark node with children WHEN minusing a set of non-children THEN no children are removed`() {
|
|
|
|
val setofNonChildren = setOf(bookmarkChild3)
|
|
|
|
val setofNonChildren = setOf(bookmarkChild3)
|
|
|
|
val bookmarkNode = newBookmarkNode("Parent 1", 0, allChildren)
|
|
|
|
val bookmarkNode = testFolder("parent1", "root", allChildren)
|
|
|
|
val bookmarkNodeNonChildrenRemoved = bookmarkNode.minus(setofNonChildren)
|
|
|
|
val bookmarkNodeNonChildrenRemoved = bookmarkNode.minus(setofNonChildren)
|
|
|
|
assertEquals(allChildren, bookmarkNodeNonChildrenRemoved.children)
|
|
|
|
assertEquals(allChildren, bookmarkNodeNonChildrenRemoved.children)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
@Test
|
|
|
|
@Test
|
|
|
|
fun `GIVEN a bookmark node with children WHEN minusing an empty set THEN no children are removed`() {
|
|
|
|
fun `GIVEN a bookmark node with children WHEN minusing an empty set THEN no children are removed`() {
|
|
|
|
val bookmarkNode = newBookmarkNode("Parent 1", 0, allChildren)
|
|
|
|
val bookmarkNode = testFolder("parent1", "root", allChildren)
|
|
|
|
val bookmarkNodeEmptySetRemoved = bookmarkNode.minus(emptySet())
|
|
|
|
val bookmarkNodeEmptySetRemoved = bookmarkNode.minus(emptySet())
|
|
|
|
assertEquals(allChildren, bookmarkNodeEmptySetRemoved.children)
|
|
|
|
assertEquals(allChildren, bookmarkNodeEmptySetRemoved.children)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
@Test
|
|
|
|
@Test
|
|
|
|
fun `GIVEN a bookmark node with an empty list as children WHEN minusing a set of non-children from an empty parent THEN an empty list remains`() {
|
|
|
|
fun `GIVEN a bookmark node with an empty list as children WHEN minusing a set of non-children from an empty parent THEN an empty list remains`() {
|
|
|
|
val parentWithEmptyList = newBookmarkNode("Parent 1", 0, emptyList<BookmarkNode>())
|
|
|
|
val parentWithEmptyList = testFolder("parent1", "root", emptyList())
|
|
|
|
val setofAllChildren = setOf(bookmarkChild1, bookmarkChild2)
|
|
|
|
val setofAllChildren = setOf(bookmarkChild1, bookmarkChild2)
|
|
|
|
val parentWithEmptyListNonChildRemoved = parentWithEmptyList.minus(setofAllChildren)
|
|
|
|
val parentWithEmptyListNonChildRemoved = parentWithEmptyList.minus(setofAllChildren)
|
|
|
|
assertEquals(emptyList<BookmarkNode>(), parentWithEmptyListNonChildRemoved.children)
|
|
|
|
assertEquals(emptyList<BookmarkNode>(), parentWithEmptyListNonChildRemoved.children)
|
|
|
@ -60,14 +59,14 @@ class BookmarkNodeTest {
|
|
|
|
|
|
|
|
|
|
|
|
@Test
|
|
|
|
@Test
|
|
|
|
fun `GIVEN a bookmark node with null as children WHEN minusing a set of non-children from a parent with null children THEN null remains`() {
|
|
|
|
fun `GIVEN a bookmark node with null as children WHEN minusing a set of non-children from a parent with null children THEN null remains`() {
|
|
|
|
val parentWithNullList = newBookmarkNode("Parent 1", 0, null)
|
|
|
|
val parentWithNullList = testFolder("parent1", "root", null)
|
|
|
|
val parentWithNullListNonChildRemoved = parentWithNullList.minus(allChildren.toSet())
|
|
|
|
val parentWithNullListNonChildRemoved = parentWithNullList.minus(allChildren.toSet())
|
|
|
|
assertEquals(null, parentWithNullListNonChildRemoved.children)
|
|
|
|
assertEquals(null, parentWithNullListNonChildRemoved.children)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
@Test
|
|
|
|
@Test
|
|
|
|
fun `GIVEN a bookmark node with children WHEN minusing a sub-set of children THEN the rest of the parents object should remain the same`() {
|
|
|
|
fun `GIVEN a bookmark node with children WHEN minusing a sub-set of children THEN the rest of the parents object should remain the same`() {
|
|
|
|
val bookmarkNode = newBookmarkNode("Parent 1", 0, allChildren)
|
|
|
|
val bookmarkNode = testFolder("parent1", "root", allChildren)
|
|
|
|
val subsetToSubtract = setOf(bookmarkChild1)
|
|
|
|
val subsetToSubtract = setOf(bookmarkChild1)
|
|
|
|
val expectedRemainingSubset = listOf(bookmarkChild2)
|
|
|
|
val expectedRemainingSubset = listOf(bookmarkChild2)
|
|
|
|
val resultBookmarkNode = bookmarkNode.minus(subsetToSubtract)
|
|
|
|
val resultBookmarkNode = bookmarkNode.minus(subsetToSubtract)
|
|
|
@ -77,14 +76,4 @@ class BookmarkNodeTest {
|
|
|
|
val restofOriginal = bookmarkNode.copy(children = expectedRemainingSubset)
|
|
|
|
val restofOriginal = bookmarkNode.copy(children = expectedRemainingSubset)
|
|
|
|
assertEquals(restOfResult, restofOriginal)
|
|
|
|
assertEquals(restOfResult, restofOriginal)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
private fun newBookmarkNode(title: String, position: Int, children: List<BookmarkNode>?) = BookmarkNode(
|
|
|
|
|
|
|
|
type = BookmarkNodeType.ITEM,
|
|
|
|
|
|
|
|
guid = uniqueId++.toString(),
|
|
|
|
|
|
|
|
parentGuid = "12",
|
|
|
|
|
|
|
|
position = position,
|
|
|
|
|
|
|
|
title = title,
|
|
|
|
|
|
|
|
url = "www.mockurl.com",
|
|
|
|
|
|
|
|
children = children
|
|
|
|
|
|
|
|
)
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|