From c595f6ccd036e025b211eaf7234e40b75d7e93e5 Mon Sep 17 00:00:00 2001 From: Brian Warner <warner@allmydata.com> Date: Tue, 6 Nov 2007 15:18:09 -0700 Subject: [PATCH] mutable: parameterize Publish/Retrieve classes in MutableFileNode, for tests --- src/allmydata/mutable.py | 37 ++++++++++++++++++------------ src/allmydata/test/test_mutable.py | 17 ++++++++++++++ 2 files changed, 39 insertions(+), 15 deletions(-) diff --git a/src/allmydata/mutable.py b/src/allmydata/mutable.py index e2bd556a..ce9e081b 100644 --- a/src/allmydata/mutable.py +++ b/src/allmydata/mutable.py @@ -163,6 +163,8 @@ def pack_offsets(verification_key_length, signature_length, class MutableFileNode: implements(IMutableFileNode) + publish_class = Publish + retrieve_class = Retrieve def __init__(self, client): self._client = client @@ -195,28 +197,33 @@ class MutableFileNode: """ self._required_shares = 3 self._total_shares = 10 - self._pubkey, self._privkey = self._generate_pubprivkeys() - pubkey_s = self._pubkey.serialize() - privkey_s = self._privkey.serialize() - self._writekey = hashutil.ssk_writekey_hash(privkey_s) - self._encprivkey = self._encrypt_privkey(self._writekey, privkey_s) - self._fingerprint = hashutil.ssk_pubkey_fingerprint_hash(pubkey_s) - self._uri = WriteableSSKFileURI(self._writekey, self._fingerprint) - self._readkey = self._uri.readkey - self._storage_index = self._uri.storage_index - self._current_seqnum = 0 # TODO: really we mean "doesn't matter - # since nobody knows about us yet" - self._current_roothash = "\x00"*32 - return self._publish(initial_contents) + d = defer.maybeDeferred(self._generate_pubprivkeys) + def _generated( (pubkey, privkey) ): + self._pubkey, self._privkey = pubkey, privkey + pubkey_s = self._pubkey.serialize() + privkey_s = self._privkey.serialize() + self._writekey = hashutil.ssk_writekey_hash(privkey_s) + self._encprivkey = self._encrypt_privkey(self._writekey, privkey_s) + self._fingerprint = hashutil.ssk_pubkey_fingerprint_hash(pubkey_s) + self._uri = WriteableSSKFileURI(self._writekey, self._fingerprint) + self._readkey = self._uri.readkey + self._storage_index = self._uri.storage_index + # TODO: seqnum/roothash: really we mean "doesn't matter since + # nobody knows about us yet" + self._current_seqnum = 0 + self._current_roothash = "\x00"*32 + return self._publish(initial_contents) + d.addCallback(_generated) + return d def _generate_pubprivkeys(self): + # TODO: wire these up to pycryptopp privkey = "very private" pubkey = "public" return pubkey, privkey def _publish(self, initial_contents): - # TODO: actually do all that stuff - p = Publish(self) + p = self.publish_class(self) d = p.publish(initial_contents) d.addCallback(lambda res: self) return d diff --git a/src/allmydata/test/test_mutable.py b/src/allmydata/test/test_mutable.py index 4176b813..fdb5083b 100644 --- a/src/allmydata/test/test_mutable.py +++ b/src/allmydata/test/test_mutable.py @@ -82,6 +82,20 @@ class FakePublish(mutable.Publish): answer = (True, readv) return defer.succeed(answer) +class FakeRetrieve(mutable.Retrieve): + def _do_query(self, args): + pass + def _deserialize_pubkey(self, pubkey_s): + return FakePubKey(134) + +class LessFakeFilenode(mutable.MutableFileNode): + publish_class = FakePublish + retrieve_class = FakeRetrieve + + def _generate_pubprivkeys(self): + count = self.counter.next() + return FakePubKey(count), FakePrivKey(count) + class FakeNewDirectoryNode(dirnode2.NewDirectoryNode): filenode_class = FakeFilenode @@ -392,6 +406,9 @@ class FakePubKey: self.count = count def serialize(self): return "PUBKEY-%d" % self.count + def verify(self, msg, signature): + return True + class FakePrivKey: def __init__(self, count): self.count = count -- 2.45.2