[svn r37960] refactored the tests and added tests and code

for disallowing to send() twice without
adding new targets.

--HG--
branch : trunk
This commit is contained in:
hpk 2007-02-05 13:55:31 +01:00
parent 11591c3c4f
commit 845357dcba
2 changed files with 117 additions and 91 deletions

View File

@ -28,18 +28,6 @@ class RSync(object):
def filter(self, path): def filter(self, path):
return True return True
def add_target(self, gateway, destdir, finishedcallback=None):
""" Adds a remote target specified via a 'gateway'
and a remote destination directory.
"""
assert finishedcallback is None or callable(finishedcallback)
def itemcallback(req):
self._receivequeue.put((channel, req))
channel = gateway.remote_exec(REMOTE_SOURCE)
channel.setcallback(itemcallback, endmarker = None)
channel.send((str(destdir), self._options))
self._channels[channel] = finishedcallback
def _end_of_channel(self, channel): def _end_of_channel(self, channel):
if channel in self._channels: if channel in self._channels:
# too early! we must have got an error # too early! we must have got an error
@ -104,6 +92,9 @@ class RSync(object):
def send(self, sourcedir): def send(self, sourcedir):
""" Sends a sourcedir to all added targets. """ Sends a sourcedir to all added targets.
""" """
if not self._channels:
raise IOError("no targets available, maybing you "
"are trying call send() twice?")
self._sourcedir = str(sourcedir) self._sourcedir = str(sourcedir)
# normalize a trailing '/' away # normalize a trailing '/' away
self._sourcedir = os.path.dirname(os.path.join(self._sourcedir, 'x')) self._sourcedir = os.path.dirname(os.path.join(self._sourcedir, 'x'))
@ -137,6 +128,19 @@ class RSync(object):
else: else:
assert "Unknown command %s" % command assert "Unknown command %s" % command
def add_target(self, gateway, destdir, finishedcallback=None):
""" Adds a remote target specified via a 'gateway'
and a remote destination directory.
"""
assert finishedcallback is None or callable(finishedcallback)
def itemcallback(req):
self._receivequeue.put((channel, req))
channel = gateway.remote_exec(REMOTE_SOURCE)
channel.setcallback(itemcallback, endmarker = None)
channel.send((str(destdir), self._options))
self._channels[channel] = finishedcallback
def _broadcast(self, msg): def _broadcast(self, msg):
for channel in self._channels: for channel in self._channels:
channel.send(msg) channel.send(msg)

View File

