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
backup_dir = 'backup.bzr.~1~'
83
70
transport = get_transport(b.base)
84
transport.stat(backup_dir)
85
transport.stat(backup_dir + '/README')
86
transport.stat(backup_dir + '/branch-format')
87
transport.stat(backup_dir + '/revision-history')
88
transport.stat(backup_dir + '/merged-patches')
89
transport.stat(backup_dir + '/pending-merged-patches')
90
transport.stat(backup_dir + '/pending-merges')
91
transport.stat(backup_dir + '/branch-name')
92
transport.stat(backup_dir + '/branch-lock')
93
transport.stat(backup_dir + '/inventory')
94
transport.stat(backup_dir + '/stat-cache')
95
transport.stat(backup_dir + '/text-store')
96
transport.stat(backup_dir + '/text-store/foo-20051004035611-1591048e9dc7c2d4.gz')
97
transport.stat(backup_dir + '/text-store/foo-20051004035756-4081373d897c3453.gz')
98
transport.stat(backup_dir + '/inventory-store/')
99
transport.stat(backup_dir + '/inventory-store/mbp@sourcefrog.net-20051004035611-176b16534b086b3c.gz')
100
transport.stat(backup_dir + '/inventory-store/mbp@sourcefrog.net-20051004035756-235f2b7dcdddd8dd.gz')
101
transport.stat(backup_dir + '/revision-store/')
102
transport.stat(backup_dir + '/revision-store/mbp@sourcefrog.net-20051004035611-176b16534b086b3c.gz')
103
transport.stat(backup_dir + '/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')
105
92
def test_upgrade_with_ghosts(self):
106
93
"""Upgrade v0.0.4 tree containing ghost references.
108
95
That is, some of the parents of revisions mentioned in the branch
109
aren't present in the branch's storage.
96
aren't present in the branch's storage.
111
This shouldn't normally happen in branches created entirely in
98
This shouldn't normally happen in branches created entirely in
112
99
bzr, but can happen in branches imported from baz and arch, or from
113
other systems, where the importer knows about a revision but not
100
other systems, where the importer knows about a revision but not
115
102
eq = self.assertEquals
116
103
self.build_tree_contents(_ghost_template)
126
113
old_repodir = bzrlib.bzrdir.BzrDir.open_unsupported('.')
127
114
old_repo_format = old_repodir.open_repository()._format
129
# this is the path to the literal file. As format changes
116
# this is the path to the literal file. As format changes
130
117
# occur it needs to be updated. FIXME: ask the store for the
132
119
repo = bzrlib.repository.Repository.open('.')
133
120
# it should have changed the format
134
121
self.assertNotEqual(old_repo_format.__class__, repo._format.__class__)
135
# 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
136
123
# 'dir-20051005095101-da1441ea3fa6917a'
138
self.addCleanup(repo.unlock)
139
text_keys = repo.texts.keys()
140
dir_keys = [key for key in text_keys if key[0] ==
141
'dir-20051005095101-da1441ea3fa6917a']
142
self.assertNotEqual([], dir_keys)
126
repo.text_store.get_weave(
127
'dir-20051005095101-da1441ea3fa6917a',
128
repo.get_transaction()))
144
130
def test_upgrade_to_meta_sets_workingtree_last_revision(self):
145
131
self.build_tree_contents(_upgrade_dir_template)
146
132
upgrade('.', bzrdir.BzrDirMetaFormat1())
147
133
tree = workingtree.WorkingTree.open('.')
148
self.assertEqual([tree.branch.revision_history()[-1]],
149
tree.get_parent_ids())
134
self.assertEqual(tree.last_revision(),
135
tree.branch.revision_history()[-1])
151
137
def test_upgrade_v6_to_meta_no_workingtree(self):
152
138
# Some format6 branches do not have checkout files. Upgrading
173
159
['mbp@sourcefrog.net-20051004035611-176b16534b086b3c',
174
160
'mbp@sourcefrog.net-20051004035756-235f2b7dcdddd8dd'])
176
def test_upgrade_rich_root(self):
177
tree = self.make_branch_and_tree('tree', format='rich-root')
178
rev_id = tree.commit('first post')
181
def test_convert_branch5_branch6(self):
182
branch = self.make_branch('branch', format='knit')
183
branch.set_revision_history(['AB', 'CD'])
184
branch.set_parent('file:///EF')
185
branch.set_bound_location('file:///GH')
186
branch.set_push_location('file:///IJ')
187
target = bzrdir.format_registry.make_bzrdir('dirstate-with-subtree')
188
converter = branch.bzrdir._format.get_converter(target)
189
converter.convert(branch.bzrdir, None)
190
new_branch = _mod_branch.Branch.open(self.get_url('branch'))
191
self.assertIs(new_branch.__class__, _mod_branch.BzrBranch6)
192
self.assertEqual('CD', new_branch.last_revision())
193
self.assertEqual('file:///EF', new_branch.get_parent())
194
self.assertEqual('file:///GH', new_branch.get_bound_location())
195
branch_config = new_branch.get_config()._get_branch_data_config()
196
self.assertEqual('file:///IJ',
197
branch_config.get_user_option('push_location'))
199
branch2 = self.make_branch('branch2', format='knit')
200
converter = branch2.bzrdir._format.get_converter(target)
201
converter.convert(branch2.bzrdir, None)
202
branch2 = _mod_branch.Branch.open(self.get_url('branch'))
203
self.assertIs(branch2.__class__, _mod_branch.BzrBranch6)
205
def test_convert_branch7_branch8(self):
206
branch = self.make_branch('branch', format='1.9')
207
target = bzrdir.format_registry.make_bzrdir('1.9')
208
target.set_branch_format(_mod_branch.BzrBranchFormat8())
209
converter = branch.bzrdir._format.get_converter(target)
210
converter.convert(branch.bzrdir, None)
211
branch = _mod_branch.Branch.open(self.get_url('branch'))
212
self.assertIs(branch.__class__, _mod_branch.BzrBranch8)
213
self.assertEqual({}, branch._get_all_reference_info())
215
def test_convert_knit_dirstate_empty(self):
216
# test that asking for an upgrade from knit to dirstate works.
217
tree = self.make_branch_and_tree('tree', format='knit')
218
target = bzrdir.format_registry.make_bzrdir('dirstate')
219
converter = tree.bzrdir._format.get_converter(target)
220
converter.convert(tree.bzrdir, None)
221
new_tree = workingtree.WorkingTree.open('tree')
222
self.assertIs(new_tree.__class__, workingtree_4.WorkingTree4)
223
self.assertEqual('null:', new_tree.last_revision())
225
def test_convert_knit_dirstate_content(self):
226
# smoke test for dirstate conversion: we call dirstate primitives,
227
# and its there that the core logic is tested.
228
tree = self.make_branch_and_tree('tree', format='knit')
229
self.build_tree(['tree/file'])
230
tree.add(['file'], ['file-id'])
231
target = bzrdir.format_registry.make_bzrdir('dirstate')
232
converter = tree.bzrdir._format.get_converter(target)
233
converter.convert(tree.bzrdir, None)
234
new_tree = workingtree.WorkingTree.open('tree')
235
self.assertIs(new_tree.__class__, workingtree_4.WorkingTree4)
236
self.assertEqual('null:', new_tree.last_revision())
238
def test_convert_knit_one_parent_dirstate(self):
239
# test that asking for an upgrade from knit to dirstate works.
240
tree = self.make_branch_and_tree('tree', format='knit')
241
rev_id = tree.commit('first post')
242
target = bzrdir.format_registry.make_bzrdir('dirstate')
243
converter = tree.bzrdir._format.get_converter(target)
244
converter.convert(tree.bzrdir, None)
245
new_tree = workingtree.WorkingTree.open('tree')
246
self.assertIs(new_tree.__class__, workingtree_4.WorkingTree4)
247
self.assertEqual(rev_id, new_tree.last_revision())
248
for path in ['basis-inventory-cache', 'inventory', 'last-revision',
249
'pending-merges', 'stat-cache']:
250
self.failIfExists('tree/.bzr/checkout/' + path)
252
def test_convert_knit_merges_dirstate(self):
253
tree = self.make_branch_and_tree('tree', format='knit')
254
rev_id = tree.commit('first post')
255
merge_tree = tree.bzrdir.sprout('tree2').open_workingtree()
256
rev_id2 = tree.commit('second post')
257
rev_id3 = merge_tree.commit('second merge post')
258
tree.merge_from_branch(merge_tree.branch)
259
target = bzrdir.format_registry.make_bzrdir('dirstate')
260
converter = tree.bzrdir._format.get_converter(target)
261
converter.convert(tree.bzrdir, None)
262
new_tree = workingtree.WorkingTree.open('tree')
263
self.assertIs(new_tree.__class__, workingtree_4.WorkingTree4)
264
self.assertEqual(rev_id2, new_tree.last_revision())
265
self.assertEqual([rev_id2, rev_id3], new_tree.get_parent_ids())
266
for path in ['basis-inventory-cache', 'inventory', 'last-revision',
267
'pending-merges', 'stat-cache']:
268
self.failIfExists('tree/.bzr/checkout/' + path)
271
163
_upgrade1_template = \
273
165
('foo', 'new contents\n'),
276
'This is a Bazaar control directory.\n'
277
'Do not change any files in this directory.\n'
278
'See http://bazaar-vcs.org/ for more information about Bazaar.\n'),
168
'This is a Bazaar-NG control directory.\nDo not change any files in this directory.\n'),
279
169
('.bzr/branch-format', 'Bazaar-NG branch, format 0.0.4\n'),
280
170
('.bzr/revision-history',
281
171
'mbp@sourcefrog.net-20051004035611-176b16534b086b3c\n'