2
# Copyright (c) 2008 Canonical
4
# Written by Marc Tardif <marc@interunion.ca>
6
# This file is part of Checkbox.
8
# Checkbox is free software: you can redistribute it and/or modify
9
# it under the terms of the GNU General Public License as published by
10
# the Free Software Foundation, either version 3 of the License, or
11
# (at your option) any later version.
13
# Checkbox is distributed in the hope that it will be useful,
14
# but WITHOUT ANY WARRANTY; without even the implied warranty of
15
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16
# GNU General Public License for more details.
18
# You should have received a copy of the GNU General Public License
19
# along with Checkbox. If not, see <http://www.gnu.org/licenses/>.
23
from checkbox.resolver import Resolver
26
class ResolverTest(unittest.TestCase):
27
def test_dependencies_none(self):
30
resolver.get_dependencies('a')
31
except Exception, error:
32
self.assertTrue(error.args[0].startswith('no dependencies'))
34
self.fail('non existing element accepted by resolver')
36
def test_dependencies_one_level(self):
40
results = resolver.get_dependencies('a')
41
self.assertTrue(len(results) == 1)
42
self.assertTrue(results[0] == 'a')
44
def test_dependencies_two_level(self):
47
resolver.add('b', 'a')
49
results = resolver.get_dependencies('b')
50
self.assertTrue(len(results) == 2)
51
self.assertTrue(results[0] == 'a')
52
self.assertTrue(results[1] == 'b')
54
def test_dependencies_multiple(self):
58
resolver.add('c', 'a', 'b')
60
results = resolver.get_dependencies('c')
61
self.assertTrue(len(results) == 3)
62
self.assertTrue(results[0] == 'a')
63
self.assertTrue(results[1] == 'b')
64
self.assertTrue(results[2] == 'c')
66
def test_dependencies_circular(self):
68
resolver.add('a', 'b')
69
resolver.add('b', 'a')
71
resolver.get_dependencies('a')
72
except Exception, error:
73
self.assertTrue(error.args[0].startswith('circular dependency'))
75
self.fail('circular dependency not detected')
77
def test_dependents_none(self):
81
results = resolver.get_dependents('a')
82
self.assertTrue(len(results) == 0)
84
def test_dependents_one(self):
87
resolver.add('b', 'a')
89
results = resolver.get_dependents('a')
90
self.assertTrue(len(results) == 1)
91
self.assertTrue(results[0] == 'b')
93
def test_dependents_two(self):
96
resolver.add('b', 'a')
97
resolver.add('c', 'b')
99
results = resolver.get_dependents('a')
100
self.assertTrue(len(results) == 2)
101
self.assertTrue(results[0] == 'b')
102
self.assertTrue(results[1] == 'c')