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