mutable.Publish: rearrange create() to use more of it in unit tests
authorBrian Warner <warner@lothar.com>
Tue, 6 Nov 2007 07:33:40 +0000 (00:33 -0700)
committerBrian Warner <warner@lothar.com>
Tue, 6 Nov 2007 07:33:40 +0000 (00:33 -0700)
src/allmydata/mutable.py
src/allmydata/test/test_mutable.py

index 0b7e4ef8d85a040880d51fef82fee679fcbb6327..dec8d0c3446f68aae465f998eeb50e7ac3e1254a 100644 (file)
@@ -126,6 +126,8 @@ class MutableFileNode:
         self._client = client
         self._pubkey = None # filled in upon first read
         self._privkey = None # filled in if we're mutable
+        self._required_shares = None # ditto
+        self._total_shares = None # ditto
         self._sharemap = {} # known shares, shnum-to-[nodeids]
 
         self._current_data = None # SDMF: we're allowed to cache the contents
@@ -149,18 +151,27 @@ class MutableFileNode:
         the initial contents. Returns a Deferred that fires (with the
         MutableFileNode instance you should use) when it completes.
         """
-        self._privkey = "very private"
-        self._pubkey = "public"
-        self._writekey = hashutil.ssk_writekey_hash(self._privkey)
+        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)
-        pubkey_s = self._pubkey.serialize()
         self._fingerprint = hashutil.ssk_pubkey_fingerprint_hash(pubkey_s)
         self._uri = WriteableSSKFileURI(self._writekey, self._fingerprint)
-        self._current_seqnum = 0
+        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)
 
+    def _generate_pubprivkeys(self):
+        privkey = "very private"
+        pubkey = "public"
+        return pubkey, privkey
+
     def _publish(self, initial_contents):
         # TODO: actually do all that stuff
         p = Publish(self)
@@ -196,9 +207,9 @@ class MutableFileNode:
         return self._pubkey
 
     def get_required_shares(self):
-        return 3 # TODO: where should this come from?
+        return self._required_shares
     def get_total_shares(self):
-        return 10 # TODO: same
+        return self._total_shares
 
 
     def get_uri(self):
index c80af2ae68e2723a19528b86eb0487af569bdaec..c19abf16eb2ef26e123bafc06bb07a4c68f7d759 100644 (file)
@@ -47,21 +47,13 @@ class FakeFilenode(mutable.MutableFileNode):
     counter = itertools.count(1)
     all_contents = {}
 
-    def create(self, initial_contents):
+    def _generate_pubprivkeys(self):
         count = self.counter.next()
-        self.init_from_uri(uri.WriteableSSKFileURI("key%d" % count,
-                                                   "fingerprint%d" % count))
+        return FakePubKey(count), FakePrivKey(count)
+    def _publish(self, initial_contents):
         self.all_contents[self._uri] = initial_contents
-        self._privkey = FakePrivKey()
-        self._pubkey = FakePubKey()
-        self._encprivkey = "encrypted private key"
-        privkey_s = self._privkey.serialize()
-        #self._encprivkey = self._encrypt_privkey(self._writekey, privkey_s)
-        pubkey_s = self._pubkey.serialize()
-        self._fingerprint = hashutil.ssk_pubkey_fingerprint_hash(pubkey_s)
-        self._current_seqnum = 0
-        self._current_roothash = "\x00"*32
         return defer.succeed(self)
+
     def download_to_data(self):
         return defer.succeed(self.all_contents[self._uri])
     def replace(self, newdata):
@@ -211,7 +203,7 @@ class Publish(unittest.TestCase):
                                  len(CONTENTS),
                                  "IV"*8),
                                 3, # seqnum
-                                FakePrivKey(), "encprivkey", FakePubKey(),
+                                FakePrivKey(0), "encprivkey", FakePubKey(0),
                                 )
         def _done( (seqnum, root_hash, final_shares) ):
             self.failUnlessEqual(seqnum, 3)
@@ -221,7 +213,7 @@ class Publish(unittest.TestCase):
             self.failUnlessEqual(sorted(final_shares.keys()), range(10))
             for i,sh in final_shares.items():
                 self.failUnless(isinstance(sh, str))
-                self.failUnlessEqual(len(sh), 367)
+                self.failUnlessEqual(len(sh), 369)
                 # feed the share through the unpacker as a sanity-check
                 pieces = mutable.unpack_share(sh)
                 (u_seqnum, u_root_hash, k, N, segsize, datalen,
@@ -233,11 +225,11 @@ class Publish(unittest.TestCase):
                 self.failUnlessEqual(N, 10)
                 self.failUnlessEqual(segsize, 21)
                 self.failUnlessEqual(datalen, len(CONTENTS))
-                self.failUnlessEqual(pubkey, FakePubKey().serialize())
+                self.failUnlessEqual(pubkey, FakePubKey(0).serialize())
                 sig_material = struct.pack(">BQ32s BBQQ", 0, seqnum, root_hash,
                                            k, N, segsize, datalen)
                 self.failUnlessEqual(signature,
-                                     FakePrivKey().sign(sig_material))
+                                     FakePrivKey(0).sign(sig_material))
                 self.failUnless(isinstance(share_hash_chain, list))
                 self.failUnlessEqual(len(share_hash_chain), 4) # ln2(10)++
                 for i in share_hash_chain:
@@ -356,7 +348,7 @@ class Publish(unittest.TestCase):
                                  len(CONTENTS),
                                  "IV"*8),
                                 3, # seqnum
-                                FakePrivKey(), "encprivkey", FakePubKey(),
+                                FakePrivKey(0), "encprivkey", FakePubKey(0),
                                 )
         return d, p
 
@@ -384,7 +376,9 @@ class Publish(unittest.TestCase):
 
     def test_publish(self):
         c, fn, p = self.setup_for_publish(20)
-        d = p.publish("new contents of the mutable filenode")
+        # make sure the length of our contents string is not a multiple of k,
+        # to exercise the padding code.
+        d = p.publish("New contents of the mutable filenode.")
         def _done(res):
             # TODO: examine peers and check on their shares
             pass
@@ -393,11 +387,15 @@ class Publish(unittest.TestCase):
 
 
 class FakePubKey:
+    def __init__(self, count):
+        self.count = count
     def serialize(self):
-        return "PUBKEY"
+        return "PUBKEY-%d" % self.count
 class FakePrivKey:
+    def __init__(self, count):
+        self.count = count
     def serialize(self):
-        return "PRIVKEY"
+        return "PRIVKEY-%d" % self.count
     def sign(self, data):
         return "SIGN(%s)" % data