1
# Copyright (C) 2006, 2007 Canonical Ltd
3
# This program is free software; you can redistribute it and/or modify
4
# it under the terms of the GNU General Public License as published by
5
# the Free Software Foundation; either version 2 of the License, or
6
# (at your option) any later version.
8
# This program is distributed in the hope that it will be useful,
9
# but WITHOUT ANY WARRANTY; without even the implied warranty of
10
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
11
# GNU General Public License for more details.
13
# You should have received a copy of the GNU General Public License
14
# along with this program; if not, write to the Free Software
15
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
17
"""Tests for the generic Tree.walkdirs interface."""
19
from bzrlib.tests.tree_implementations import TestCaseWithTree
22
class TestWalkdirs(TestCaseWithTree):
24
def get_all_subdirs_expected(self, tree):
26
(('', tree.path2id('')),
28
('0file', '0file', 'file', None, '2file', 'file'),
29
('1top-dir', '1top-dir', 'directory', None, '1top-dir', 'directory'),
30
(u'2utf\u1234file', u'2utf\u1234file', 'file', None,
31
u'0utf\u1234file'.encode('utf8'), 'file'),
32
('symlink', 'symlink', 'symlink', None, 'symlink', 'symlink')
34
(('1top-dir', '1top-dir'),
35
[('1top-dir/0file-in-1topdir', '0file-in-1topdir', 'file', None, '1file-in-1topdir', 'file'),
36
('1top-dir/1dir-in-1topdir', '1dir-in-1topdir', 'directory', None, '0dir-in-1topdir', 'directory'),
38
(('1top-dir/1dir-in-1topdir', '0dir-in-1topdir'),
43
def test_walkdir_root(self):
44
tree = self.get_tree_with_subdirs_and_all_content_types()
46
expected_dirblocks = self.get_all_subdirs_expected(tree)
47
# test that its iterable by iterating
49
for dirinfo, block in tree.walkdirs():
52
if row[4] is not None:
53
newblock.append(row[0:3] + (None,) + row[4:])
56
result.append((dirinfo, newblock))
58
# check each return value for debugging ease.
59
for pos, item in enumerate(expected_dirblocks):
60
self.assertEqual(item, result[pos])
61
self.assertEqual(len(expected_dirblocks), len(result))
63
def test_walkdir_subtree(self):
64
tree = self.get_tree_with_subdirs_and_all_content_types()
65
# test that its iterable by iterating
68
expected_dirblocks = self.get_all_subdirs_expected(tree)[1:]
69
for dirinfo, block in tree.walkdirs('1top-dir'):
72
if row[4] is not None:
73
newblock.append(row[0:3] + (None,) + row[4:])
76
result.append((dirinfo, newblock))
78
# check each return value for debugging ease.
79
for pos, item in enumerate(expected_dirblocks):
80
self.assertEqual(item, result[pos])
81
self.assertEqual(len(expected_dirblocks), len(result))