18
18
"""Tests for upgrades of various stacking situations."""
26
from ..upgrade import upgrade
27
from .scenarios import load_tests_apply_scenarios
26
from brzlib.upgrade import upgrade
27
from brzlib.tests.scenarios import load_tests_apply_scenarios
30
30
def upgrade_scenarios():
31
scenario_pairs = [ # old format, new format, model_change
32
# ('knit', 'rich-root', True),
31
scenario_pairs = [ # old format, new format, model_change
32
# ('knit', 'rich-root', True),
33
33
('knit', '1.6', False),
34
# ('pack-0.92', '1.6', False),
34
# ('pack-0.92', '1.6', False),
35
35
('1.6', '1.6.1-rich-root', True),
38
38
for (old_name, new_name, model_change) in scenario_pairs:
39
39
name = old_name + ', ' + new_name
40
40
scenarios.append((name,
41
dict(scenario_old_format=old_name,
42
scenario_new_format=new_name,
43
scenario_model_change=model_change)))
41
dict(scenario_old_format=old_name,
42
scenario_new_format=new_name,
43
scenario_model_change=model_change)))
51
51
# TODO: This should possibly be repeated for all stacking repositories,
52
52
# pairwise by rich/non-rich format; should possibly also try other kinds
53
53
# of upgrades like knit->pack. -- mbp 20080804
55
55
scenarios = upgrade_scenarios()
57
57
def test_stack_upgrade(self):
64
64
base = self.make_branch_and_tree('base',
65
format=self.scenario_old_format)
65
format=self.scenario_old_format)
66
66
self.build_tree(['base/foo'])
67
67
base.commit('base commit')
68
68
# make another one stacked
69
stacked = base.controldir.sprout('stacked', stacked=True)
69
stacked = base.bzrdir.sprout('stacked', stacked=True)
70
70
# this must really be stacked (or get_stacked_on_url raises an error)
71
71
self.assertTrue(stacked.open_branch().get_stacked_on_url())
72
72
# now we'll upgrade the underlying branch, then upgrade the stacked
73
73
# branch, and this should still work.
74
new_format = controldir.format_registry.make_controldir(
74
new_format = controldir.format_registry.make_bzrdir(
75
75
self.scenario_new_format)
76
76
upgrade('base', new_format)
77
77
# in some cases you'll get an error if the underlying model has
78
78
# changed; if just the data format has changed this should still work
79
79
if self.scenario_model_change:
80
80
self.assertRaises(errors.IncompatibleRepositories,
83
83
check.check_dwim('stacked', False, True, True)
84
84
stacked = controldir.ControlDir.open('stacked')