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 source_file_name(self, package):
44
"""Return the path of the .py file for package."""
45
path = package.__file__
51
def test_branch_working_tree(self):
52
"""Test that the number of uses of working_tree in branch is stable."""
53
occurences = self.find_occurences('self.working_tree()',
54
self.source_file_name(bzrlib.branch))
55
# do not even think of increasing this number. If you think you need to
56
# increase it, then you almost certainly are doing something wrong as
57
# the relationship from working_tree to branch is one way.
58
# This number should be 0, but the basis_inventory merge was done
59
# before this test was written. Note that this is an exact equality
60
# so that when the number drops, it is not given a buffer but rather
61
# this test updated immediately.
62
self.assertEqual(1, occurences)
64
def test_branch_WorkingTree(self):
65
"""Test that the number of uses of working_tree in branch is stable."""
66
occurences = self.find_occurences('WorkingTree',
67
self.source_file_name(bzrlib.branch))
68
# do not even think of increasing this number. If you think you need to
69
# increase it, then you almost certainly are doing something wrong as
70
# the relationship from working_tree to branch is one way.
71
# This number should be 4 (import NoWorkingTree and WorkingTree,
72
# raise NoWorkingTree from working_tree(), and construct a working tree
73
# there) but a merge that regressed this was done before this test was
74
# written. Note that this is an exact equality so that when the number
75
# drops, it is not given a buffer but rather this test updated
77
self.assertEqual(9, occurences)