Beispiel #1
0
    def test_GetAddedNodes(self):
        tree = KeyedTree()
        tree.add_pair("parent", "child")
        self.assertEqual(tree.get_node("parent"), KeyedNode("parent"))
        self.assertEqual(tree.get_node("child"), KeyedNode("child"))

        self.assertEqual(
            tree.get_node("child").get_parent(), tree.get_node("parent"))
Beispiel #2
0
 def test_ParentIsAlreadyKnown(self):
     tree = KeyedTree()
     tree.add_pair("parent", "child")
     tree.add_pair("parent", "brother")
     self.assertEqual(tree.get_node("parent"), KeyedNode("parent"))
     self.assertEqual(tree.get_node("child"), KeyedNode("child"))
     self.assertEqual(tree.get_node("brother"), KeyedNode("brother"))
     self.assertListEqual(
         tree.get_node("parent").get_child_nodes(),
         [KeyedNode("child"), KeyedNode("brother")])
Beispiel #3
0
 def test_ChildIsAlreadyKnown(self):
     tree = KeyedTree()
     tree.add_pair("parent", "child")
     tree.add_pair("grandparent", "parent")
     self.assertEqual(tree.get_node("parent"), KeyedNode("parent"))
     self.assertEqual(tree.get_node("grandparent"),
                      KeyedNode("grandparent"))
     self.assertEqual(tree.get_node("child"), KeyedNode("child"))
     self.assertListEqual(
         tree.get_node("parent").get_child_nodes(), [KeyedNode("child")])
     self.assertEqual(
         tree.get_node("parent").get_parent(), tree.get_node("grandparent"))
Beispiel #4
0
    def test_Parent_NoDoubleSet(self):
        parent = KeyedNode("parent")
        child = KeyedNode("child")
        child.set_parent(parent)

        imposter = KeyedNode("imposter")
        self.assertRaises(MultipleParentsNotSupported,
                          lambda: child.set_parent(imposter))

        self.assertEqual(child.get_parent(), parent)
Beispiel #5
0
    def test_KeyList_Repeats(self):
        tree = KeyedTree()
        tree.add_pair("parent", "child")
        tree.add_pair("parent", "brother")
        tree.add_pair("parent", "sister")
        tree.add_pair("grandparent", "parent")

        expected = [
            KeyedNode(n)
            for n in ["parent", "child", "brother", "sister", "grandparent"]
        ]
        nodes = []
        tree.for_each_node(lambda n: nodes.append(n))
        self.assertListEqual(nodes, expected)
Beispiel #6
0
 def test_GetPath_Cousin(self):
     tree = KeyedTree()
     tree.add_pair("grandparent", "uncle")
     tree.add_pair("grandparent", "parent")
     tree.add_pair("uncle", "cousin")
     tree.add_pair("parent", "child")
     self.assertListEqual(tree.get_path("cousin", "child"), [
         KeyedNode("uncle"),
         KeyedNode("grandparent"),
         KeyedNode("parent")
     ])
     self.assertListEqual(tree.get_path("child", "cousin"), [
         KeyedNode("parent"),
         KeyedNode("grandparent"),
         KeyedNode("uncle")
     ])
Beispiel #7
0
    def test_Children_SingleChild(self):
        grandParent = KeyedNode("grand pa")
        parent = KeyedNode("pa")
        child = KeyedNode("me")
        child.set_parent(parent)
        parent.set_parent(grandParent)

        self.assertListEqual(child.get_child_nodes(), [])
        self.assertListEqual(parent.get_child_nodes(), [child])
        self.assertListEqual(grandParent.get_child_nodes(), [parent])
Beispiel #8
0
 def test_Children_DefaultEmpty(self):
     child = KeyedNode("me")
     self.assertListEqual(child.get_child_nodes(), [])
Beispiel #9
0
    def test_Parent_NoSetSelf(self):
        child = KeyedNode("child")

        self.assertRaises(TreeHasLoop, lambda: child.set_parent(child))
Beispiel #10
0
    def test_LT(self):
        self.assertLess(KeyedNode("A"), KeyedNode("B"))
        self.assertLess(KeyedNode("ABBA"), KeyedNode("BAN"))
        self.assertLess(KeyedNode("ABBA"), KeyedNode("ABBC"))

        self.assertFalse(KeyedNode("ABBC") < KeyedNode("ABBA"))
