17
17
"""Tests for the BzrDir facility and any format specific tests.
19
For interface contract tests, see tests/per_bzr_dir.
19
For interface contract tests, see tests/bzr_dir_implementations.
24
from StringIO import StringIO
26
28
from bzrlib import (
35
revision as _mod_revision,
39
transport as _mod_transport,
45
40
import bzrlib.branch
46
from bzrlib.errors import (
48
NoColocatedBranchSupport,
50
UnsupportedFormatError,
41
from bzrlib.errors import (NotBranchError,
43
UnsupportedFormatError,
52
45
from bzrlib.tests import (
54
47
TestCaseWithMemoryTransport,
55
48
TestCaseWithTransport,
58
52
from bzrlib.tests import(
62
56
from bzrlib.tests.test_http import TestWithTransport_pycurl
63
from bzrlib.transport import (
57
from bzrlib.transport import get_transport
67
58
from bzrlib.transport.http._urllib import HttpTransport_urllib
59
from bzrlib.transport.memory import MemoryServer
68
60
from bzrlib.transport.nosmart import NoSmartTransportDecorator
69
61
from bzrlib.transport.readonly import ReadonlyTransportDecorator
70
from bzrlib.repofmt import knitrepo, knitpack_repo
62
from bzrlib.repofmt import knitrepo, weaverepo, pack_repo
73
65
class TestDefaultFormat(TestCase):
75
67
def test_get_set_default_format(self):
76
68
old_format = bzrdir.BzrDirFormat.get_default_format()
77
# default is BzrDirMetaFormat1
78
self.assertIsInstance(old_format, bzrdir.BzrDirMetaFormat1)
79
controldir.ControlDirFormat._set_default_format(SampleBzrDirFormat())
69
# default is BzrDirFormat6
70
self.failUnless(isinstance(old_format, bzrdir.BzrDirMetaFormat1))
71
bzrdir.BzrDirFormat._set_default_format(SampleBzrDirFormat())
80
72
# creating a bzr dir should now create an instrumented dir.
82
74
result = bzrdir.BzrDir.create('memory:///')
83
self.assertIsInstance(result, SampleBzrDir)
75
self.failUnless(isinstance(result, SampleBzrDir))
85
controldir.ControlDirFormat._set_default_format(old_format)
77
bzrdir.BzrDirFormat._set_default_format(old_format)
86
78
self.assertEqual(old_format, bzrdir.BzrDirFormat.get_default_format())
89
class DeprecatedBzrDirFormat(bzrdir.BzrDirFormat):
90
"""A deprecated bzr dir format."""
93
81
class TestFormatRegistry(TestCase):
95
83
def make_format_registry(self):
96
my_format_registry = controldir.ControlDirFormatRegistry()
97
my_format_registry.register('deprecated', DeprecatedBzrDirFormat,
98
'Some format. Slower and unawesome and deprecated.',
100
my_format_registry.register_lazy('lazy', 'bzrlib.tests.test_bzrdir',
101
'DeprecatedBzrDirFormat', 'Format registered lazily',
103
bzrdir.register_metadir(my_format_registry, 'knit',
84
my_format_registry = bzrdir.BzrDirFormatRegistry()
85
my_format_registry.register('weave', bzrdir.BzrDirFormat6,
86
'Pre-0.8 format. Slower and does not support checkouts or shared'
87
' repositories', deprecated=True)
88
my_format_registry.register_lazy('lazy', 'bzrlib.bzrdir',
89
'BzrDirFormat6', 'Format registered lazily', deprecated=True)
90
my_format_registry.register_metadir('knit',
104
91
'bzrlib.repofmt.knitrepo.RepositoryFormatKnit1',
105
92
'Format using knits',
107
94
my_format_registry.set_default('knit')
108
bzrdir.register_metadir(my_format_registry,
95
my_format_registry.register_metadir(
110
97
'bzrlib.repofmt.knitrepo.RepositoryFormatKnit3',
111
98
'Experimental successor to knit. Use at your own risk.',
112
99
branch_format='bzrlib.branch.BzrBranchFormat6',
113
100
experimental=True)
114
bzrdir.register_metadir(my_format_registry,
101
my_format_registry.register_metadir(
116
103
'bzrlib.repofmt.knitrepo.RepositoryFormatKnit3',
117
104
'Experimental successor to knit. Use at your own risk.',
118
105
branch_format='bzrlib.branch.BzrBranchFormat6', hidden=True)
119
my_format_registry.register('hiddendeprecated', DeprecatedBzrDirFormat,
120
'Old format. Slower and does not support things. ', hidden=True)
121
my_format_registry.register_lazy('hiddenlazy', 'bzrlib.tests.test_bzrdir',
122
'DeprecatedBzrDirFormat', 'Format registered lazily',
123
deprecated=True, hidden=True)
106
my_format_registry.register('hiddenweave', bzrdir.BzrDirFormat6,
107
'Pre-0.8 format. Slower and does not support checkouts or shared'
108
' repositories', hidden=True)
109
my_format_registry.register_lazy('hiddenlazy', 'bzrlib.bzrdir',
110
'BzrDirFormat6', 'Format registered lazily', deprecated=True,
124
112
return my_format_registry
126
114
def test_format_registry(self):
127
115
my_format_registry = self.make_format_registry()
128
116
my_bzrdir = my_format_registry.make_bzrdir('lazy')
129
self.assertIsInstance(my_bzrdir, DeprecatedBzrDirFormat)
130
my_bzrdir = my_format_registry.make_bzrdir('deprecated')
131
self.assertIsInstance(my_bzrdir, DeprecatedBzrDirFormat)
117
self.assertIsInstance(my_bzrdir, bzrdir.BzrDirFormat6)
118
my_bzrdir = my_format_registry.make_bzrdir('weave')
119
self.assertIsInstance(my_bzrdir, bzrdir.BzrDirFormat6)
132
120
my_bzrdir = my_format_registry.make_bzrdir('default')
133
121
self.assertIsInstance(my_bzrdir.repository_format,
134
122
knitrepo.RepositoryFormatKnit1)
178
167
self.assertIs(bzrdir.format_registry.get('dirstate-with-subtree'),
179
168
bzrdir.format_registry.get('default'))
181
repository.format_registry.get_default().__class__,
170
repository.RepositoryFormat.get_default_format().__class__,
182
171
knitrepo.RepositoryFormatKnit3)
184
173
bzrdir.format_registry.set_default_repository(old_default)
186
175
def test_aliases(self):
187
a_registry = controldir.ControlDirFormatRegistry()
188
a_registry.register('deprecated', DeprecatedBzrDirFormat,
189
'Old format. Slower and does not support stuff',
191
a_registry.register('deprecatedalias', DeprecatedBzrDirFormat,
192
'Old format. Slower and does not support stuff',
193
deprecated=True, alias=True)
194
self.assertEqual(frozenset(['deprecatedalias']), a_registry.aliases())
176
a_registry = bzrdir.BzrDirFormatRegistry()
177
a_registry.register('weave', bzrdir.BzrDirFormat6,
178
'Pre-0.8 format. Slower and does not support checkouts or shared'
179
' repositories', deprecated=True)
180
a_registry.register('weavealias', bzrdir.BzrDirFormat6,
181
'Pre-0.8 format. Slower and does not support checkouts or shared'
182
' repositories', deprecated=True, alias=True)
183
self.assertEqual(frozenset(['weavealias']), a_registry.aliases())
197
186
class SampleBranch(bzrlib.branch.Branch):
254
241
return "opened branch."
257
class BzrDirFormatTest1(bzrdir.BzrDirMetaFormat1):
260
def get_format_string():
261
return "Test format 1"
264
class BzrDirFormatTest2(bzrdir.BzrDirMetaFormat1):
267
def get_format_string():
268
return "Test format 2"
271
244
class TestBzrDirFormat(TestCaseWithTransport):
272
245
"""Tests for the BzrDirFormat facility."""
274
247
def test_find_format(self):
275
248
# is the right format object found for a branch?
276
249
# create a branch with a few known format objects.
277
bzrdir.BzrProber.formats.register(BzrDirFormatTest1.get_format_string(),
279
self.addCleanup(bzrdir.BzrProber.formats.remove,
280
BzrDirFormatTest1.get_format_string())
281
bzrdir.BzrProber.formats.register(BzrDirFormatTest2.get_format_string(),
283
self.addCleanup(bzrdir.BzrProber.formats.remove,
284
BzrDirFormatTest2.get_format_string())
285
t = self.get_transport()
250
# this is not quite the same as
251
t = get_transport(self.get_url())
286
252
self.build_tree(["foo/", "bar/"], transport=t)
287
253
def check_format(format, url):
288
254
format.initialize(url)
289
t = _mod_transport.get_transport(url)
255
t = get_transport(url)
290
256
found_format = bzrdir.BzrDirFormat.find_format(t)
291
self.assertIsInstance(found_format, format.__class__)
292
check_format(BzrDirFormatTest1(), "foo")
293
check_format(BzrDirFormatTest2(), "bar")
257
self.failUnless(isinstance(found_format, format.__class__))
258
check_format(bzrdir.BzrDirFormat5(), "foo")
259
check_format(bzrdir.BzrDirFormat6(), "bar")
295
261
def test_find_format_nothing_there(self):
296
262
self.assertRaises(NotBranchError,
297
263
bzrdir.BzrDirFormat.find_format,
298
_mod_transport.get_transport('.'))
300
266
def test_find_format_unknown_format(self):
301
t = self.get_transport()
267
t = get_transport(self.get_url())
303
269
t.put_bytes('.bzr/branch-format', '')
304
270
self.assertRaises(UnknownFormatError,
305
271
bzrdir.BzrDirFormat.find_format,
306
_mod_transport.get_transport('.'))
308
274
def test_register_unregister_format(self):
309
275
format = SampleBzrDirFormat()
709
674
self.assertEqual(relpath, 'baz')
711
676
def test_open_containing_from_transport(self):
712
self.assertRaises(NotBranchError,
713
bzrdir.BzrDir.open_containing_from_transport,
714
_mod_transport.get_transport(self.get_readonly_url('')))
715
self.assertRaises(NotBranchError,
716
bzrdir.BzrDir.open_containing_from_transport,
717
_mod_transport.get_transport(self.get_readonly_url('g/p/q')))
677
self.assertRaises(NotBranchError, bzrdir.BzrDir.open_containing_from_transport,
678
get_transport(self.get_readonly_url('')))
679
self.assertRaises(NotBranchError, bzrdir.BzrDir.open_containing_from_transport,
680
get_transport(self.get_readonly_url('g/p/q')))
718
681
control = bzrdir.BzrDir.create(self.get_url())
719
682
branch, relpath = bzrdir.BzrDir.open_containing_from_transport(
720
_mod_transport.get_transport(self.get_readonly_url('')))
683
get_transport(self.get_readonly_url('')))
721
684
self.assertEqual('', relpath)
722
685
branch, relpath = bzrdir.BzrDir.open_containing_from_transport(
723
_mod_transport.get_transport(self.get_readonly_url('g/p/q')))
686
get_transport(self.get_readonly_url('g/p/q')))
724
687
self.assertEqual('g/p/q', relpath)
726
689
def test_open_containing_tree_or_branch(self):
770
733
# transport pointing at bzrdir should give a bzrdir with root transport
771
734
# set to the given transport
772
735
control = bzrdir.BzrDir.create(self.get_url())
773
t = self.get_transport()
774
opened_bzrdir = bzrdir.BzrDir.open_from_transport(t)
775
self.assertEqual(t.base, opened_bzrdir.root_transport.base)
736
transport = get_transport(self.get_url())
737
opened_bzrdir = bzrdir.BzrDir.open_from_transport(transport)
738
self.assertEqual(transport.base, opened_bzrdir.root_transport.base)
776
739
self.assertIsInstance(opened_bzrdir, bzrdir.BzrDir)
778
741
def test_open_from_transport_no_bzrdir(self):
779
t = self.get_transport()
780
self.assertRaises(NotBranchError, bzrdir.BzrDir.open_from_transport, t)
742
transport = get_transport(self.get_url())
743
self.assertRaises(NotBranchError, bzrdir.BzrDir.open_from_transport,
782
746
def test_open_from_transport_bzrdir_in_parent(self):
783
747
control = bzrdir.BzrDir.create(self.get_url())
784
t = self.get_transport()
786
t = t.clone('subdir')
787
self.assertRaises(NotBranchError, bzrdir.BzrDir.open_from_transport, t)
748
transport = get_transport(self.get_url())
749
transport.mkdir('subdir')
750
transport = transport.clone('subdir')
751
self.assertRaises(NotBranchError, bzrdir.BzrDir.open_from_transport,
789
754
def test_sprout_recursive(self):
790
755
tree = self.make_branch_and_tree('tree1',
820
785
self.build_tree(['tree1/subtree/file'])
821
786
sub_tree.add('file')
822
787
tree.commit('Initial commit')
823
# The following line force the orhaning to reveal bug #634470
824
tree.branch.get_config().set_user_option(
825
'bzr.transform.orphan_policy', 'move')
826
788
tree.bzrdir.destroy_workingtree()
827
# FIXME: subtree/.bzr is left here which allows the test to pass (or
828
# fail :-( ) -- vila 20100909
829
789
repo = self.make_repository('repo', shared=True,
830
790
format='dirstate-with-subtree')
831
791
repo.set_make_working_trees(False)
832
# FIXME: we just deleted the workingtree and now we want to use it ????
833
# At a minimum, we should use tree.branch below (but this fails too
834
# currently) or stop calling this test 'treeless'. Specifically, I've
835
# turn the line below into an assertRaises when 'subtree/.bzr' is
836
# orphaned and sprout tries to access the branch there (which is left
837
# by bzrdir.BzrDirMeta1.destroy_workingtree when it ignores the
838
# [DeletingParent('Not deleting', u'subtree', None)] conflict). See bug
839
# #634470. -- vila 20100909
840
self.assertRaises(errors.NotBranchError,
841
tree.bzrdir.sprout, 'repo/tree2')
842
# self.assertPathExists('repo/tree2/subtree')
843
# self.assertPathDoesNotExist('repo/tree2/subtree/file')
792
tree.bzrdir.sprout('repo/tree2')
793
self.failUnlessExists('repo/tree2/subtree')
794
self.failIfExists('repo/tree2/subtree/file')
845
796
def make_foo_bar_baz(self):
846
797
foo = bzrdir.BzrDir.create_branch_convenience('foo').bzrdir
851
802
def test_find_bzrdirs(self):
852
803
foo, bar, baz = self.make_foo_bar_baz()
853
t = self.get_transport()
854
self.assertEqualBzrdirs([baz, foo, bar], bzrdir.BzrDir.find_bzrdirs(t))
856
def make_fake_permission_denied_transport(self, transport, paths):
857
"""Create a transport that raises PermissionDenied for some paths."""
860
raise errors.PermissionDenied(path)
862
path_filter_server = pathfilter.PathFilteringServer(transport, filter)
863
path_filter_server.start_server()
864
self.addCleanup(path_filter_server.stop_server)
865
path_filter_transport = pathfilter.PathFilteringTransport(
866
path_filter_server, '.')
867
return (path_filter_server, path_filter_transport)
869
def assertBranchUrlsEndWith(self, expect_url_suffix, actual_bzrdirs):
870
"""Check that each branch url ends with the given suffix."""
871
for actual_bzrdir in actual_bzrdirs:
872
self.assertEndsWith(actual_bzrdir.user_url, expect_url_suffix)
874
def test_find_bzrdirs_permission_denied(self):
875
foo, bar, baz = self.make_foo_bar_baz()
876
t = self.get_transport()
877
path_filter_server, path_filter_transport = \
878
self.make_fake_permission_denied_transport(t, ['foo'])
880
self.assertBranchUrlsEndWith('/baz/',
881
bzrdir.BzrDir.find_bzrdirs(path_filter_transport))
883
smart_transport = self.make_smart_server('.',
884
backing_server=path_filter_server)
885
self.assertBranchUrlsEndWith('/baz/',
886
bzrdir.BzrDir.find_bzrdirs(smart_transport))
804
transport = get_transport(self.get_url())
805
self.assertEqualBzrdirs([baz, foo, bar],
806
bzrdir.BzrDir.find_bzrdirs(transport))
888
808
def test_find_bzrdirs_list_current(self):
889
809
def list_current(transport):
890
810
return [s for s in transport.list_dir('') if s != 'baz']
892
812
foo, bar, baz = self.make_foo_bar_baz()
893
t = self.get_transport()
894
self.assertEqualBzrdirs(
896
bzrdir.BzrDir.find_bzrdirs(t, list_current=list_current))
813
transport = get_transport(self.get_url())
814
self.assertEqualBzrdirs([foo, bar],
815
bzrdir.BzrDir.find_bzrdirs(transport,
816
list_current=list_current))
898
819
def test_find_bzrdirs_evaluate(self):
899
820
def evaluate(bzrdir):
920
842
root = self.make_repository('', shared=True)
921
843
foo, bar, baz = self.make_foo_bar_baz()
922
844
qux = self.make_bzrdir('foo/qux')
923
t = self.get_transport()
924
branches = bzrdir.BzrDir.find_branches(t)
845
transport = get_transport(self.get_url())
846
branches = bzrdir.BzrDir.find_branches(transport)
925
847
self.assertEqual(baz.root_transport.base, branches[0].base)
926
848
self.assertEqual(foo.root_transport.base, branches[1].base)
927
849
self.assertEqual(bar.root_transport.base, branches[2].base)
929
851
# ensure this works without a top-level repo
930
branches = bzrdir.BzrDir.find_branches(t.clone('foo'))
852
branches = bzrdir.BzrDir.find_branches(transport.clone('foo'))
931
853
self.assertEqual(foo.root_transport.base, branches[0].base)
932
854
self.assertEqual(bar.root_transport.base, branches[1].base)
935
class TestMissingRepoBranchesSkipped(TestCaseWithMemoryTransport):
937
def test_find_bzrdirs_missing_repo(self):
938
t = self.get_transport()
939
arepo = self.make_repository('arepo', shared=True)
940
abranch_url = arepo.user_url + '/abranch'
941
abranch = bzrdir.BzrDir.create(abranch_url).create_branch()
942
t.delete_tree('arepo/.bzr')
943
self.assertRaises(errors.NoRepositoryPresent,
944
branch.Branch.open, abranch_url)
945
self.make_branch('baz')
946
for actual_bzrdir in bzrdir.BzrDir.find_branches(t):
947
self.assertEndsWith(actual_bzrdir.user_url, '/baz/')
950
857
class TestMeta1DirFormat(TestCaseWithTransport):
951
858
"""Tests specific to the meta1 dir format."""
1013
919
self.assertEqual(2, rpc_count)
922
class TestFormat5(TestCaseWithTransport):
923
"""Tests specific to the version 5 bzrdir format."""
925
def test_same_lockfiles_between_tree_repo_branch(self):
926
# this checks that only a single lockfiles instance is created
927
# for format 5 objects
928
dir = bzrdir.BzrDirFormat5().initialize(self.get_url())
929
def check_dir_components_use_same_lock(dir):
930
ctrl_1 = dir.open_repository().control_files
931
ctrl_2 = dir.open_branch().control_files
932
ctrl_3 = dir.open_workingtree()._control_files
933
self.assertTrue(ctrl_1 is ctrl_2)
934
self.assertTrue(ctrl_2 is ctrl_3)
935
check_dir_components_use_same_lock(dir)
936
# and if we open it normally.
937
dir = bzrdir.BzrDir.open(self.get_url())
938
check_dir_components_use_same_lock(dir)
940
def test_can_convert(self):
941
# format 5 dirs are convertable
942
dir = bzrdir.BzrDirFormat5().initialize(self.get_url())
943
self.assertTrue(dir.can_convert_format())
945
def test_needs_conversion(self):
946
# format 5 dirs need a conversion if they are not the default,
948
dir = bzrdir.BzrDirFormat5().initialize(self.get_url())
949
# don't need to convert it to itself
950
self.assertFalse(dir.needs_format_conversion(bzrdir.BzrDirFormat5()))
951
# do need to convert it to the current default
952
self.assertTrue(dir.needs_format_conversion(
953
bzrdir.BzrDirFormat.get_default_format()))
956
class TestFormat6(TestCaseWithTransport):
957
"""Tests specific to the version 6 bzrdir format."""
959
def test_same_lockfiles_between_tree_repo_branch(self):
960
# this checks that only a single lockfiles instance is created
961
# for format 6 objects
962
dir = bzrdir.BzrDirFormat6().initialize(self.get_url())
963
def check_dir_components_use_same_lock(dir):
964
ctrl_1 = dir.open_repository().control_files
965
ctrl_2 = dir.open_branch().control_files
966
ctrl_3 = dir.open_workingtree()._control_files
967
self.assertTrue(ctrl_1 is ctrl_2)
968
self.assertTrue(ctrl_2 is ctrl_3)
969
check_dir_components_use_same_lock(dir)
970
# and if we open it normally.
971
dir = bzrdir.BzrDir.open(self.get_url())
972
check_dir_components_use_same_lock(dir)
974
def test_can_convert(self):
975
# format 6 dirs are convertable
976
dir = bzrdir.BzrDirFormat6().initialize(self.get_url())
977
self.assertTrue(dir.can_convert_format())
979
def test_needs_conversion(self):
980
# format 6 dirs need an conversion if they are not the default.
981
dir = bzrdir.BzrDirFormat6().initialize(self.get_url())
982
self.assertTrue(dir.needs_format_conversion(
983
bzrdir.BzrDirFormat.get_default_format()))
986
class NotBzrDir(bzrlib.bzrdir.BzrDir):
987
"""A non .bzr based control directory."""
989
def __init__(self, transport, format):
990
self._format = format
991
self.root_transport = transport
992
self.transport = transport.clone('.not')
995
class NotBzrDirFormat(bzrlib.bzrdir.BzrDirFormat):
996
"""A test class representing any non-.bzr based disk format."""
998
def initialize_on_transport(self, transport):
999
"""Initialize a new .not dir in the base directory of a Transport."""
1000
transport.mkdir('.not')
1001
return self.open(transport)
1003
def open(self, transport):
1004
"""Open this directory."""
1005
return NotBzrDir(transport, self)
1008
def _known_formats(self):
1009
return set([NotBzrDirFormat()])
1012
def probe_transport(self, transport):
1013
"""Our format is present if the transport ends in '.not/'."""
1014
if transport.has('.not'):
1015
return NotBzrDirFormat()
1018
class TestNotBzrDir(TestCaseWithTransport):
1019
"""Tests for using the bzrdir api with a non .bzr based disk format.
1021
If/when one of these is in the core, we can let the implementation tests
1025
def test_create_and_find_format(self):
1026
# create a .notbzr dir
1027
format = NotBzrDirFormat()
1028
dir = format.initialize(self.get_url())
1029
self.assertIsInstance(dir, NotBzrDir)
1031
bzrlib.bzrdir.BzrDirFormat.register_control_format(format)
1033
found = bzrlib.bzrdir.BzrDirFormat.find_format(
1034
get_transport(self.get_url()))
1035
self.assertIsInstance(found, NotBzrDirFormat)
1037
bzrlib.bzrdir.BzrDirFormat.unregister_control_format(format)
1039
def test_included_in_known_formats(self):
1040
bzrlib.bzrdir.BzrDirFormat.register_control_format(NotBzrDirFormat)
1042
formats = bzrlib.bzrdir.BzrDirFormat.known_formats()
1043
for format in formats:
1044
if isinstance(format, NotBzrDirFormat):
1046
self.fail("No NotBzrDirFormat in %s" % formats)
1048
bzrlib.bzrdir.BzrDirFormat.unregister_control_format(NotBzrDirFormat)
1016
1051
class NonLocalTests(TestCaseWithTransport):
1017
1052
"""Tests for bzrdir static behaviour on non local paths."""
1019
1054
def setUp(self):
1020
1055
super(NonLocalTests, self).setUp()
1021
self.vfs_transport_factory = memory.MemoryServer
1056
self.vfs_transport_factory = MemoryServer
1023
1058
def test_create_branch_convenience(self):
1024
1059
# outside a repo the default convenience output is a repo+branch_tree
1226
1251
class _TestBranch(bzrlib.branch.Branch):
1227
1252
"""Test Branch implementation for TestBzrDirSprout."""
1229
def __init__(self, transport, *args, **kwargs):
1254
def __init__(self, *args, **kwargs):
1230
1255
self._format = _TestBranchFormat()
1231
self._transport = transport
1232
self.base = transport.base
1233
1256
super(_TestBranch, self).__init__(*args, **kwargs)
1234
1257
self.calls = []
1235
1258
self._parent = None
1237
1260
def sprout(self, *args, **kwargs):
1238
1261
self.calls.append('sprout')
1239
return _TestBranch(self._transport)
1262
return _TestBranch()
1241
1264
def copy_content_into(self, destination, revision_id=None):
1242
1265
self.calls.append('copy_content_into')
1244
def last_revision(self):
1245
return _mod_revision.NULL_REVISION
1247
1267
def get_parent(self):
1248
1268
return self._parent
1250
def _get_config(self):
1251
return config.TransportConfig(self._transport, 'branch.conf')
1253
1270
def set_parent(self, parent):
1254
1271
self._parent = parent
1256
def lock_read(self):
1257
return lock.LogicalLockResult(self.unlock)
1263
1274
class TestBzrDirSprout(TestCaseWithMemoryTransport):
1318
1329
url = transport.base
1319
1330
err = self.assertRaises(errors.BzrError, bzrdir.BzrDir.open, url)
1320
1331
self.assertEqual('fail', err._preformatted_string)
1322
def test_post_repo_init(self):
1323
from bzrlib.bzrdir import RepoInitHookParams
1325
bzrdir.BzrDir.hooks.install_named_hook('post_repo_init',
1327
self.make_repository('foo')
1328
self.assertLength(1, calls)
1330
self.assertIsInstance(params, RepoInitHookParams)
1331
self.assertTrue(hasattr(params, 'bzrdir'))
1332
self.assertTrue(hasattr(params, 'repository'))
1334
def test_post_repo_init_hook_repr(self):
1336
bzrdir.BzrDir.hooks.install_named_hook('post_repo_init',
1337
lambda params: param_reprs.append(repr(params)), None)
1338
self.make_repository('foo')
1339
self.assertLength(1, param_reprs)
1340
param_repr = param_reprs[0]
1341
self.assertStartsWith(param_repr, '<RepoInitHookParams for ')
1344
class TestGenerateBackupName(TestCaseWithMemoryTransport):
1345
# FIXME: This may need to be unified with test_osutils.TestBackupNames or
1346
# moved to per_bzrdir or per_transport for better coverage ?
1350
super(TestGenerateBackupName, self).setUp()
1351
self._transport = self.get_transport()
1352
bzrdir.BzrDir.create(self.get_url(),
1353
possible_transports=[self._transport])
1354
self._bzrdir = bzrdir.BzrDir.open_from_transport(self._transport)
1356
def test_deprecated_generate_backup_name(self):
1357
res = self.applyDeprecated(
1358
symbol_versioning.deprecated_in((2, 3, 0)),
1359
self._bzrdir.generate_backup_name, 'whatever')
1362
self.assertEqual("a.~1~", self._bzrdir._available_backup_name("a"))
1364
def test_exiting(self):
1365
self._transport.put_bytes("a.~1~", "some content")
1366
self.assertEqual("a.~2~", self._bzrdir._available_backup_name("a"))