60
89
return { "dummy ding": "%s/%s\\%s" % foreign_revid }
92
class DummyForeignVcsBranch(branch.BzrBranch6,foreign.ForeignBranch):
93
"""A Dummy VCS Branch."""
95
def __init__(self, _format, _control_files, a_bzrdir, *args, **kwargs):
96
self._format = _format
97
self._base = a_bzrdir.transport.base
98
self._ignore_fallbacks = False
99
foreign.ForeignBranch.__init__(self,
100
DummyForeignVcsMapping(DummyForeignVcs()))
101
branch.BzrBranch6.__init__(self, _format, _control_files, a_bzrdir,
104
def dpull(self, source, stop_revision=None):
107
# This just handles simple cases, but that's good enough for tests
108
my_history = self.revision_history()
109
their_history = source.revision_history()
110
if their_history[:min(len(my_history), len(their_history))] != my_history:
111
raise errors.DivergedBranches(self, source)
112
todo = their_history[len(my_history):]
115
rev = source.repository.get_revision(revid)
116
tree = source.repository.revision_tree(revid)
117
def get_file_with_stat(file_id, path=None):
118
return (tree.get_file(file_id), None)
119
tree.get_file_with_stat = get_file_with_stat
120
new_revid = self.mapping.revision_id_foreign_to_bzr(
121
(str(rev.timestamp), str(rev.timezone), str(self.revno())))
122
parent_revno, parent_revid= self.last_revision_info()
123
builder = self.get_commit_builder([parent_revid],
124
self.get_config(), rev.timestamp,
125
rev.timezone, rev.committer, rev.properties,
128
for path, ie in tree.inventory.iter_entries():
130
new_ie.revision = None
131
builder.record_entry_contents(new_ie,
132
[self.repository.get_inventory(parent_revid)],
134
(ie.kind, ie.text_size, ie.executable, ie.text_sha1))
135
builder.finish_inventory()
139
revidmap[revid] = builder.commit(rev.message)
140
self.set_last_revision_info(parent_revno+1, revidmap[revid])
141
trace.mutter('lossily pushed revision %s -> %s',
142
revid, revidmap[revid])
148
class DummyForeignVcsBranchFormat(branch.BzrBranchFormat6):
150
def get_format_string(self):
151
return "Branch for Testing"
154
super(DummyForeignVcsBranchFormat, self).__init__()
155
self._matchingbzrdir = DummyForeignVcsDirFormat()
157
def open(self, a_bzrdir, _found=False):
159
raise NotImplementedError
161
transport = a_bzrdir.get_branch_transport(None)
162
control_files = lockable_files.LockableFiles(transport, 'lock',
164
return DummyForeignVcsBranch(_format=self,
165
_control_files=control_files,
167
_repository=a_bzrdir.find_repository())
168
except errors.NoSuchFile:
169
raise errors.NotBranchError(path=transport.base)
172
class DummyForeignVcsDirFormat(BzrDirMetaFormat1):
173
"""BzrDirFormat for the dummy foreign VCS."""
176
def get_format_string(cls):
177
return "A Dummy VCS Dir"
180
def get_format_description(cls):
181
return "A Dummy VCS Dir"
184
def is_supported(cls):
187
def get_branch_format(self):
188
return DummyForeignVcsBranchFormat()
191
def probe_transport(klass, transport):
192
"""Return the .bzrdir style format present in a directory."""
193
if not transport.has('.dummy'):
194
raise errors.NotBranchError(path=transport.base)
197
def initialize_on_transport(self, transport):
198
"""Initialize a new bzrdir in the base directory of a Transport."""
199
# Since we don't have a .bzr directory, inherit the
200
# mode from the root directory
201
temp_control = lockable_files.LockableFiles(transport,
202
'', lockable_files.TransportLock)
203
temp_control._transport.mkdir('.dummy',
204
# FIXME: RBC 20060121 don't peek under
206
mode=temp_control._dir_mode)
208
bzrdir_transport = transport.clone('.dummy')
209
# NB: no need to escape relative paths that are url safe.
210
control_files = lockable_files.LockableFiles(bzrdir_transport,
211
self._lock_file_name, self._lock_class)
212
control_files.create_lock()
213
return self.open(transport, _found=True)
215
def _open(self, transport):
216
return DummyForeignVcsDir(transport, self)
219
class DummyForeignVcsDir(BzrDirMeta1):
221
def __init__(self, _transport, _format):
222
self._format = _format
223
self.transport = _transport.clone('.dummy')
224
self.root_transport = _transport
225
self._mode_check_done = False
226
self._control_files = lockable_files.LockableFiles(self.transport,
227
"lock", lockable_files.TransportLock)
229
def open_branch(self, ignore_fallbacks=True):
230
return self._format.get_branch_format().open(self, _found=True)
232
def cloning_metadir(self, stacked=False):
233
"""Produce a metadir suitable for cloning with."""
234
return format_registry.make_bzrdir("default")
236
def sprout(self, url, revision_id=None, force_new_repo=False,
237
recurse='down', possible_transports=None,
238
accelerator_tree=None, hardlink=False, stacked=False,
240
# dirstate doesn't cope with accelerator_trees well
241
# that have a different control dir
242
return super(DummyForeignVcsDir, self).sprout(url=url,
243
revision_id=revision_id, force_new_repo=force_new_repo,
244
recurse=recurse, possible_transports=possible_transports,
245
hardlink=hardlink, stacked=stacked, source_branch=source_branch)
64
248
class ForeignVcsRegistryTests(TestCase):
249
"""Tests for the ForeignVcsRegistry class."""
66
251
def test_parse_revision_id_no_dash(self):
67
252
reg = foreign.ForeignVcsRegistry()
121
306
"roundtrip-revid")
122
307
self.assertEquals({ "dummy ding": "some/foreign\\revid" },
123
308
foreign.show_foreign_properties(rev))
311
class WorkingTreeFileUpdateTests(TestCaseWithTransport):
312
"""Tests for _determine_fileid_renames()."""
314
def test_det_renames_same(self):
316
a.add_path("bla", "directory", "bla-a")
318
b.add_path("bla", "directory", "bla-a")
320
'': ('TREE_ROOT', 'TREE_ROOT'),
321
'bla': ('bla-a', 'bla-a')},
322
foreign._determine_fileid_renames(a, b))
324
def test_det_renames_simple(self):
326
a.add_path("bla", "directory", "bla-a")
328
b.add_path("bla", "directory", "bla-b")
330
'': ('TREE_ROOT', 'TREE_ROOT'),
331
'bla': ('bla-a', 'bla-b'),
332
}, foreign._determine_fileid_renames(a, b))
334
def test_det_renames_root(self):
336
a.add_path("", "directory", "bla-a")
338
b.add_path("", "directory", "bla-b")
340
{"": ("bla-a", "bla-b")},
341
foreign._determine_fileid_renames(a, b))
343
def test_update_workinginv(self):
345
a.add_path("bla", "directory", "bla-a")
347
b.add_path("bla", "directory", "bla-b")
348
wt = self.make_branch_and_tree('br1')
349
self.build_tree_contents([('br1/bla', 'original contents\n')])
350
wt.add('bla', 'bla-a')
351
foreign.update_workinginv_fileids(wt, a, b)
354
self.assertEquals(["TREE_ROOT", "bla-b"], list(wt.inventory))
359
class DummyForeignVcsTests(TestCaseWithTransport):
360
"""Very basic test for DummyForeignVcs."""
363
BzrDirFormat.register_control_format(DummyForeignVcsDirFormat)
364
self.addCleanup(self.unregister)
365
super(DummyForeignVcsTests, self).setUp()
367
def unregister(self):
369
BzrDirFormat.unregister_control_format(DummyForeignVcsDirFormat)
373
def test_create(self):
374
"""Test we can create dummies."""
375
self.make_branch_and_tree("d", format=DummyForeignVcsDirFormat())
376
dir = BzrDir.open("d")
377
self.assertEquals("A Dummy VCS Dir", dir._format.get_format_string())
378
dir.open_repository()
380
dir.open_workingtree()
382
def test_sprout(self):
383
"""Test we can clone dummies and that the format is not preserved."""
384
self.make_branch_and_tree("d", format=DummyForeignVcsDirFormat())
385
dir = BzrDir.open("d")
386
newdir = dir.sprout("e")
387
self.assertNotEquals("A Dummy VCS Dir", newdir._format.get_format_string())