This repository has been archived on 2023-03-25. You can view files and clone it, but cannot push or open issues or pull requests.
mightyscape-1.1-deprecated/extensions/networkx/algorithms/traversal/tests/test_bfs.py
2020-07-30 01:16:18 +02:00

83 lines
2.7 KiB
Python

import networkx as nx
class TestBFS:
@classmethod
def setup_class(cls):
# simple graph
G = nx.Graph()
G.add_edges_from([(0, 1), (1, 2), (1, 3), (2, 4), (3, 4)])
cls.G = G
def test_successor(self):
assert (dict(nx.bfs_successors(self.G, source=0)) ==
{0: [1], 1: [2, 3], 2: [4]})
def test_predecessor(self):
assert (dict(nx.bfs_predecessors(self.G, source=0)) ==
{1: 0, 2: 1, 3: 1, 4: 2})
def test_bfs_tree(self):
T = nx.bfs_tree(self.G, source=0)
assert sorted(T.nodes()) == sorted(self.G.nodes())
assert sorted(T.edges()) == [(0, 1), (1, 2), (1, 3), (2, 4)]
def test_bfs_edges(self):
edges = nx.bfs_edges(self.G, source=0)
assert list(edges) == [(0, 1), (1, 2), (1, 3), (2, 4)]
def test_bfs_edges_reverse(self):
D = nx.DiGraph()
D.add_edges_from([(0, 1), (1, 2), (1, 3), (2, 4), (3, 4)])
edges = nx.bfs_edges(D, source=4, reverse=True)
assert list(edges) == [(4, 2), (4, 3), (2, 1), (1, 0)]
def test_bfs_tree_isolates(self):
G = nx.Graph()
G.add_node(1)
G.add_node(2)
T = nx.bfs_tree(G, source=1)
assert sorted(T.nodes()) == [1]
assert sorted(T.edges()) == []
class TestBreadthLimitedSearch:
@classmethod
def setup_class(cls):
# a tree
G = nx.Graph()
nx.add_path(G, [0, 1, 2, 3, 4, 5, 6])
nx.add_path(G, [2, 7, 8, 9, 10])
cls.G = G
# a disconnected graph
D = nx.Graph()
D.add_edges_from([(0, 1), (2, 3)])
nx.add_path(D, [2, 7, 8, 9, 10])
cls.D = D
def bfs_test_successor(self):
assert (dict(nx.bfs_successors(self.G, source=1, depth_limit=3)) ==
{1: [0, 2], 2: [3, 7], 3: [4], 7: [8]})
result = {n: sorted(s) for n, s in nx.bfs_successors(self.D, source=7,
depth_limit=2)}
assert result == {8: [9], 2: [3], 7: [2, 8]}
def bfs_test_predecessor(self):
assert (dict(nx.bfs_predecessors(self.G, source=1,
depth_limit=3)) ==
{0: 1, 2: 1, 3: 2, 4: 3, 7: 2, 8: 7})
assert (dict(nx.bfs_predecessors(self.D, source=7,
depth_limit=2)) ==
{2: 7, 3: 2, 8: 7, 9: 8})
def bfs_test_tree(self):
T = nx.bfs_tree(self.G, source=3, depth_limit=1)
assert sorted(T.edges()) == [(3, 2), (3, 4)]
def bfs_test_edges(self):
edges = nx.bfs_edges(self.G, source=9, depth_limit=4)
assert list(edges) == [(9, 8), (9, 10), (8, 7),
(7, 2), (2, 1), (2, 3)]