@ -11,92 +11,114 @@ def teardown_module(mod):
mod.gw2.exit() mod.gw2.exit()
def test_dirsync(): class DirSetup:
base = py.test.ensuretemp('dirsync') def setup_method(self, method):
dest = base.join('dest') name = "%s.%s" %(self.__class__.__name__, method.func_name)
dest2 = base.join('dest2') self.tmpdir = t = py.test.ensuretemp(name)
source = base.mkdir('source') self.source = t.join("source")
self.dest1 = t.join("dest1")
self.dest2 = t.join("dest2")
for s in ('content1', 'content2-a-bit-longer'): class TestRSync(DirSetup):
source.ensure('subdir', 'file1').write(s) def test_notargets(self):
rsync = RSync()
py.test.raises(IOError, "rsync.send(self.source)")
def test_dirsync(self):
dest = self.dest1
dest2 = self.dest2
source = self.source
for s in ('content1', 'content2-a-bit-longer'):
source.ensure('subdir', 'file1').write(s)
rsync = RSync()
rsync.add_target(gw, dest)
rsync.add_target(gw2, dest2)
rsync.send(source)
assert dest.join('subdir').check(dir=1)
assert dest.join('subdir', 'file1').check(file=1)
assert dest.join('subdir', 'file1').read() == s
assert dest2.join('subdir').check(dir=1)
assert dest2.join('subdir', 'file1').check(file=1)
assert dest2.join('subdir', 'file1').read() == s
source.join('subdir').remove('file1')
rsync = RSync()
rsync.add_target(gw2, dest2)
rsync.add_target(gw, dest)
rsync.send(source)
assert dest.join('subdir', 'file1').check(file=1)
assert dest2.join('subdir', 'file1').check(file=1)
rsync = RSync(delete=True)
rsync.add_target(gw2, dest2)
rsync.add_target(gw, dest)
rsync.send(source)
assert not dest.join('subdir', 'file1').check()
assert not dest2.join('subdir', 'file1').check()
def test_dirsync_twice(self):
source = self.source
source.ensure("hello")
rsync = RSync()
rsync.add_target(gw, self.dest1)
rsync.send(self.source)
assert self.dest1.join('hello').check()
py.test.raises(IOError, "rsync.send(self.source)")
rsync.add_target(gw, self.dest2)
rsync.send(self.source)
assert self.dest2.join('hello').check()
py.test.raises(IOError, "rsync.send(self.source)")
def test_symlink_rsync(self):
if py.std.sys.platform == 'win32':
py.test.skip("symlinks are unsupported on Windows.")
source = self.source
dest = self.dest1
self.source.ensure("existant")
source.join("rellink").mksymlinkto(source.join("existant"), absolute=0)
source.join('abslink').mksymlinkto(source.join("existant"))
rsync = RSync() rsync = RSync()
rsync.add_target(gw, dest) rsync.add_target(gw, dest)
rsync.add_target(gw2, dest2)
rsync.send(source) rsync.send(source)
assert dest.join('subdir').check(dir=1)
assert dest.join('subdir', 'file1').check(file=1) assert dest.join('rellink').readlink() == dest.join("existant")
assert dest.join('subdir', 'file1').read() == s assert dest.join('abslink').readlink() == dest.join("existant")
assert dest2.join('subdir').check(dir=1)
assert dest2.join('subdir', 'file1').check(file=1)
assert dest2.join('subdir', 'file1').read() == s
source.join('subdir').remove('file1')
rsync = RSync()
rsync.add_target(gw2, dest2)
rsync.add_target(gw, dest)
rsync.send(source)
assert dest.join('subdir', 'file1').check(file=1)
assert dest2.join('subdir', 'file1').check(file=1)
rsync = RSync(delete=True)
rsync.add_target(gw2, dest2)
rsync.add_target(gw, dest)
rsync.send(source)
assert not dest.join('subdir', 'file1').check()
assert not dest2.join('subdir', 'file1').check()
def test_symlink_rsync(): def test_callback(self):
if py.std.sys.platform == 'win32': dest = self.dest1
py.test.skip("symlinks are unsupported on Windows.") source = self.source
base = py.test.ensuretemp('symlinkrsync') source.ensure("existant").write("a" * 100)
dest = base.join('dest') source.ensure("existant2").write("a" * 10)
source = base.join('source') total = {}
source.ensure("existant") def callback(cmd, lgt, channel):
source.join("rellink").mksymlinkto(source.join("existant"), absolute=0) total[(cmd, lgt)] = True
source.join('abslink').mksymlinkto(source.join("existant"))
rsync = RSync()
rsync.add_target(gw, dest)
rsync.send(source)
assert dest.join('rellink').readlink() == dest.join("existant")
assert dest.join('abslink').readlink() == dest.join("existant")
def test_callback(): rsync = RSync(callback=callback)
base = py.test.ensuretemp('callback') #rsync = RSync()
dest = base.join("dest") rsync.add_target(gw, dest)
source = base.join("source") rsync.send(source)
source.ensure("existant").write("a" * 100)
source.ensure("existant2").write("a" * 10)
total = {}
def callback(cmd, lgt, channel):
total[(cmd, lgt)] = True
rsync = RSync(callback=callback) assert total == {("list", 110):True, ("ack", 100):True, ("ack", 10):True}
#rsync = RSync()
rsync.add_target(gw, dest)
rsync.send(source)
assert total == {("list", 110):True, ("ack", 100):True, ("ack", 10):True} def test_file_disappearing(self):
dest = self.dest1
source = self.source
source.ensure("ex").write("a" * 100)
source.ensure("ex2").write("a" * 100)
def test_file_disappearing(): class DRsync(RSync):
base = py.test.ensuretemp("file_disappearing") def filter(self, x):
dest = base.join("dest") assert x != source
source = base.join("source") if x.endswith("ex2"):
source.ensure("ex").write("a" * 100) self.x = 1
source.ensure("ex2").write("a" * 100) source.join("ex2").remove()
return True
class DRsync(RSync): rsync = DRsync()
def filter(self, x): rsync.add_target(gw, dest)
assert x != source rsync.send(source)
if x.endswith("ex2"): assert rsync.x == 1
self.x = 1 assert len(dest.listdir()) == 1
source.join("ex2").remove() assert len(source.listdir()) == 1
return True
rsync = DRsync()
rsync.add_target(gw, dest)
rsync.send(source)
assert rsync.x == 1
assert len(dest.listdir()) == 1
assert len(source.listdir()) == 1