1
# Copyright (C) 2005 by Canonical Ltd
2
# Authors: Robert Collins <robert.collins@canonical.com>
4
# This program is free software; you can redistribute it and/or modify
5
# it under the terms of the GNU General Public License as published by
6
# the Free Software Foundation; either version 2 of the License, or
7
# (at your option) any later version.
9
# This program is distributed in the hope that it will be useful,
10
# but WITHOUT ANY WARRANTY; without even the implied warranty of
11
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12
# GNU General Public License for more details.
14
# You should have received a copy of the GNU General Public License
15
# along with this program; if not, write to the Free Software
16
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
18
"""These tests are tests about the source code of bzrlib itself.
20
They are useful for testing code quality, checking coverage metric etc.
23
# import system imports here
27
#import bzrlib specific imports here
28
from bzrlib.tests import TestCase
32
class TestApiUsage(TestCase):
34
def find_occurences(self, rule, filename):
35
"""Find the number of occurences of rule in a file."""
37
source = file(filename, 'r')
39
if line.find(rule) > -1:
43
def test_branch_working_tree(self):
44
"""Test that the number of uses of working_tree in branch is stable."""
45
occurences = self.find_occurences('self.working_tree()',
46
bzrlib.branch.__file__[:-1])
47
# do not even think of increasing this number. If you think you need to
48
# increase it, then you almost certainly are doing something wrong as
49
# the relationship from working_tree to branch is one way.
50
# This number should be 0, but the basis_inventory merge was done
51
# before this test was written. Note that this is an exact equality
52
# so that when the number drops, it is not given a buffer but rather
53
# this test updated immediately.
54
self.assertEqual(2, occurences)
56
def test_branch_WorkingTree(self):
57
"""Test that the number of uses of working_tree in branch is stable."""
58
occurences = self.find_occurences('WorkingTree',
59
bzrlib.branch.__file__[:-1])
60
# do not even think of increasing this number. If you think you need to
61
# increase it, then you almost certainly are doing something wrong as
62
# the relationship from working_tree to branch is one way.
63
# This number should be 4 (import NoWorkingTree and WorkingTree,
64
# raise NoWorkingTree from working_tree(), and construct a working tree
65
# there) but a merge that regressed this was done before this test was
66
# written. Note that this is an exact equality so that when the number
67
# drops, it is not given a buffer but rather this test updated
69
self.assertEqual(6, occurences)