13
13
# You should have received a copy of the GNU General Public License
14
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
15
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
17
17
"""Tests for upgrade of old trees.
19
This file contains canned versions of some old trees, which are instantiated
19
This file contains canned versions of some old trees, which are instantiated
20
20
and then upgraded to the new format."""
22
22
# TODO queue for upgrade:
67
67
'mbp@sourcefrog.net-20051004035756-235f2b7dcdddd8dd'])
68
68
rt = b.repository.revision_tree(rh[0])
69
69
foo_id = 'foo-20051004035605-91e788d1875603ae'
70
eq(rt.get_file_text(foo_id), 'initial contents\n')
72
eq(rt.get_file_text(foo_id), 'initial contents\n')
71
75
rt = b.repository.revision_tree(rh[1])
72
eq(rt.get_file_text(foo_id), 'new contents\n')
78
eq(rt.get_file_text(foo_id), 'new contents\n')
73
81
# check a backup was made:
74
82
transport = get_transport(b.base)
75
transport.stat('.bzr.backup')
76
transport.stat('.bzr.backup/README')
77
transport.stat('.bzr.backup/branch-format')
78
transport.stat('.bzr.backup/revision-history')
79
transport.stat('.bzr.backup/merged-patches')
80
transport.stat('.bzr.backup/pending-merged-patches')
81
transport.stat('.bzr.backup/pending-merges')
82
transport.stat('.bzr.backup/branch-name')
83
transport.stat('.bzr.backup/branch-lock')
84
transport.stat('.bzr.backup/inventory')
85
transport.stat('.bzr.backup/stat-cache')
86
transport.stat('.bzr.backup/text-store')
87
transport.stat('.bzr.backup/text-store/foo-20051004035611-1591048e9dc7c2d4.gz')
88
transport.stat('.bzr.backup/text-store/foo-20051004035756-4081373d897c3453.gz')
89
transport.stat('.bzr.backup/inventory-store/')
90
transport.stat('.bzr.backup/inventory-store/mbp@sourcefrog.net-20051004035611-176b16534b086b3c.gz')
91
transport.stat('.bzr.backup/inventory-store/mbp@sourcefrog.net-20051004035756-235f2b7dcdddd8dd.gz')
92
transport.stat('.bzr.backup/revision-store/')
93
transport.stat('.bzr.backup/revision-store/mbp@sourcefrog.net-20051004035611-176b16534b086b3c.gz')
94
transport.stat('.bzr.backup/revision-store/mbp@sourcefrog.net-20051004035756-235f2b7dcdddd8dd.gz')
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')
96
104
def test_upgrade_with_ghosts(self):
97
105
"""Upgrade v0.0.4 tree containing ghost references.
99
107
That is, some of the parents of revisions mentioned in the branch
100
aren't present in the branch's storage.
108
aren't present in the branch's storage.
102
This shouldn't normally happen in branches created entirely in
110
This shouldn't normally happen in branches created entirely in
103
111
bzr, but can happen in branches imported from baz and arch, or from
104
other systems, where the importer knows about a revision but not
112
other systems, where the importer knows about a revision but not
106
114
eq = self.assertEquals
107
115
self.build_tree_contents(_ghost_template)
117
125
old_repodir = bzrlib.bzrdir.BzrDir.open_unsupported('.')
118
126
old_repo_format = old_repodir.open_repository()._format
120
# this is the path to the literal file. As format changes
128
# this is the path to the literal file. As format changes
121
129
# occur it needs to be updated. FIXME: ask the store for the
123
131
repo = bzrlib.repository.Repository.open('.')
124
132
# it should have changed the format
125
133
self.assertNotEqual(old_repo_format.__class__, repo._format.__class__)
126
# and we should be able to read the names for the file id
134
# and we should be able to read the names for the file id
127
135
# 'dir-20051005095101-da1441ea3fa6917a'
130
repo.text_store.get_weave(
131
'dir-20051005095101-da1441ea3fa6917a',
132
repo.get_transaction()))
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)
134
143
def test_upgrade_to_meta_sets_workingtree_last_revision(self):
135
144
self.build_tree_contents(_upgrade_dir_template)
145
154
upgrade('.', bzrdir.BzrDirFormat6())
146
155
transport = get_transport('.')
147
156
transport.delete_multi(['.bzr/pending-merges', '.bzr/inventory'])
148
assert not transport.has('.bzr/stat-cache')
149
# XXX: upgrade fails if a .bzr.backup is already present
157
self.assertFalse(transport.has('.bzr/stat-cache'))
158
# XXX: upgrade fails if a backup.bzr is already present
150
159
# -- David Allouche 2006-08-11
151
transport.delete_tree('.bzr.backup')
160
transport.delete_tree('backup.bzr')
152
161
# At this point, we have a format6 branch without checkout files.
153
162
upgrade('.', bzrdir.BzrDirMetaFormat1())
154
163
# The upgrade should not have set up a working tree.
187
201
branch2 = _mod_branch.Branch.open(self.get_url('branch'))
188
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, progress.DummyProgress())
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())
190
214
def test_convert_knit_dirstate_empty(self):
191
215
# test that asking for an upgrade from knit to dirstate works.
192
216
tree = self.make_branch_and_tree('tree', format='knit')
248
272
('foo', 'new contents\n'),
251
'This is a Bazaar-NG control directory.\nDo not change any files in this directory.\n'),
275
'This is a Bazaar control directory.\n'
276
'Do not change any files in this directory.\n'
277
'See http://bazaar-vcs.org/ for more information about Bazaar.\n'),
252
278
('.bzr/branch-format', 'Bazaar-NG branch, format 0.0.4\n'),
253
279
('.bzr/revision-history',
254
280
'mbp@sourcefrog.net-20051004035611-176b16534b086b3c\n'