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
28
from bzrlib.tests import (
30
TestCaseWithTransport,
28
33
from bzrlib.tests.test_sftp_transport import TestCaseWithSFTPServer
29
34
from bzrlib.transport import get_transport
30
import bzrlib.ui as ui
35
from bzrlib.repofmt.knitrepo import (
36
RepositoryFormatKnit1,
33
40
class TestWithUpgradableBranches(TestCaseWithTransport):
36
43
super(TestWithUpgradableBranches, self).setUp()
37
44
self.old_format = bzrdir.BzrDirFormat.get_default_format()
38
self.old_repo_format = \
39
bzrlib.repository.RepositoryFormat.get_default_format()
40
45
self.old_ui_factory = ui.ui_factory
41
46
self.addCleanup(self.restoreDefaults)
43
48
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.
48
49
# setup a format 5 branch we can upgrade from.
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')
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)
62
59
def restoreDefaults(self):
63
bzrdir.BzrDirFormat.set_default_format(self.old_format)
64
bzrlib.repository.RepositoryFormat.set_default_format(
66
60
ui.ui_factory = self.old_ui_factory
61
bzrdir.BzrDirFormat._set_default_format(self.old_format)
68
63
def test_readonly_url_error(self):
69
(out, err) = self.run_bzr_captured(
70
['upgrade', self.get_readonly_url('format_5_branch')], 3)
64
(out, err) = self.run_bzr(
65
['upgrade', self.get_readonly_url('format_5_branch')], retcode=3)
71
66
self.assertEqual(out, "")
72
self.assertEqual(err, "bzr: ERROR: Upgrade URL cannot work with readonly URL's.\n")
67
self.assertEqual(err, "bzr: ERROR: Upgrade URL cannot work with readonly URLs.\n")
74
69
def test_upgrade_up_to_date(self):
75
70
# when up to date we should get a message to that effect
76
(out, err) = self.run_bzr_captured(
77
['upgrade', 'current_format_branch'], 3)
71
(out, err) = self.run_bzr('upgrade current_format_branch', retcode=3)
78
72
self.assertEqual("", out)
79
73
self.assertEqualDiff("bzr: ERROR: The branch format Bazaar-NG meta "
80
74
"directory, format 1 is already at the most "
84
78
# when upgrading a checkout, the branch location and a suggestion
85
79
# to upgrade it should be emitted even if the checkout is up to
87
(out, err) = self.run_bzr_captured(
88
['upgrade', 'current_format_checkout'], 3)
81
(out, err) = self.run_bzr('upgrade current_format_checkout', retcode=3)
89
82
self.assertEqual("This is a checkout. The branch (%s) needs to be "
90
"upgraded separately.\n"
83
"upgraded separately.\n"
91
84
% get_transport(self.get_url('current_format_branch')).base,
93
86
self.assertEqualDiff("bzr: ERROR: The branch format Bazaar-NG meta "
111
104
# users can force an upgrade to metadir format.
112
105
url = get_transport(self.get_url('format_5_branch')).base
113
106
# check --format takes effect
114
bzrdir.BzrDirFormat.set_default_format(bzrdir.BzrDirFormat5())
115
(out, err) = self.run_bzr_captured(
107
bzrdir.BzrDirFormat._set_default_format(bzrdir.BzrDirFormat5())
108
(out, err) = self.run_bzr(
116
109
['upgrade', '--format=metaweave', url])
117
110
self.assertEqualDiff("""starting upgrade of %s
118
111
making backup of tree history
136
129
url = get_transport(self.get_url('metadir_weave_branch')).base
137
130
# check --format takes effect
138
bzrdir.BzrDirFormat.set_default_format(bzrdir.BzrDirFormat5())
139
(out, err) = self.run_bzr_captured(
131
bzrdir.BzrDirFormat._set_default_format(bzrdir.BzrDirFormat5())
132
(out, err) = self.run_bzr(
140
133
['upgrade', '--format=knit', url])
141
134
self.assertEqualDiff("""starting upgrade of %s
142
135
making backup of tree history
152
145
self.assertTrue(isinstance(converted_dir._format,
153
146
bzrdir.BzrDirMetaFormat1))
154
147
self.assertTrue(isinstance(converted_dir.open_repository()._format,
155
repository.RepositoryFormatKnit1))
148
RepositoryFormatKnit1))
157
150
def test_upgrade_repo(self):
158
self.run_bzr('init-repository', '--format=metaweave', 'repo')
159
self.run_bzr('upgrade', '--format=knit', 'repo')
151
self.run_bzr('init-repository --format=metaweave repo')
152
self.run_bzr('upgrade --format=knit repo')
162
155
class SFTPTests(TestCaseWithSFTPServer):
173
166
ui.ui_factory = self.old_ui_factory
175
168
def test_upgrade_url(self):
176
self.run_bzr('init', '--format=weave')
169
self.run_bzr('init --format=weave')
177
170
t = get_transport(self.get_url())
179
out, err = self.run_bzr('upgrade', '--format=knit', url)
172
out, err = self.run_bzr(['upgrade', '--format=knit', url])
180
173
self.assertEqualDiff("""starting upgrade of %s
181
174
making backup of tree history
182
175
%s.bzr has been backed up to %s.bzr.backup
189
182
""" % (url, url, url), out)
190
183
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)