Exemplo n.º 1
0
 def test_depth_first_search_simple_mode(self):
     #[ARRANGE]
     graph = Graph()
     #[ACT]
     string_result = graph.depth_first_search("A")
     #[ASSERT]
     self.assertEqual('A', string_result)
Exemplo n.º 2
0
 def test_add_link_with_exception(self):
     #[ARRANGE]
     graph = Graph()
     parent_id = "B"
     child_id = "C"
     #[ACT]-[ASSERT]
     with self.assertRaises(GraphException):
         graph.add_link(parent_id, child_id)
Exemplo n.º 3
0
 def test_depth_first_search_normal_mode_1(self):
     #[ARRANGE]
     graph = Graph()
     graph.add_link("A", "B")
     graph.add_link("B", "C")
     #[ACT]
     string_result = graph.depth_first_search("C")
     #[ASSERT]
     self.assertEqual('A->B->C', string_result)
Exemplo n.º 4
0
 def test_add_link_method(self):
     #[ARRANGE]
     graph = Graph()
     parent_id = "A"
     child_id = "B"
     #[ACT] 
     graph.add_link(parent_id, child_id)
     #[ASSERT]
     self.assertEqual(1, len(graph.root.children))
     self.assertEqual(child_id, graph.root.children[0].id)
     self.assertEqual("A", graph.root.children[0].parents[0].id)
Exemplo n.º 5
0
 def test_add_link_another_variant_2(self):
     #[ARRANGE]
     graph = Graph()
     graph.root.add_child(Node("B"))
     graph.root.children[0].add_parent(graph.root)
     #[ACT]
     graph.add_link("B", "C")
     #[ASSERT]
     self.assertEqual(1, len(graph.root.children))
     self.assertEqual(1, len(graph.root.children[0].children))
     self.assertEqual(1, len(graph.root.children[0].parents))
     self.assertEqual(1, len(graph.root.children[0].children[0].parents))
     self.assertEqual("B", graph.root.children[0].id)
     self.assertEqual("C", graph.root.children[0].children[0].id)
Exemplo n.º 6
0
 def test_breadth_first_search_with_exception(self):
     #[ARRANGE]
     graph = Graph()
     graph.add_link("A", "B")
     #[ACT]-[ASSERT]
     with self.assertRaises(NodeNotFoundException):
         graph.breadth_first_search("E")
Exemplo n.º 7
0
 def test_breadth_first_search_control_example(self):
     #[ARRANGE]
     # 1-st layer
     graph = Graph()
     # 2-nd layer
     graph.add_link("A", "B")
     graph.add_link("A", "C")
     graph.add_link("A", "D")
     # 3-d layer
     graph.add_link("B", "E")
     graph.add_link("B", "F")
     graph.add_link("C", "G")
     graph.add_link("C", "H")
     graph.add_link("D", "I")
     graph.add_link("D", "J")
     # 4-th layer
     graph.add_link("E", "K")
     graph.add_link("E", "L")
     graph.add_link("F", "L")
     graph.add_link("F", "M")
     graph.add_link("G", "N")
     graph.add_link("H", "O")
     graph.add_link("H", "P")
     graph.add_link("I", "P")
     graph.add_link("I", "Q")
     graph.add_link("J", "R")
     # additional links
     #graph.add_link("C", "M")
     #graph.add_link("D", "Q")
     #[ACT]
     string_result = graph.breadth_first_search("N")
     #[ASSERT]
     self.assertEqual("A->B->C->D->E->F->G->H->I->J->K->L->M->N", string_result)
Exemplo n.º 8
0
 def test_init_graph(self):
     #[ARRANGE]-[ACT]
     graph = Graph()
     #[ASSERT]
     self.assertIsNotNone(graph.root) 
     self.assertEqual("A", graph.root.id)
"""
Main module
"""


from app.logic.graph import Graph
from app.logic.node import Node


if __name__ == '__main__':
    #[INIT]
    # 1-st layer
    graph = Graph()
    # 2-nd layer
    graph.add_link("A", "B")
    graph.add_link("A", "C")
    graph.add_link("A", "D")
    # 3-d layer
    graph.add_link("B", "E")
    graph.add_link("B", "F")
    graph.add_link("C", "G")
    graph.add_link("C", "H")
    graph.add_link("D", "I")
    graph.add_link("D", "J")
    # 4-th layer
    graph.add_link("E", "K")
    graph.add_link("E", "L")
    graph.add_link("F", "L")
    graph.add_link("F", "M")
    graph.add_link("G", "N")
    graph.add_link("H", "O")
"""
Main module
"""

from app.logic.graph import Graph
from app.logic.node import Node

if __name__ == '__main__':
    #[INIT]
    # 1-st layer
    graph = Graph()
    # 2-nd layer
    graph.add_link("A", "B")
    graph.add_link("A", "C")
    graph.add_link("A", "D")
    # 3-d layer
    graph.add_link("B", "E")
    graph.add_link("B", "F")
    graph.add_link("C", "G")
    graph.add_link("C", "H")
    graph.add_link("D", "I")
    graph.add_link("D", "J")
    # 4-th layer
    graph.add_link("E", "K")
    graph.add_link("E", "L")
    graph.add_link("F", "L")
    graph.add_link("F", "M")
    graph.add_link("G", "N")
    graph.add_link("H", "O")
    graph.add_link("H", "P")
    graph.add_link("I", "P")