/brz/remove-bazaar

To get this branch, use:
bzr branch http://gegoxaren.bato24.eu/bzr/brz/remove-bazaar

« back to all changes in this revision

Viewing changes to bzrlib/tests/test_revision.py

  • Committer: John Arbash Meinel
  • Date: 2008-08-18 22:34:21 UTC
  • mto: (3606.5.6 1.6)
  • mto: This revision was merged to the branch mainline in revision 3641.
  • Revision ID: john@arbash-meinel.com-20080818223421-todjny24vj4faj4t
Add tests for the fetching behavior.

The proper parameter passed is 'unordered' add an assert for it, and
fix callers that were passing 'unsorted' instead.
Add tests that we make the right get_record_stream call based
on the value of _fetch_uses_deltas.
Fix the fetch request for signatures.

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
# Copyright (C) 2005 Canonical Ltd
 
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
 
 
18
import os
 
19
import warnings
 
20
 
 
21
from bzrlib import (
 
22
    revision,
 
23
    symbol_versioning,
 
24
    )
 
25
from bzrlib.branch import Branch
 
26
from bzrlib.errors import NoSuchRevision
 
27
from bzrlib.deprecated_graph import Graph
 
28
from bzrlib.revision import (find_present_ancestors,
 
29
                             NULL_REVISION)
 
30
from bzrlib.symbol_versioning import one_three
 
31
from bzrlib.tests import TestCase, TestCaseWithTransport
 
32
from bzrlib.trace import mutter
 
33
from bzrlib.workingtree import WorkingTree
 
34
 
 
35
# We're allowed to test deprecated interfaces
 
36
warnings.filterwarnings('ignore',
 
37
        '.*get_intervening_revisions was deprecated',
 
38
        DeprecationWarning,
 
39
        r'bzrlib\.tests\.test_revision')
 
40
 
 
41
# XXX: Make this a method of a merge base case
 
42
def make_branches(self, format=None):
 
43
    """Create two branches
 
44
 
 
45
    branch 1 has 6 commits, branch 2 has 3 commits
 
46
    commit 10 is a ghosted merge merge from branch 1
 
47
 
 
48
    the object graph is
 
49
    B:     A:
 
50
    a..0   a..0 
 
51
    a..1   a..1
 
52
    a..2   a..2
 
53
    b..3   a..3 merges b..4
 
54
    b..4   a..4
 
55
    b..5   a..5 merges b..5
 
56
    b..6 merges a4
 
57
 
 
58
    so A is missing b6 at the start
 
59
    and B is missing a3, a4, a5
 
60
    """
 
61
    tree1 = self.make_branch_and_tree("branch1", format=format)
 
62
    br1 = tree1.branch
 
63
    
 
64
    tree1.commit("Commit one", rev_id="a@u-0-0")
 
65
    tree1.commit("Commit two", rev_id="a@u-0-1")
 
66
    tree1.commit("Commit three", rev_id="a@u-0-2")
 
67
 
 
68
    tree2 = tree1.bzrdir.clone("branch2").open_workingtree()
 
69
    br2 = tree2.branch
 
70
    tree2.commit("Commit four", rev_id="b@u-0-3")
 
71
    tree2.commit("Commit five", rev_id="b@u-0-4")
 
72
    revisions_2 = br2.revision_history()
 
73
    self.assertEquals(revisions_2[-1], 'b@u-0-4')
 
74
    
 
75
    tree1.merge_from_branch(br2)
 
76
    tree1.commit("Commit six", rev_id="a@u-0-3")
 
77
    tree1.commit("Commit seven", rev_id="a@u-0-4")
 
78
    tree2.commit("Commit eight", rev_id="b@u-0-5")
 
79
    self.assertEquals(br2.revision_history()[-1], 'b@u-0-5')
 
80
    
 
81
    tree1.merge_from_branch(br2)
 
82
    tree1.commit("Commit nine", rev_id="a@u-0-5")
 
83
    # DO NOT MERGE HERE - we WANT a GHOST.
 
84
    tree2.add_parent_tree_id(br1.revision_history()[4])
 
85
    tree2.commit("Commit ten - ghost merge", rev_id="b@u-0-6")
 
86
    
 
87
    return br1, br2
 
88
 
 
89
 
 
90
class TestIsAncestor(TestCaseWithTransport):
 
91
 
 
92
    def test_recorded_ancestry(self):
 
93
        """Test that commit records all ancestors"""
 
94
        br1, br2 = make_branches(self)
 
95
        d = [('a@u-0-0', ['a@u-0-0']),
 
96
             ('a@u-0-1', ['a@u-0-0', 'a@u-0-1']),
 
97
             ('a@u-0-2', ['a@u-0-0', 'a@u-0-1', 'a@u-0-2']),
 
98
             ('b@u-0-3', ['a@u-0-0', 'a@u-0-1', 'a@u-0-2', 'b@u-0-3']),
 
99
             ('b@u-0-4', ['a@u-0-0', 'a@u-0-1', 'a@u-0-2', 'b@u-0-3',
 
100
                          'b@u-0-4']),
 
101
             ('a@u-0-3', ['a@u-0-0', 'a@u-0-1', 'a@u-0-2', 'b@u-0-3', 'b@u-0-4',
 
102
                          'a@u-0-3']),
 
103
             ('a@u-0-4', ['a@u-0-0', 'a@u-0-1', 'a@u-0-2', 'b@u-0-3', 'b@u-0-4',
 
104
                          'a@u-0-3', 'a@u-0-4']),
 
105
             ('b@u-0-5', ['a@u-0-0', 'a@u-0-1', 'a@u-0-2', 'b@u-0-3', 'b@u-0-4',
 
106
                          'b@u-0-5']),
 
107
             ('a@u-0-5', ['a@u-0-0', 'a@u-0-1', 'a@u-0-2', 'a@u-0-3', 'a@u-0-4',
 
108
                          'b@u-0-3', 'b@u-0-4',
 
109
                          'b@u-0-5', 'a@u-0-5']),
 
110
             ('b@u-0-6', ['a@u-0-0', 'a@u-0-1', 'a@u-0-2',
 
111
                          'b@u-0-3', 'b@u-0-4',
 
112
                          'b@u-0-5', 'b@u-0-6']),
 
113
             ]
 
