/brz/remove-bazaar

To get this branch, use:
bzr branch http://gegoxaren.bato24.eu/bzr/brz/remove-bazaar
1852.16.5 by John Arbash Meinel
[merge] bzr.dev 2255, resolve conflicts, update copyrights
1
# Copyright (C) 2006, 2007 Canonical Ltd
1852.15.5 by Robert Collins
Add missing test_walkdirs test file.
2
#
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.
7
#
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.
12
#
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
16
17
"""Tests for the generic Tree.walkdirs interface."""
18
19
from bzrlib.tests.tree_implementations import TestCaseWithTree
20
21
22
class TestWalkdirs(TestCaseWithTree):
23
1852.15.10 by Robert Collins
Tweak the Tree.walkdirs interface more to be more useful.
24
    def get_all_subdirs_expected(self, tree):
25
        return [
2255.2.18 by Robert Collins
Dirstate: all tree_implementation tests passing.
26
            (('', tree.path2id('')),
1852.15.10 by Robert Collins
Tweak the Tree.walkdirs interface more to be more useful.
27
            [
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, u'0utf\u1234file', 'file'),
31
             ('symlink', 'symlink', 'symlink', None, 'symlink', 'symlink')
32
            ]),
33
            (('1top-dir', '1top-dir'),
34
            [('1top-dir/0file-in-1topdir', '0file-in-1topdir', 'file', None, '1file-in-1topdir', 'file'),
35
             ('1top-dir/1dir-in-1topdir', '1dir-in-1topdir', 'directory', None, '0dir-in-1topdir', 'directory'),
36
            ]),
37
            (('1top-dir/1dir-in-1topdir', '0dir-in-1topdir'),
38
            [
39
            ]),
40
            ]
41
1852.15.5 by Robert Collins
Add missing test_walkdirs test file.
42
    def test_walkdir_root(self):
43
        tree = self.get_tree_with_subdirs_and_all_content_types()
1852.15.10 by Robert Collins
Tweak the Tree.walkdirs interface more to be more useful.
44
        expected_dirblocks = self.get_all_subdirs_expected(tree)
2255.2.18 by Robert Collins
Dirstate: all tree_implementation tests passing.
45
        tree.lock_read()
1852.15.5 by Robert Collins
Add missing test_walkdirs test file.
46
        # test that its iterable by iterating
47
        result = []
1852.15.7 by Robert Collins
Start testing behaviour of unknowns in WorkingTree.walkdirs.
48
        for dirinfo, block in tree.walkdirs():
49
            newblock = []
50
            for row in block:
51
                if row[4] is not None:
52
                    newblock.append(row[0:3] + (None,) + row[4:])
53
                else:
54
                    newblock.append(row)
55
            result.append((dirinfo, newblock))
2255.2.18 by Robert Collins
Dirstate: all tree_implementation tests passing.
56
        tree.unlock()
1852.15.7 by Robert Collins
Start testing behaviour of unknowns in WorkingTree.walkdirs.
57
        # check each return value for debugging ease.
58
        for pos, item in enumerate(expected_dirblocks):
59
            self.assertEqual(item, result[pos])
1852.15.11 by Robert Collins
Tree.walkdirs handles missing contents in workingtrees.
60
        self.assertEqual(len(expected_dirblocks), len(result))
1852.15.10 by Robert Collins
Tweak the Tree.walkdirs interface more to be more useful.
61
            
62
    def test_walkdir_subtree(self):
63
        tree = self.get_tree_with_subdirs_and_all_content_types()
64
        expected_dirblocks = self.get_all_subdirs_expected(tree)[1:]
65
        # test that its iterable by iterating
66
        result = []
2255.2.18 by Robert Collins
Dirstate: all tree_implementation tests passing.
67
        tree.lock_read()
1852.15.10 by Robert Collins
Tweak the Tree.walkdirs interface more to be more useful.
68
        for dirinfo, block in tree.walkdirs('1top-dir'):
69
            newblock = []
70
            for row in block:
71
                if row[4] is not None:
72
                    newblock.append(row[0:3] + (None,) + row[4:])
73
                else:
74
                    newblock.append(row)
75
            result.append((dirinfo, newblock))
2255.2.18 by Robert Collins
Dirstate: all tree_implementation tests passing.
76
        tree.unlock()
1852.15.10 by Robert Collins
Tweak the Tree.walkdirs interface more to be more useful.
77
        # check each return value for debugging ease.
78
        for pos, item in enumerate(expected_dirblocks):
79
            self.assertEqual(item, result[pos])
1852.15.11 by Robert Collins
Tree.walkdirs handles missing contents in workingtrees.
80
        self.assertEqual(len(expected_dirblocks), len(result))