19
19
This file contains canned versions of some old trees, which are instantiated
20
20
and then upgraded to the new format."""
22
# TODO queue for upgrade:
23
# test the error message when upgrading an unknown BzrDir format.
26
from bzrlib.tests import TestCase, TestCaseInTempDir
27
30
from bzrlib.branch import Branch
31
import bzrlib.bzrdir as bzrdir
32
import bzrlib.repository as repository
28
33
from bzrlib.revision import is_ancestor
34
from bzrlib.tests import TestCase, TestCaseInTempDir
35
from bzrlib.transport import get_transport
29
36
from bzrlib.upgrade import upgrade
37
import bzrlib.workingtree as workingtree
32
40
class TestUpgrade(TestCaseInTempDir):
42
50
eq = self.assertEquals
43
51
self.build_tree_contents(_upgrade1_template)
46
eq(b._branch_format, 6)
53
control = bzrdir.BzrDir.open('.')
54
b = control.open_branch()
55
r = control.open_repository()
56
t = control.open_workingtree()
57
# tsk, peeking under the covers.
58
self.failUnless(isinstance(control._format, bzrdir.BzrDirFormat6))
59
self.failUnless(isinstance(b._format, bzrlib.branch.BzrBranchFormat4))
60
self.failUnless(isinstance(r._format, repository.RepositoryFormat6))
61
self.failUnless(isinstance(t._format, workingtree.WorkingTreeFormat2))
47
62
rh = b.revision_history()
49
64
['mbp@sourcefrog.net-20051004035611-176b16534b086b3c',
50
65
'mbp@sourcefrog.net-20051004035756-235f2b7dcdddd8dd'])
51
t = b.revision_tree(rh[0])
66
rt = b.repository.revision_tree(rh[0])
52
67
foo_id = 'foo-20051004035605-91e788d1875603ae'
53
eq(t.get_file_text(foo_id), 'initial contents\n')
54
t = b.revision_tree(rh[1])
55
eq(t.get_file_text(foo_id), 'new contents\n')
68
eq(rt.get_file_text(foo_id), 'initial contents\n')
69
rt = b.repository.revision_tree(rh[1])
70
eq(rt.get_file_text(foo_id), 'new contents\n')
71
# check a backup was made:
72
transport = get_transport(b.base)
73
transport.stat('.bzr.backup')
74
transport.stat('.bzr.backup/README')
75
transport.stat('.bzr.backup/branch-format')
76
transport.stat('.bzr.backup/revision-history')
77
transport.stat('.bzr.backup/merged-patches')
78
transport.stat('.bzr.backup/pending-merged-patches')
79
transport.stat('.bzr.backup/pending-merges')
80
transport.stat('.bzr.backup/branch-name')
81
transport.stat('.bzr.backup/branch-lock')
82
transport.stat('.bzr.backup/inventory')
83
transport.stat('.bzr.backup/stat-cache')
84
transport.stat('.bzr.backup/text-store')
85
transport.stat('.bzr.backup/text-store/foo-20051004035611-1591048e9dc7c2d4.gz')
86
transport.stat('.bzr.backup/text-store/foo-20051004035756-4081373d897c3453.gz')
87
transport.stat('.bzr.backup/inventory-store/')
88
transport.stat('.bzr.backup/inventory-store/mbp@sourcefrog.net-20051004035611-176b16534b086b3c.gz')
89
transport.stat('.bzr.backup/inventory-store/mbp@sourcefrog.net-20051004035756-235f2b7dcdddd8dd.gz')
90
transport.stat('.bzr.backup/revision-store/')
91
transport.stat('.bzr.backup/revision-store/mbp@sourcefrog.net-20051004035611-176b16534b086b3c.gz')
92
transport.stat('.bzr.backup/revision-store/mbp@sourcefrog.net-20051004035756-235f2b7dcdddd8dd.gz')
57
94
def test_upgrade_with_ghosts(self):
58
95
"""Upgrade v0.0.4 tree containing ghost references.
60
97
That is, some of the parents of revisions mentioned in the branch
61
aren't present in the branches storage.
98
aren't present in the branch's storage.
63
100
This shouldn't normally happen in branches created entirely in
64
bzr but can happen in imports from baz and arch, or from other
65
systems, where the importer knows about a revision but not
101
bzr, but can happen in branches imported from baz and arch, or from
102
other systems, where the importer knows about a revision but not
67
104
eq = self.assertEquals
68
105
self.build_tree_contents(_ghost_template)
70
107
b = Branch.open(u'.')
71
108
revision_id = b.revision_history()[1]
72
rev = b.get_revision(revision_id)
109
rev = b.repository.get_revision(revision_id)
73
110
eq(len(rev.parent_ids), 2)
74
111
eq(rev.parent_ids[1], 'wibble@wobble-2')