114
        br1_only = ('a@u-0-3', 'a@u-0-4', 'a@u-0-5')
 
115
        br2_only = ('b@u-0-6',)
 
116
        for branch in br1, br2:
 
117
            for rev_id, anc in d:
 
118
                if rev_id in br1_only and not branch is br1:
 
119
                    continue
 
120
                if rev_id in br2_only and not branch is br2:
 
121
                    continue
 
122
                mutter('ancestry of {%s}: %r',
 
123
                       rev_id, branch.repository.get_ancestry(rev_id))
 
124
                result = sorted(branch.repository.get_ancestry(rev_id))
 
125
                self.assertEquals(result, [None] + sorted(anc))
 
126
    
 
127
 
 
128
class TestIntermediateRevisions(TestCaseWithTransport):
 
129
 
 
130
    def setUp(self):
 
131
        TestCaseWithTransport.setUp(self)
 
132
        self.br1, self.br2 = make_branches(self)
 
133
        wt1 = self.br1.bzrdir.open_workingtree()
 
134
        wt2 = self.br2.bzrdir.open_workingtree()
 
135
        wt2.commit("Commit eleven", rev_id="b@u-0-7")
 
136
        wt2.commit("Commit twelve", rev_id="b@u-0-8")
 
137
        wt2.commit("Commit thirtteen", rev_id="b@u-0-9")
 
138
 
 
139
        wt1.merge_from_branch(self.br2)
 
140
        wt1.commit("Commit fourtten", rev_id="a@u-0-6")
 
141
 
 
142
        wt2.merge_from_branch(self.br1)
 
143
        wt2.commit("Commit fifteen", rev_id="b@u-0-10")
 
144
 
 
145
 
 
146
class MockRevisionSource(object):
 
147
    """A RevisionSource that takes a pregenerated graph.
 
148
 
 
149
    This is useful for testing revision graph algorithms where
 
150
    the actual branch existing is irrelevant.
 
151
    """
 
152
 
 
153
    def __init__(self, full_graph):
 
154
        self._full_graph = full_graph
 
155
 
 
156
    def get_revision_graph_with_ghosts(self, revision_ids):
 
157
        # This is mocked out to just return a constant graph.
 
158
        return self._full_graph
 
159
 
 
160
 
 
161
class TestCommonAncestor(TestCaseWithTransport):
 
162
    """Test checking whether a revision is an ancestor of another revision"""
 
163
 
 
164
    def test_get_history(self):
 
165
        # TODO: test ghosts on the left hand branch's impact
 
166
        # TODO: test ghosts on all parents, we should get some
 
167
        # indicator. i.e. NULL_REVISION
 
168
        # RBC 20060608
 
169
        tree = self.make_branch_and_tree('.')
 
170
        tree.commit('1', rev_id = '1', allow_pointless=True)
 
171
        tree.commit('2', rev_id = '2', allow_pointless=True)
 
172
        tree.commit('3', rev_id = '3', allow_pointless=True)
 
173
        rev = tree.branch.repository.get_revision('1')
 
174
        history = rev.get_history(tree.branch.repository)
 
175
        self.assertEqual([None, '1'], history)
 
176
        rev = tree.branch.repository.get_revision('2')
 
177
        history = rev.get_history(tree.branch.repository)
 
178
        self.assertEqual([None, '1', '2'], history)
 
179
        rev = tree.branch.repository.get_revision('3')
 
180
        history = rev.get_history(tree.branch.repository)
 
181
        self.assertEqual([None, '1', '2' ,'3'], history)
 
182
 
 
183
 
 
184
class TestReservedId(TestCase):
 
185
 
 
186
    def test_is_reserved_id(self):
 
187
        self.assertEqual(True, revision.is_reserved_id(NULL_REVISION))
 
188
        self.assertEqual(True, revision.is_reserved_id(
 
189
            revision.CURRENT_REVISION))
 
190
        self.assertEqual(True, revision.is_reserved_id('arch:'))
 
191
        self.assertEqual(False, revision.is_reserved_id('null'))
 
192
        self.assertEqual(False, revision.is_reserved_id(
 
193
            'arch:a@example.com/c--b--v--r'))
 
194
        self.assertEqual(False, revision.is_reserved_id(None))
 
195
 
 
196
 
 
197
class TestRevisionMethods(TestCase):
 
198
 
 
199
    def test_get_summary(self):
 
200
        r = revision.Revision('1')
 
201
        r.message = 'a'
 
202
        self.assertEqual('a', r.get_summary())
 
203
        r.message = 'a\nb'
 
204
        self.assertEqual('a', r.get_summary())
 
205
        r.message = '\na\nb'
 
206
        self.assertEqual('a', r.get_summary())
 
207
 
 
208
    def test_get_apparent_author(self):
 
209
        r = revision.Revision('1')
 
210
        r.committer = 'A'
 
211
        self.assertEqual('A', r.get_apparent_author())
 
212
        r.properties['author'] = 'B'
 
213
        self.assertEqual('B', r.get_apparent_author())