From 91d72bb504a51b27233c911afe4f882215ce2bf7 Mon Sep 17 00:00:00 2001
From: Brian Warner <warner@allmydata.com>
Date: Wed, 18 Apr 2007 15:42:34 -0700
Subject: [PATCH] test_storage: test StorageServer code too: allocation,
 lookup, multiple-writer behavior

---
 src/allmydata/test/test_storage.py | 67 +++++++++++++++++++++++++++++-
 1 file changed, 65 insertions(+), 2 deletions(-)

diff --git a/src/allmydata/test/test_storage.py b/src/allmydata/test/test_storage.py
index 31063a70..b8f9297b 100644
--- a/src/allmydata/test/test_storage.py
+++ b/src/allmydata/test/test_storage.py
@@ -1,13 +1,16 @@
 
 from twisted.trial import unittest
 
+from twisted.application import service
+from foolscap import Referenceable
 import os.path
 from allmydata import storageserver
 from allmydata.util import fileutil
 
-class Storage(unittest.TestCase):
+
+class Bucket(unittest.TestCase):
     def make_workdir(self, name):
-        basedir = os.path.join("test_storage", "Storage", name)
+        basedir = os.path.join("test_storage", "Bucket", name)
         incoming = os.path.join(basedir, "tmp", "bucket")
         final = os.path.join(basedir, "bucket")
         fileutil.make_dirs(basedir)
@@ -41,3 +44,63 @@ class Storage(unittest.TestCase):
         self.failUnlessEqual(br.remote_get_share_hashes(),
                              [(5, "5"*32), (6, "6"*32)])
 
+class Server(unittest.TestCase):
+
+    def setUp(self):
+        self.sparent = service.MultiService()
+    def tearDown(self):
+        return self.sparent.stopService()
+
+    def workdir(self, name):
+        basedir = os.path.join("test_storage", "Server", name)
+        return basedir
+
+    def create(self, name):
+        workdir = self.workdir(name)
+        ss = storageserver.StorageServer(workdir)
+        ss.setServiceParent(self.sparent)
+        return ss
+
+    def test_create(self):
+        ss = self.create("test_create")
+
+    def test_allocate(self):
+        ss = self.create("test_allocate")
+
+        self.failUnlessEqual(ss.remote_get_buckets("vid"), {})
+
+        canary = Referenceable()
+        already,writers = ss.remote_allocate_buckets("vid", [0,1,2],
+                                                     75, 25, canary)
+        self.failUnlessEqual(already, set())
+        self.failUnlessEqual(set(writers.keys()), set([0,1,2]))
+
+        # while the buckets are open, they should not count as readable
+        self.failUnlessEqual(ss.remote_get_buckets("vid"), {})
+
+        for i,wb in writers.items():
+            wb.remote_put_block(0, "%25d" % i)
+            wb.remote_close()
+
+        # now they should be readable
+        b = ss.remote_get_buckets("vid")
+        self.failUnlessEqual(set(b.keys()), set([0,1,2]))
+        self.failUnlessEqual(b[0].remote_get_block(0),
+                             "%25d" % 0)
+
+        # now if we about writing again, the server should offer those three
+        # buckets as already present
+        already,writers = ss.remote_allocate_buckets("vid", [0,1,2,3,4],
+                                                     75, 25, canary)
+        self.failUnlessEqual(already, set([0,1,2]))
+        self.failUnlessEqual(set(writers.keys()), set([3,4]))
+
+        # while those two buckets are open for writing, the server should
+        # tell new uploaders that they already exist (so that we don't try to
+        # upload into them a second time)
+
+        already,writers = ss.remote_allocate_buckets("vid", [2,3,4,5],
+                                                     75, 25, canary)
+        self.failUnlessEqual(already, set([2,3,4]))
+        self.failUnlessEqual(set(writers.keys()), set([5]))
+
-- 
2.45.2