~bzr-pqm/bzr/bzr.dev

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
from bzrlib.selftest import TestCase
from bzrlib.graph import shortest_path
from bzrlib.graph import farthest_nodes_ab

class TestBase(TestCase):
    def edge_add(self, *args):
        for start, end in zip(args[:-1], args[1:]):
            if start not in self.graph:
                self.graph[start] = {}
            if end not in self.graph:
                self.graph[end] = {}
            self.graph[start][end] = 1

    def setUp(self):
        TestCase.setUp(self)
        self.graph = {}
        self.edge_add('A', 'B', 'C')
        self.edge_add('A', 'D', 'E', 'B', 'G')
        self.edge_add('E', 'F')
    
    def test_shortest(self):
        """Ensure we find the longest path to A"""
        assert 'B' in self.graph['A']
        self.assertEqual(shortest_path(self.graph, 'A', 'F'), 
                         ['A', 'D', 'E', 'F'])
        self.assertEqual(shortest_path(self.graph, 'A', 'G'), 
                         ['A', 'B', 'G'])
    def test_farthest(self):
        self.assertEqual(farthest_nodes_ab(self.graph, 'A')[0], 'G')
        self.assertEqual(farthest_nodes_ab(self.graph, 'F')[0], 'F')
        self.graph = {}
        self.edge_add('A', 'B', 'C', 'D')
        self.edge_add('A', 'E', 'F', 'C')
        self.edge_add('A', 'G', 'H', 'I', 'B')
        self.edge_add('A', 'J', 'K', 'L', 'M', 'N')
        self.assertEqual(farthest_nodes_ab(self.graph, 'A')[0], 'D')