~bzr-pqm/bzr/bzr.dev

« back to all changes in this revision

Viewing changes to bzrlib/tests/test_source.py

  • Committer: Martin Pool
  • Date: 2006-01-06 01:13:05 UTC
  • mfrom: (1534.1.4 integration)
  • Revision ID: mbp@sourcefrog.net-20060106011305-3772285d84b5cbb4
[merge] robertc

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
# Copyright (C) 2005 by Canonical Ltd
 
2
#   Authors: Robert Collins <robert.collins@canonical.com>
 
3
#
 
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.
 
8
#
 
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.
 
13
#
 
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
 
17
 
 
18
"""These tests are tests about the source code of bzrlib itself.
 
19
 
 
20
They are useful for testing code quality, checking coverage metric etc.
 
21
"""
 
22
 
 
23
# import system imports here
 
24
import os
 
25
import sys
 
26
 
 
27
#import bzrlib specific imports here
 
28
from bzrlib.tests import TestCase
 
29
import bzrlib.branch
 
30
 
 
31
 
 
32
class TestApiUsage(TestCase):
 
33
 
 
34
    def find_occurences(self, rule, filename):
 
35
        """Find the number of occurences of rule in a file."""
 
36
        occurences = 0
 
37
        source = file(filename, 'r')
 
38
        for line in source:
 
39
            if line.find(rule) > -1:
 
40
                occurences += 1
 
41
        return occurences
 
42
 
 
43
    def source_file_name(self, package):
 
44
        """Return the path of the .py file for package."""
 
45
        path = package.__file__
 
46
        if path[-1] in 'co':
 
47
            return path[:-1]
 
48
        else:
 
49
            return path
 
50
 
 
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(2, occurences)
 
63
 
 
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
 
76
        # immediately.
 
77
        self.assertEqual(6, occurences)