from twisted.spread import pb from twisted.internet import defer import time class PBBenchClient: hostname = 'localhost' portno = pb.portno calledThisSecond = 0 def callLoop(self, ignored): d1 = self.persp.callRemote("simple") d2 = self.persp.callRemote("complexTypes") defer.DeferredList([d1, d2]).addCallback(self.callLoop) self.calledThisSecond += 1 thisSecond = int(time.time()) if thisSecond != self.lastSecond: if thisSecond - self.lastSecond > 1: print "WARNING it took more than one second" print 'cps:', self.calledThisSecond self.calledThisSecond = 0 self.lastSecond = thisSecond def _cbPerspective(self, persp): self.persp = persp self.lastSecond = int(time.time()) self.callLoop(None) def runTest(self): pb.connect(self.hostname, self.portno, "benchmark", "benchmark", "benchmark").addCallback(self._cbPerspective) PBBenchClient().runTest() from twisted.internet import reactor reactor.run()