test_system: stall for a second while bouncing the client, it might help windows

This commit is contained in:
Brian Warner 2007-06-28 19:20:28 -07:00
parent 9ecde0d23e
commit 9d47c2524e
1 changed files with 10 additions and 0 deletions

View File

@ -289,6 +289,11 @@ class SystemTest(testutil.SignalMixin, unittest.TestCase):
d = old_client0.disownServiceParent() d = old_client0.disownServiceParent()
assert isinstance(d, defer.Deferred) assert isinstance(d, defer.Deferred)
d.addCallback(self.log, "STOPPED") d.addCallback(self.log, "STOPPED")
# I think windows requires a moment to let the connection really stop
# and the port number made available for re-use. TODO: examine the
# behavior, see if this is really the problem, see if we can do
# better than blindly waiting for a second.
d.addCallback(self.stall, 1.0)
def _stopped(res): def _stopped(res):
new_client0 = client.Client(basedir=self.getdir("client0")) new_client0 = client.Client(basedir=self.getdir("client0"))
self.add_service(new_client0) self.add_service(new_client0)
@ -310,6 +315,11 @@ class SystemTest(testutil.SignalMixin, unittest.TestCase):
log.msg(msg) log.msg(msg)
return res return res
def stall(self, res, delay=1.0):
d = defer.Deferred()
reactor.callLater(delay, d.callback, res)
return d
def _do_publish_private(self, res): def _do_publish_private(self, res):
ut = upload.Data(self.data) ut = upload.Data(self.data)
vdrive0 = self.clients[0].getServiceNamed("vdrive") vdrive0 = self.clients[0].getServiceNamed("vdrive")