28
from bzrlib.tests import (
30
TestCaseWithTransport,
24
import bzrlib.bzrdir as bzrdir
25
import bzrlib.repository as repository
26
from bzrlib.tests import TestCaseWithTransport
27
from bzrlib.tests.blackbox import TestUIFactory
33
28
from bzrlib.tests.test_sftp_transport import TestCaseWithSFTPServer
34
29
from bzrlib.transport import get_transport
35
from bzrlib.repofmt.knitrepo import (
36
RepositoryFormatKnit1,
30
import bzrlib.ui as ui
40
33
class TestWithUpgradableBranches(TestCaseWithTransport):
43
36
super(TestWithUpgradableBranches, self).setUp()
44
37
self.old_format = bzrdir.BzrDirFormat.get_default_format()
38
self.old_repo_format = \
39
bzrlib.repository.RepositoryFormat.get_default_format()
45
40
self.old_ui_factory = ui.ui_factory
46
41
self.addCleanup(self.restoreDefaults)
48
43
ui.ui_factory = TestUIFactory()
44
bzrdir.BzrDirFormat.set_default_format(bzrdir.BzrDirMetaFormat1())
45
bzrlib.repository.RepositoryFormat.set_default_format(
46
bzrlib.repository.RepositoryFormat7())
47
# FIXME RBC 20060120 we should be able to do this via ui calls only.
49
48
# setup a format 5 branch we can upgrade from.
50
self.make_branch_and_tree('format_5_branch',
51
format=bzrdir.BzrDirFormat5())
53
current_tree = self.make_branch_and_tree('current_format_branch',
55
self.make_branch_and_tree('metadir_weave_branch', format='metaweave')
56
current_tree.branch.create_checkout(
57
self.get_url('current_format_checkout'), lightweight=True)
49
t = get_transport(self.get_url())
50
t.mkdir('format_5_branch')
51
bzrdir.BzrDirFormat5().initialize(self.get_url('format_5_branch'))
52
bzrdir.BzrDir.create_standalone_workingtree('current_format_branch')
53
d = bzrdir.BzrDir.create('metadir_weave_branch')
56
d.create_workingtree()
57
self.run_bzr('checkout',
59
self.get_url('current_format_branch'),
60
'current_format_checkout')
59
62
def restoreDefaults(self):
63
bzrdir.BzrDirFormat.set_default_format(self.old_format)
64
bzrlib.repository.RepositoryFormat.set_default_format(
60
66
ui.ui_factory = self.old_ui_factory
61
bzrdir.BzrDirFormat._set_default_format(self.old_format)
63
68
def test_readonly_url_error(self):
64
(out, err) = self.run_bzr(
65
['upgrade', self.get_readonly_url('format_5_branch')], retcode=3)
69
(out, err) = self.run_bzr_captured(
70
['upgrade', self.get_readonly_url('format_5_branch')], 3)
66
71
self.assertEqual(out, "")
67
self.assertEqual(err, "bzr: ERROR: Upgrade URL cannot work with readonly URLs.\n")
72
self.assertEqual(err, "bzr: ERROR: Upgrade URL cannot work with readonly URL's.\n")
69
74
def test_upgrade_up_to_date(self):
70
75
# when up to date we should get a message to that effect
71
(out, err) = self.run_bzr('upgrade current_format_branch', retcode=3)
76
(out, err) = self.run_bzr_captured(
77
['upgrade', 'current_format_branch'], 3)
72
78
self.assertEqual("", out)
73
79
self.assertEqualDiff("bzr: ERROR: The branch format Bazaar-NG meta "
74
80
"directory, format 1 is already at the most "
78
84
# when upgrading a checkout, the branch location and a suggestion
79
85
# to upgrade it should be emitted even if the checkout is up to
81
(out, err) = self.run_bzr('upgrade current_format_checkout', retcode=3)
87
(out, err) = self.run_bzr_captured(
88
['upgrade', 'current_format_checkout'], 3)
82
89
self.assertEqual("This is a checkout. The branch (%s) needs to be "
83
"upgraded separately.\n"
90
"upgraded separately.\n"
84
91
% get_transport(self.get_url('current_format_branch')).base,
86
93
self.assertEqualDiff("bzr: ERROR: The branch format Bazaar-NG meta "
104
111
# users can force an upgrade to metadir format.
105
112
url = get_transport(self.get_url('format_5_branch')).base
106
113
# check --format takes effect
107
bzrdir.BzrDirFormat._set_default_format(bzrdir.BzrDirFormat5())
108
(out, err) = self.run_bzr(
114
bzrdir.BzrDirFormat.set_default_format(bzrdir.BzrDirFormat5())
115
(out, err) = self.run_bzr_captured(
109
116
['upgrade', '--format=metaweave', url])
110
117
self.assertEqualDiff("""starting upgrade of %s
111
118
making backup of tree history
129
136
url = get_transport(self.get_url('metadir_weave_branch')).base
130
137
# check --format takes effect
131
bzrdir.BzrDirFormat._set_default_format(bzrdir.BzrDirFormat5())
132
(out, err) = self.run_bzr(
138
bzrdir.BzrDirFormat.set_default_format(bzrdir.BzrDirFormat5())
139
(out, err) = self.run_bzr_captured(
133
140
['upgrade', '--format=knit', url])
134
141
self.assertEqualDiff("""starting upgrade of %s
135
142
making backup of tree history
145
152
self.assertTrue(isinstance(converted_dir._format,
146
153
bzrdir.BzrDirMetaFormat1))
147
154
self.assertTrue(isinstance(converted_dir.open_repository()._format,
148
RepositoryFormatKnit1))
155
repository.RepositoryFormatKnit1))
150
157
def test_upgrade_repo(self):
151
self.run_bzr('init-repository --format=metaweave repo')
152
self.run_bzr('upgrade --format=knit repo')
158
self.run_bzr('init-repository', '--format=metaweave', 'repo')
159
self.run_bzr('upgrade', '--format=knit', 'repo')
155
162
class SFTPTests(TestCaseWithSFTPServer):
166
173
ui.ui_factory = self.old_ui_factory
168
175
def test_upgrade_url(self):
169
self.run_bzr('init --format=weave')
176
self.run_bzr('init', '--format=weave')
170
177
t = get_transport(self.get_url())
172
out, err = self.run_bzr(['upgrade', '--format=knit', url])
179
out, err = self.run_bzr('upgrade', '--format=knit', url)
173
180
self.assertEqualDiff("""starting upgrade of %s
174
181
making backup of tree history
175
182
%s.bzr has been backed up to %s.bzr.backup
182
189
""" % (url, url, url), out)
183
190
self.assertEqual('', err)
186
class UpgradeRecommendedTests(TestCaseInTempDir):
188
def test_recommend_upgrade_wt4(self):
189
# using a deprecated format gives a warning
190
self.run_bzr('init --knit a')
191
out, err = self.run_bzr('status a')
192
self.assertContainsRe(err, 'bzr upgrade .*[/\\\\]a')
194
def test_no_upgrade_recommendation_from_bzrdir(self):
195
# we should only get a recommendation to upgrade when we're accessing
196
# the actual workingtree, not when we only open a bzrdir that contains
198
self.run_bzr('init --knit a')
199
out, err = self.run_bzr('checkout a b')
200
if err.find('upgrade') > -1:
201
self.fail("message shouldn't suggest upgrade:\n%s" % err)