67
63
'mbp@sourcefrog.net-20051004035756-235f2b7dcdddd8dd'])
68
64
rt = b.repository.revision_tree(rh[0])
69
65
foo_id = 'foo-20051004035605-91e788d1875603ae'
72
eq(rt.get_file_text(foo_id), 'initial contents\n')
66
eq(rt.get_file_text(foo_id), 'initial contents\n')
75
67
rt = b.repository.revision_tree(rh[1])
78
eq(rt.get_file_text(foo_id), 'new contents\n')
68
eq(rt.get_file_text(foo_id), 'new contents\n')
81
69
# check a backup was made:
82
70
transport = get_transport(b.base)
83
transport.stat('backup.bzr')
84
transport.stat('backup.bzr/README')
85
transport.stat('backup.bzr/branch-format')
86
transport.stat('backup.bzr/revision-history')
87
transport.stat('backup.bzr/merged-patches')
88
transport.stat('backup.bzr/pending-merged-patches')
89
transport.stat('backup.bzr/pending-merges')
90
transport.stat('backup.bzr/branch-name')
91
transport.stat('backup.bzr/branch-lock')
92
transport.stat('backup.bzr/inventory')
93
transport.stat('backup.bzr/stat-cache')
94
transport.stat('backup.bzr/text-store')
95
transport.stat('backup.bzr/text-store/foo-20051004035611-1591048e9dc7c2d4.gz')
96
transport.stat('backup.bzr/text-store/foo-20051004035756-4081373d897c3453.gz')
97
transport.stat('backup.bzr/inventory-store/')
98
transport.stat('backup.bzr/inventory-store/mbp@sourcefrog.net-20051004035611-176b16534b086b3c.gz')
99
transport.stat('backup.bzr/inventory-store/mbp@sourcefrog.net-20051004035756-235f2b7dcdddd8dd.gz')
100
transport.stat('backup.bzr/revision-store/')
101
transport.stat('backup.bzr/revision-store/mbp@sourcefrog.net-20051004035611-176b16534b086b3c.gz')
102
transport.stat('backup.bzr/revision-store/mbp@sourcefrog.net-20051004035756-235f2b7dcdddd8dd.gz')
71
transport.stat('.bzr.backup')
72
transport.stat('.bzr.backup/README')
73
transport.stat('.bzr.backup/branch-format')
74
transport.stat('.bzr.backup/revision-history')
75
transport.stat('.bzr.backup/merged-patches')
76
transport.stat('.bzr.backup/pending-merged-patches')
77
transport.stat('.bzr.backup/pending-merges')
78
transport.stat('.bzr.backup/branch-name')
79
transport.stat('.bzr.backup/branch-lock')
80
transport.stat('.bzr.backup/inventory')
81
transport.stat('.bzr.backup/stat-cache')
82
transport.stat('.bzr.backup/text-store')
83
transport.stat('.bzr.backup/text-store/foo-20051004035611-1591048e9dc7c2d4.gz')
84
transport.stat('.bzr.backup/text-store/foo-20051004035756-4081373d897c3453.gz')
85
transport.stat('.bzr.backup/inventory-store/')
86
transport.stat('.bzr.backup/inventory-store/mbp@sourcefrog.net-20051004035611-176b16534b086b3c.gz')
87
transport.stat('.bzr.backup/inventory-store/mbp@sourcefrog.net-20051004035756-235f2b7dcdddd8dd.gz')
88
transport.stat('.bzr.backup/revision-store/')
89
transport.stat('.bzr.backup/revision-store/mbp@sourcefrog.net-20051004035611-176b16534b086b3c.gz')
90
transport.stat('.bzr.backup/revision-store/mbp@sourcefrog.net-20051004035756-235f2b7dcdddd8dd.gz')
104
92
def test_upgrade_with_ghosts(self):
105
93
"""Upgrade v0.0.4 tree containing ghost references.
107
95
That is, some of the parents of revisions mentioned in the branch
108
aren't present in the branch's storage.
96
aren't present in the branch's storage.
110
This shouldn't normally happen in branches created entirely in
98
This shouldn't normally happen in branches created entirely in
111
99
bzr, but can happen in branches imported from baz and arch, or from
112
other systems, where the importer knows about a revision but not
100
other systems, where the importer knows about a revision but not
114
102
eq = self.assertEquals
115
103
self.build_tree_contents(_ghost_template)
125
113
old_repodir = bzrlib.bzrdir.BzrDir.open_unsupported('.')
126
114
old_repo_format = old_repodir.open_repository()._format
128
# this is the path to the literal file. As format changes
116
# this is the path to the literal file. As format changes
129
117
# occur it needs to be updated. FIXME: ask the store for the
131
119
repo = bzrlib.repository.Repository.open('.')
132
120
# it should have changed the format
133
121
self.assertNotEqual(old_repo_format.__class__, repo._format.__class__)
134
# and we should be able to read the names for the file id
122
# and we should be able to read the names for the file id
135
123
# 'dir-20051005095101-da1441ea3fa6917a'
137
self.addCleanup(repo.unlock)
138
text_keys = repo.texts.keys()
139
dir_keys = [key for key in text_keys if key[0] ==
140
'dir-20051005095101-da1441ea3fa6917a']
141
self.assertNotEqual([], dir_keys)
126
repo.text_store.get_weave(
127
'dir-20051005095101-da1441ea3fa6917a',
128
repo.get_transaction()))
143
130
def test_upgrade_to_meta_sets_workingtree_last_revision(self):
144
131
self.build_tree_contents(_upgrade_dir_template)
145
132
upgrade('.', bzrdir.BzrDirMetaFormat1())
146
133
tree = workingtree.WorkingTree.open('.')
147
self.assertEqual([tree.branch.revision_history()[-1]],
148
tree.get_parent_ids())
150
def test_upgrade_v6_to_meta_no_workingtree(self):
151
# Some format6 branches do not have checkout files. Upgrading
152
# such a branch to metadir must not setup a working tree.
153
self.build_tree_contents(_upgrade1_template)
154
upgrade('.', bzrdir.BzrDirFormat6())
155
transport = get_transport('.')
156
transport.delete_multi(['.bzr/pending-merges', '.bzr/inventory'])
157
self.assertFalse(transport.has('.bzr/stat-cache'))
158
# XXX: upgrade fails if a backup.bzr is already present
159
# -- David Allouche 2006-08-11
160
transport.delete_tree('backup.bzr')
161
# At this point, we have a format6 branch without checkout files.
162
upgrade('.', bzrdir.BzrDirMetaFormat1())
163
# The upgrade should not have set up a working tree.
164
control = bzrdir.BzrDir.open('.')
165
self.assertFalse(control.has_workingtree())
166
# We have covered the scope of this test, we may as well check that
167
# upgrade has not eaten our data, even if it's a bit redundant with
169
self.failUnless(isinstance(control._format, bzrdir.BzrDirMetaFormat1))
170
branch = control.open_branch()
171
self.assertEquals(branch.revision_history(),
172
['mbp@sourcefrog.net-20051004035611-176b16534b086b3c',
173
'mbp@sourcefrog.net-20051004035756-235f2b7dcdddd8dd'])
175
def test_upgrade_rich_root(self):
176
tree = self.make_branch_and_tree('tree', format='rich-root')
177
rev_id = tree.commit('first post')
180
def test_convert_branch5_branch6(self):
181
branch = self.make_branch('branch', format='knit')
182
branch.set_revision_history(['AB', 'CD'])
183
branch.set_parent('file:///EF')
184
branch.set_bound_location('file:///GH')
185
branch.set_push_location('file:///IJ')
186
target = bzrdir.format_registry.make_bzrdir('dirstate-with-subtree')
187
converter = branch.bzrdir._format.get_converter(target)
188
converter.convert(branch.bzrdir, None)
189
new_branch = _mod_branch.Branch.open(self.get_url('branch'))
190
self.assertIs(new_branch.__class__, _mod_branch.BzrBranch6)
191
self.assertEqual('CD', new_branch.last_revision())
192
self.assertEqual('file:///EF', new_branch.get_parent())
193
self.assertEqual('file:///GH', new_branch.get_bound_location())
194
branch_config = new_branch.get_config()._get_branch_data_config()
195
self.assertEqual('file:///IJ',
196
branch_config.get_user_option('push_location'))
198
branch2 = self.make_branch('branch2', format='knit')
199
converter = branch2.bzrdir._format.get_converter(target)
200
converter.convert(branch2.bzrdir, None)
201
branch2 = _mod_branch.Branch.open(self.get_url('branch'))
202
self.assertIs(branch2.__class__, _mod_branch.BzrBranch6)
204
def test_convert_branch7_branch8(self):
205
branch = self.make_branch('branch', format='1.9')
206
target = bzrdir.format_registry.make_bzrdir('1.9')
207
target.set_branch_format(_mod_branch.BzrBranchFormat8())
208
converter = branch.bzrdir._format.get_converter(target)
209
converter.convert(branch.bzrdir, None)
210
branch = _mod_branch.Branch.open(self.get_url('branch'))
211
self.assertIs(branch.__class__, _mod_branch.BzrBranch8)
212
self.assertEqual({}, branch._get_all_reference_info())
214
def test_convert_knit_dirstate_empty(self):
215
# test that asking for an upgrade from knit to dirstate works.
216
tree = self.make_branch_and_tree('tree', format='knit')
217
target = bzrdir.format_registry.make_bzrdir('dirstate')
218
converter = tree.bzrdir._format.get_converter(target)
219
converter.convert(tree.bzrdir, None)
220
new_tree = workingtree.WorkingTree.open('tree')
221
self.assertIs(new_tree.__class__, workingtree_4.WorkingTree4)
222
self.assertEqual('null:', new_tree.last_revision())
224
def test_convert_knit_dirstate_content(self):
225
# smoke test for dirstate conversion: we call dirstate primitives,
226
# and its there that the core logic is tested.
227
tree = self.make_branch_and_tree('tree', format='knit')
228
self.build_tree(['tree/file'])
229
tree.add(['file'], ['file-id'])
230
target = bzrdir.format_registry.make_bzrdir('dirstate')
231
converter = tree.bzrdir._format.get_converter(target)
232
converter.convert(tree.bzrdir, None)
233
new_tree = workingtree.WorkingTree.open('tree')
234
self.assertIs(new_tree.__class__, workingtree_4.WorkingTree4)
235
self.assertEqual('null:', new_tree.last_revision())
237
def test_convert_knit_one_parent_dirstate(self):
238
# test that asking for an upgrade from knit to dirstate works.
239
tree = self.make_branch_and_tree('tree', format='knit')
240
rev_id = tree.commit('first post')
241
target = bzrdir.format_registry.make_bzrdir('dirstate')
242
converter = tree.bzrdir._format.get_converter(target)
243
converter.convert(tree.bzrdir, None)
244
new_tree = workingtree.WorkingTree.open('tree')
245
self.assertIs(new_tree.__class__, workingtree_4.WorkingTree4)
246
self.assertEqual(rev_id, new_tree.last_revision())
247
for path in ['basis-inventory-cache', 'inventory', 'last-revision',
248
'pending-merges', 'stat-cache']:
249
self.failIfExists('tree/.bzr/checkout/' + path)
251
def test_convert_knit_merges_dirstate(self):
252
tree = self.make_branch_and_tree('tree', format='knit')
253
rev_id = tree.commit('first post')
254
merge_tree = tree.bzrdir.sprout('tree2').open_workingtree()
255
rev_id2 = tree.commit('second post')
256
rev_id3 = merge_tree.commit('second merge post')
257
tree.merge_from_branch(merge_tree.branch)
258
target = bzrdir.format_registry.make_bzrdir('dirstate')
259
converter = tree.bzrdir._format.get_converter(target)
260
converter.convert(tree.bzrdir, None)
261
new_tree = workingtree.WorkingTree.open('tree')
262
self.assertIs(new_tree.__class__, workingtree_4.WorkingTree4)
263
self.assertEqual(rev_id2, new_tree.last_revision())
264
self.assertEqual([rev_id2, rev_id3], new_tree.get_parent_ids())
265
for path in ['basis-inventory-cache', 'inventory', 'last-revision',
266
'pending-merges', 'stat-cache']:
267
self.failIfExists('tree/.bzr/checkout/' + path)
134
self.assertEqual(tree.last_revision(),
135
tree.branch.revision_history()[-1])
270
138
_upgrade1_template = \