14
14
# along with this program; if not, write to the Free Software
15
15
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
17
from bzrlib.selftest import InTempDir
21
class TestAppendRevisions(InTempDir):
22
"""Test appending more than one revision"""
24
from bzrlib.branch import Branch
25
br = Branch(".", init=True)
18
from bzrlib.branch import Branch
19
from bzrlib.clone import copy_branch
20
from bzrlib.commit import commit
21
from bzrlib.errors import NoSuchRevision, UnlistableBranch
22
from bzrlib.selftest import TestCaseInTempDir
23
from bzrlib.trace import mutter
25
class TestBranch(TestCaseInTempDir):
27
def test_append_revisions(self):
28
"""Test appending more than one revision"""
29
br = Branch.initialize(".")
26
30
br.append_revision("rev1")
27
31
self.assertEquals(br.revision_history(), ["rev1",])
28
32
br.append_revision("rev2", "rev3")
29
33
self.assertEquals(br.revision_history(), ["rev1", "rev2", "rev3"])
36
class TestFetch(TestCaseInTempDir):
38
def test_fetch_revisions(self):
39
"""Test fetch-revision operation."""
40
from bzrlib.fetch import Fetcher
43
b1 = Branch.initialize('b1')
44
b2 = Branch.initialize('b2')
45
file(os.sep.join(['b1', 'foo']), 'w').write('hello')
46
b1.add(['foo'], ['foo-id'])
47
b1.commit('lala!', rev_id='revision-1', allow_pointless=False)
50
f = Fetcher(from_branch=b1, to_branch=b2)
51
eq = self.assertEquals
53
eq(f.last_revision, 'revision-1')
55
rev = b2.get_revision('revision-1')
56
tree = b2.revision_tree('revision-1')
57
eq(tree.get_file_text('foo-id'), 'hello')
59
def test_push_stores(self):
60
"""Copy the stores from one branch to another"""
62
br_a = Branch.initialize("a")
63
file('a/b', 'wb').write('b')
65
commit(br_a, "silly commit")
68
br_b = Branch.initialize("b")
69
self.assertRaises(NoSuchRevision, br_b.get_revision,
70
br_a.revision_history()[0])
71
br_a.push_stores(br_b)
72
rev = br_b.get_revision(br_a.revision_history()[0])
73
tree = br_b.revision_tree(br_a.revision_history()[0])
75
if tree.inventory[file_id].kind == "file":
76
tree.get_file(file_id).read()
79
def test_copy_branch(self):
80
"""Copy the stores from one branch to another"""
81
br_a, br_b = self.test_push_stores()
82
commit(br_b, "silly commit")
84
br_c = copy_branch(br_a, 'c', basis_branch=br_b)
85
self.assertEqual(br_a.revision_history(), br_c.revision_history())
86
assert br_b.last_revision() not in br_c.revision_history()
87
br_c.get_revision(br_b.last_revision())
88
# TODO: rewrite this as a regular unittest, without relying on the displayed output
89
# >>> from bzrlib.commit import commit
90
# >>> bzrlib.trace.silent = True
91
# >>> br1 = ScratchBranch(files=['foo', 'bar'])
94
# >>> commit(br1, "lala!", rev_id="REVISION-ID-1", verbose=False)
95
# >>> br2 = ScratchBranch()
96
# >>> br2.update_revisions(br1)
98
# Added 1 inventories.
100
# >>> br2.revision_history()
102
# >>> br2.update_revisions(br1)
104
# >>> br1.text_store.total_size() == br2.text_store.total_size()