61
62
class TestDefaultFormat(TestCaseWithTransport):
63
64
def test_get_set_default_format(self):
64
old_format = workingtree.format_registry.get_default()
65
old_format = workingtree.WorkingTreeFormat.get_default_format()
66
67
self.assertTrue(isinstance(old_format, workingtree.WorkingTreeFormat3))
67
workingtree.format_registry.set_default(SampleTreeFormat())
68
workingtree.WorkingTreeFormat.set_default_format(SampleTreeFormat())
69
70
# the default branch format is used by the meta dir format
70
71
# which is not the default bzrdir format at this point
184
185
format.initialize(dir)
185
186
# register a format for it.
186
self.applyDeprecated(symbol_versioning.deprecated_in((2, 4, 0)),
187
workingtree.WorkingTreeFormat.register_format, format)
188
self.assertTrue(format in
189
self.applyDeprecated(symbol_versioning.deprecated_in((2, 4, 0)),
190
workingtree.WorkingTreeFormat.get_formats))
187
workingtree.WorkingTreeFormat.register_format(format)
188
self.assertTrue(format in workingtree.WorkingTreeFormat.get_formats())
191
189
# which branch.Open will refuse (not supported)
192
190
self.assertRaises(errors.UnsupportedFormatError, workingtree.WorkingTree.open, '.')
193
191
# but open_downlevel will work
194
192
self.assertEqual(format.open(dir), workingtree.WorkingTree.open_downlevel('.'))
195
193
# unregister the format
196
self.applyDeprecated(symbol_versioning.deprecated_in((2, 4, 0)),
197
workingtree.WorkingTreeFormat.unregister_format, format)
198
self.assertFalse(format in
199
self.applyDeprecated(symbol_versioning.deprecated_in((2, 4, 0)),
200
workingtree.WorkingTreeFormat.get_formats))
203
class TestWorkingTreeFormatRegistry(TestCase):
206
super(TestWorkingTreeFormatRegistry, self).setUp()
207
self.registry = workingtree.WorkingTreeFormatRegistry()
209
def test_register_unregister_format(self):
210
format = SampleTreeFormat()
211
self.registry.register(format)
212
self.assertEquals(format, self.registry.get("Sample tree format."))
213
self.registry.remove(format)
214
self.assertRaises(KeyError, self.registry.get, "Sample tree format.")
216
def test_get_all(self):
217
format = SampleTreeFormat()
218
self.assertEquals([], self.registry._get_all())
219
self.registry.register(format)
220
self.assertEquals([format], self.registry._get_all())
222
def test_register_extra(self):
194
workingtree.WorkingTreeFormat.unregister_format(format)
195
self.assertFalse(format in workingtree.WorkingTreeFormat.get_formats())
197
def test_register_unregister_extra_format(self):
223
198
format = SampleExtraTreeFormat()
224
self.assertEquals([], self.registry._get_all())
225
self.registry.register_extra(format)
226
self.assertEquals([format], self.registry._get_all())
228
def test_register_extra_lazy(self):
229
self.assertEquals([], self.registry._get_all())
230
self.registry.register_extra_lazy("bzrlib.tests.test_workingtree",
231
"SampleExtraTreeFormat")
232
formats = self.registry._get_all()
233
self.assertEquals(1, len(formats))
234
self.assertIsInstance(formats[0], SampleExtraTreeFormat)
199
workingtree.WorkingTreeFormat.register_extra_format(format)
200
self.assertTrue(format in workingtree.WorkingTreeFormat.get_formats())
201
workingtree.WorkingTreeFormat.unregister_extra_format(format)
202
self.assertFalse(format in workingtree.WorkingTreeFormat.get_formats())
237
205
class TestWorkingTreeFormat3(TestCaseWithTransport):
297
265
self.assertEqual([], tree.get_parent_ids())
268
class TestFormat2WorkingTree(TestCaseWithTransport):
269
"""Tests that are specific to format 2 trees."""
271
def create_format2_tree(self, url):
272
return self.make_branch_and_tree(
273
url, format=bzrdir.BzrDirFormat6())
275
def test_conflicts(self):
276
# test backwards compatability
277
tree = self.create_format2_tree('.')
278
self.assertRaises(errors.UnsupportedOperation, tree.set_conflicts,
280
file('lala.BASE', 'wb').write('labase')
281
expected = conflicts.ContentsConflict('lala')
282
self.assertEqual(list(tree.conflicts()), [expected])
283
file('lala', 'wb').write('la')
284
tree.add('lala', 'lala-id')
285
expected = conflicts.ContentsConflict('lala', file_id='lala-id')
286
self.assertEqual(list(tree.conflicts()), [expected])
287
file('lala.THIS', 'wb').write('lathis')
288
file('lala.OTHER', 'wb').write('laother')
289
# When "text conflict"s happen, stem, THIS and OTHER are text
290
expected = conflicts.TextConflict('lala', file_id='lala-id')
291
self.assertEqual(list(tree.conflicts()), [expected])
292
os.unlink('lala.OTHER')
293
os.mkdir('lala.OTHER')
294
expected = conflicts.ContentsConflict('lala', file_id='lala-id')
295
self.assertEqual(list(tree.conflicts()), [expected])
300
298
class InstrumentedTree(object):
301
299
"""A instrumented tree to check the needs_tree_write_lock decorator."""