Beispiel #11
0
    def test_RootNode_NoLoops(self):
        grandParent = KeyedNode("grand pa")
        parent = KeyedNode("pa")
        child = KeyedNode("me")
        child.set_parent(parent)
        parent.set_parent(grandParent)

        self.assertEqual(child.get_root_node(), grandParent)
        self.assertEqual(parent.get_root_node(), grandParent)
        self.assertEqual(grandParent.get_root_node(), grandParent)
Beispiel #12
0
 def test_Parent_DefaultNone(self):
     child = KeyedNode("child")
     self.assertIsNone(child.get_parent())
Beispiel #13
0
 def test_Str(self):
     self.assertEqual(str(KeyedNode("APPLE")), "<KeyedNode: APPLE>")
Beispiel #14
0
    def test_Traverse_MultipleChildren(self):
        calledBack = {}

        def callback(depth, node):
            if depth not in calledBack:
                calledBack[depth] = []
            calledBack[depth].append(node)

        grandParent = KeyedNode("grand pa")

        parent = KeyedNode("pa")
        aunt = KeyedNode("aunt")
        uncle = KeyedNode("uncle")

        me = KeyedNode("me")
        brother = KeyedNode("bro")
        sister = KeyedNode("si")

        cousin_aunt = KeyedNode("cousin (aunt)")
        cousin_aunt.set_parent(aunt)
        cousin_uncle = KeyedNode("cousin (uncle)")
        cousin_uncle.set_parent(uncle)

        me.set_parent(parent)
        brother.set_parent(parent)
        sister.set_parent(parent)

        parent.set_parent(grandParent)
        aunt.set_parent(grandParent)
        uncle.set_parent(grandParent)
        expected = {
            1: [parent, aunt, uncle],
            2: [me, brother, sister, cousin_aunt, cousin_uncle]
        }

        grandParent.traverse(callback)
        self.assertDictEqual(calledBack, expected)
Beispiel #15
0
    def test_Depth_NoLoops(self):
        grandParent = KeyedNode("grand pa")
        parent = KeyedNode("pa")
        child = KeyedNode("me")
        child.set_parent(parent)
        parent.set_parent(grandParent)

        self.assertEqual(child.get_depth(), 2)
        self.assertEqual(parent.get_depth(), 1)
        self.assertEqual(grandParent.get_depth(), 0)
Beispiel #16
0
    def test_Children_MultipleChildren(self):
        grandParent = KeyedNode("grand pa")

        parent = KeyedNode("pa")
        aunt = KeyedNode("aunt")
        uncle = KeyedNode("uncle")

        me = KeyedNode("me")
        brother = KeyedNode("bro")
        sister = KeyedNode("si")

        me.set_parent(parent)
        brother.set_parent(parent)
        sister.set_parent(parent)

        parent.set_parent(grandParent)
        aunt.set_parent(grandParent)
        uncle.set_parent(grandParent)

        self.assertListEqual(me.get_child_nodes(), [])
        self.assertListEqual(parent.get_child_nodes(), [me, brother, sister])
        self.assertListEqual(grandParent.get_child_nodes(),
                             [parent, aunt, uncle])
Beispiel #17
0
 def test_EQ(self):
     self.assertEqual(KeyedNode("A"), KeyedNode("A"))
     self.assertNotEqual(KeyedNode("A"), KeyedNode("B"))
     self.assertNotEqual(KeyedNode("A"), KeyedNode("a"))
Beispiel #18
0
    def test_Parent_CanSet(self):
        parent = KeyedNode("parent")
        child = KeyedNode("child")
        child.set_parent(parent)

        self.assertEqual(child.get_parent(), parent)
Beispiel #19
0
    def test_RootNode_LoopException(self):
        grandParent = KeyedNode("grand pa")
        parent = KeyedNode("pa")
        child = KeyedNode("me")
        child.set_parent(parent)
        parent.set_parent(grandParent)
        grandParent.set_parent(child)

        self.assertRaises(TreeHasLoop, lambda: child.get_root_node())
        self.assertRaises(TreeHasLoop, lambda: parent.get_root_node())
        self.assertRaises(TreeHasLoop, lambda: grandParent.get_root_node())
Beispiel #20
0
    def test_Ancestory_NoLoops(self):
        grandParent = KeyedNode("grand pa")
        parent = KeyedNode("pa")
        child = KeyedNode("me")
        child.set_parent(parent)
        parent.set_parent(grandParent)

        self.assertEqual(child.get_ancestry(), [parent, grandParent])
        self.assertEqual(parent.get_ancestry(), [grandParent])
        self.assertEqual(grandParent.get_ancestry(), [])