~bzr-pqm/bzr/bzr.dev

« back to all changes in this revision

Viewing changes to bzrlib/tests/test_tree.py

  • Committer: John Arbash Meinel
  • Date: 2006-10-11 00:23:23 UTC
  • mfrom: (2070 +trunk)
  • mto: This revision was merged to the branch mainline in revision 2071.
  • Revision ID: john@arbash-meinel.com-20061011002323-82ba88c293d7caff
[merge] bzr.dev 2070

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
 
# Copyright (C) 2006 Canonical Ltd
 
1
# Copyright (C) 2006 by Canonical Ltd
2
2
#
3
3
# This program is free software; you can redistribute it and/or modify
4
4
# it under the terms of the GNU General Public License as published by
16
16
 
17
17
"""Tests for Tree and InterTree."""
18
18
 
19
 
from bzrlib import errors
20
19
from bzrlib.tests import TestCaseWithTransport
21
20
from bzrlib.tree import InterTree
22
21
 
63
62
    calls = []
64
63
 
65
64
    def compare(self, want_unchanged=False, specific_files=None,
66
 
        extra_trees=None, require_versioned=False, include_root=False,
67
 
        want_unversioned=False):
 
65
        extra_trees=None, require_versioned=False, include_root=False):
68
66
        self.calls.append(
69
67
            ('compare', self.source, self.target, want_unchanged,
70
68
             specific_files, extra_trees, require_versioned, 
71
 
             include_root, want_unversioned)
 
69
             include_root)
72
70
            )
73
71
    
74
72
    @classmethod
100
98
                extra_trees='extra',
101
99
                require_versioned='require',
102
100
                include_root=True,
103
 
                want_unversioned=True,
104
101
                )
105
102
        finally:
106
103
            InterTree._optimisers = old_optimisers
107
104
        self.assertEqual(
108
105
            [
109
 
             ('compare', tree2, tree, False, None, None, False, False, False),
110
 
             ('compare', tree2, tree, 'unchanged', 'specific', 'extra',
111
 
              'require', True, False),
112
 
             ('compare', tree2, tree, 'unchanged', 'specific', 'extra',
113
 
              'require', True, True),
 
106
             ('compare', tree2, tree, False, None, None, False, False),
 
107
             ('compare', tree2, tree, 'unchanged', 'specific', 'extra',
 
108
              'require', True),
 
109
             ('compare', tree2, tree, 'unchanged', 'specific', 'extra',
 
110
              'require', True),
114
111
            ], RecordingOptimiser.calls)
115
 
 
116
 
    def test_changes_from_with_root(self):
117
 
        """Ensure the include_root option does what's expected."""
118
 
        wt = self.make_branch_and_tree('.')
119
 
        delta = wt.changes_from(wt.basis_tree())
120
 
        self.assertEqual(len(delta.added), 0)
121
 
        delta = wt.changes_from(wt.basis_tree(), wt, include_root=True)
122
 
        self.assertEqual(len(delta.added), 1)
123
 
        self.assertEqual(delta.added[0][0], '')
124
 
 
125
 
    def test_changes_from_with_require_versioned(self):
126
 
        """Ensure the require_versioned option does what's expected."""
127
 
        wt = self.make_branch_and_tree('.')
128
 
        self.build_tree(['known_file', 'unknown_file'])
129
 
        wt.add('known_file')
130
 
 
131
 
        self.assertRaises(errors.PathsNotVersionedError,
132
 
            wt.changes_from, wt.basis_tree(), wt, specific_files=['known_file',
133
 
            'unknown_file'], require_versioned=True)
134
 
 
135
 
        # we need to pass a known file with an unknown file to get this to
136
 
        # fail when expected.
137
 
        delta = wt.changes_from(wt.basis_tree(), wt, 
138
 
            specific_files=['known_file', 'unknown_file'] ,
139
 
            require_versioned=False)
140
 
        self.assertEqual(len(delta.added), 1)