55
72
# do not even think of increasing this number. If you think you need to
56
73
# increase it, then you almost certainly are doing something wrong as
57
74
# 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)
75
# Note that this is an exact equality so that when the number drops,
76
#it is not given a buffer but rather has this test updated immediately.
77
self.assertEqual(0, occurences)
64
79
def test_branch_WorkingTree(self):
65
80
"""Test that the number of uses of working_tree in branch is stable."""
66
81
occurences = self.find_occurences('WorkingTree',
67
82
self.source_file_name(bzrlib.branch))
68
# do not even think of increasing this number. If you think you need to
83
# Do not even think of increasing this number. If you think you need to
69
84
# increase it, then you almost certainly are doing something wrong as
70
85
# 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(6, occurences)
86
# As of 20070809, there are no longer any mentions at all.
87
self.assertEqual(0, occurences)
90
class TestSource(TestSourceHelper):
92
def get_bzrlib_dir(self):
93
"""Get the path to the root of bzrlib"""
94
source = self.source_file_name(bzrlib)
95
source_dir = os.path.dirname(source)
97
# Avoid the case when bzrlib is packaged in a zip file
98
if not os.path.isdir(source_dir):
99
raise TestSkipped('Cannot find bzrlib source directory. Expected %s'
103
def get_source_files(self):
104
"""yield all source files for bzr and bzrlib"""
105
bzrlib_dir = self.get_bzrlib_dir()
107
# This is the front-end 'bzr' script
108
bzr_path = self.get_bzr_path()
111
for root, dirs, files in os.walk(bzrlib_dir):
113
if d.endswith('.tmp'):
116
if not f.endswith('.py'):
118
yield osutils.pathjoin(root, f)
120
def get_source_file_contents(self):
121
for fname in self.get_source_files():
122
f = open(fname, 'rb')
129
def is_copyright_exception(self, fname):
130
"""Certain files are allowed to be different"""
131
if '/util/' in fname or '/plugins/' in fname:
132
# We don't ask that external utilities or plugins be
136
for exc in COPYRIGHT_EXCEPTIONS:
137
if fname.endswith(exc):
142
def is_license_exception(self, fname):
143
"""Certain files are allowed to be different"""
144
if '/util/' in fname or '/plugins/' in fname:
145
# We don't ask that external utilities or plugins be
149
for exc in LICENSE_EXCEPTIONS:
150
if fname.endswith(exc):
155
def test_tmpdir_not_in_source_files(self):
156
"""When scanning for source files, we don't descend test tempdirs"""
157
for filename in self.get_source_files():
158
if re.search(r'test....\.tmp', filename):
159
self.fail("get_source_file() returned filename %r "
160
"from within a temporary directory"
163
def test_copyright(self):
164
"""Test that all .py files have a valid copyright statement"""
165
# These are files which contain a different copyright statement
169
copyright_re = re.compile('#\\s*copyright.*(?=\n)', re.I)
170
copyright_canonical_re = re.compile(
171
r'# Copyright \(C\) ' # Opening "# Copyright (C)"
172
r'(\d+)(, \d+)*' # Followed by a series of dates
173
r'.*Canonical Ltd' # And containing 'Canonical Ltd'
176
for fname, text in self.get_source_file_contents():
177
if self.is_copyright_exception(fname):
179
match = copyright_canonical_re.search(text)
181
match = copyright_re.search(text)
183
incorrect.append((fname, 'found: %s' % (match.group(),)))
185
incorrect.append((fname, 'no copyright line found\n'))
187
if 'by Canonical' in match.group():
188
incorrect.append((fname,
189
'should not have: "by Canonical": %s'
193
help_text = ["Some files have missing or incorrect copyright"
196
"Please either add them to the list of"
197
" COPYRIGHT_EXCEPTIONS in"
198
" bzrlib/tests/test_source.py",
199
# this is broken to prevent a false match
200
"or add '# Copyright (C)"
201
" 2007 Canonical Ltd' to these files:",
204
for fname, comment in incorrect:
205
help_text.append(fname)
206
help_text.append((' '*4) + comment)
208
self.fail('\n'.join(help_text))
211
"""Test that all .py files have a GPL disclaimer"""
215
# This program is free software; you can redistribute it and/or modify
216
# it under the terms of the GNU General Public License as published by
217
# the Free Software Foundation; either version 2 of the License, or
218
# (at your option) any later version.
220
# This program is distributed in the hope that it will be useful,
221
# but WITHOUT ANY WARRANTY; without even the implied warranty of
222
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
223
# GNU General Public License for more details.
225
# You should have received a copy of the GNU General Public License
226
# along with this program; if not, write to the Free Software
227
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
229
gpl_re = re.compile(re.escape(gpl_txt), re.MULTILINE)
231
for fname, text in self.get_source_file_contents():
232
if self.is_license_exception(fname):
234
if not gpl_re.search(text):
235
incorrect.append(fname)
238
help_text = ['Some files have missing or incomplete GPL statement',
240
"Please either add them to the list of"
241
" LICENSE_EXCEPTIONS in"
242
" bzrlib/tests/test_source.py",
243
"Or add the following text to the beginning:",
246
for fname in incorrect:
247
help_text.append((' '*4) + fname)
249
self.fail('\n'.join(help_text))
251
def test_no_tabs(self):
252
"""bzrlib source files should not contain any tab characters."""
255
for fname, text in self.get_source_file_contents():
256
if '/util/' in fname or '/plugins/' in fname:
259
incorrect.append(fname)
262
self.fail('Tab characters were found in the following source files.'
263
'\nThey should either be replaced by "\\t" or by spaces:'
265
% ('\n '.join(incorrect)))