mutable: minor refactoring of _do_read, to make other tests easier

This commit is contained in:
Brian Warner 2008-03-10 15:42:56 -07:00
parent cad26e000d
commit d6cde55c63
2 changed files with 12 additions and 5 deletions

View File

@ -1098,10 +1098,15 @@ class Publish:
# the permuted peerlist. # the permuted peerlist.
return d return d
def _do_read(self, ss, peerid, storage_index, shnums, readv):
# isolate the callRemote to a separate method, so tests can subclass
# Publish and override it
d = ss.callRemote("slot_readv", storage_index, shnums, readv)
return d
def _do_query(self, ss, peerid, storage_index): def _do_query(self, ss, peerid, storage_index):
self.log("querying %s" % idlib.shortnodeid_b2a(peerid)) self.log("querying %s" % idlib.shortnodeid_b2a(peerid))
d = ss.callRemote("slot_readv", d = self._do_read(ss, peerid, storage_index, [], [(0, self._read_size)])
storage_index, [], [(0, self._read_size)])
return d return d
def _got_query_results(self, datavs, peerid, permutedid, def _got_query_results(self, datavs, peerid, permutedid,
@ -1302,7 +1307,7 @@ class Publish:
def _do_privkey_query(self, rref, peerid, shnum, offset, length): def _do_privkey_query(self, rref, peerid, shnum, offset, length):
started = time.time() started = time.time()
d = rref.callRemote("slot_readv", self._storage_index, d = self._do_read(rref, peerid, self._storage_index,
[shnum], [(offset, length)]) [shnum], [(offset, length)])
d.addCallback(self._privkey_query_response, peerid, shnum, started) d.addCallback(self._privkey_query_response, peerid, shnum, started)
return d return d

View File

@ -47,8 +47,9 @@ class FakeFilenode(mutable.MutableFileNode):
return defer.succeed(None) return defer.succeed(None)
class FakePublish(mutable.Publish): class FakePublish(mutable.Publish):
def _do_query(self, ss, peerid, storage_index): def _do_read(self, ss, peerid, storage_index, shnums, readv):
assert ss[0] == peerid assert ss[0] == peerid
assert shnums == []
shares = self._peers[peerid] shares = self._peers[peerid]
return defer.succeed(shares) return defer.succeed(shares)
@ -275,6 +276,7 @@ class Publish(unittest.TestCase):
p = FakePublish(fn) p = FakePublish(fn)
p._storage_index = "\x00"*32 p._storage_index = "\x00"*32
p._new_seqnum = 3 p._new_seqnum = 3
p._read_size = 1000
#r = mutable.Retrieve(fn) #r = mutable.Retrieve(fn)
p._peers = {} p._peers = {}
for peerid in c._peerids: for peerid in c._peerids: