change StorageServer to take nodeid in the constructor, instead of assigning it later...
authorBrian Warner <warner@lothar.com>
Wed, 18 Feb 2009 23:23:01 +0000 (16:23 -0700)
committerBrian Warner <warner@lothar.com>
Wed, 18 Feb 2009 23:23:01 +0000 (16:23 -0700)
src/allmydata/client.py
src/allmydata/storage/server.py
src/allmydata/test/no_network.py
src/allmydata/test/test_mutable.py
src/allmydata/test/test_storage.py

index 085b29179ebe6ef174d424d824604bcef6133533..a77bda4f8172dfc1bc2670af83b4fd3a36ce1977 100644 (file)
@@ -162,7 +162,7 @@ class Client(node.Node, pollmixin.PollMixin):
             reserved = 0
         discard = self.get_config("storage", "debug_discard", False,
                                   boolean=True)
-        ss = StorageServer(storedir,
+        ss = StorageServer(storedir, self.nodeid,
                            reserved_space=reserved,
                            discard_storage=discard,
                            readonly_storage=readonly,
index fdc2a1a629c70b384adbe3f9c4ca61a94e60c087..a65801697f01668fcab1340992230e290cb0b218 100644 (file)
@@ -42,10 +42,13 @@ class StorageServer(service.MultiService, Referenceable):
     implements(RIStorageServer, IStatsProducer)
     name = 'storage'
 
-    def __init__(self, storedir, reserved_space=0,
+    def __init__(self, storedir, nodeid, reserved_space=0,
                  discard_storage=False, readonly_storage=False,
                  stats_provider=None):
         service.MultiService.__init__(self)
+        assert isinstance(nodeid, str)
+        assert len(nodeid) == 20
+        self.my_nodeid = nodeid
         self.storedir = storedir
         sharedir = os.path.join(storedir, "shares")
         fileutil.make_dirs(sharedir)
@@ -125,18 +128,6 @@ class StorageServer(service.MultiService, Referenceable):
             kwargs["facility"] = "tahoe.storage"
         return log.msg(*args, **kwargs)
 
-    def setNodeID(self, nodeid):
-        # somebody must set this before any slots can be created or leases
-        # added
-        self.my_nodeid = nodeid
-
-    def startService(self):
-        service.MultiService.startService(self)
-        if self.parent:
-            nodeid = self.parent.nodeid # 20 bytes, binary
-            assert len(nodeid) == 20
-            self.setNodeID(nodeid)
-
     def _clean_incomplete(self):
         fileutil.rm_dir(self.incomingdir)
 
index 1380720bc85e5b0c14f9364f7c2e8da5658bebd7..e6bee787035108bd6a191ab715a3f0af3abf7c26 100644 (file)
@@ -152,7 +152,7 @@ class NoNetworkGrid(service.MultiService):
             serverdir = os.path.join(basedir, "servers",
                                      idlib.shortnodeid_b2a(serverid))
             fileutil.make_dirs(serverdir)
-            ss = StorageServer(serverdir)
+            ss = StorageServer(serverdir, serverid)
             self.add_server(i, serverid, ss)
 
         for i in range(num_clients):
@@ -181,11 +181,11 @@ class NoNetworkGrid(service.MultiService):
             self.clients.append(c)
 
     def add_server(self, i, serverid, ss):
-        # TODO: ss.setServiceParent(self), but first remove the goofy
-        # self.parent.nodeid from Storage.startService . At the moment,
-        # Storage doesn't really need to be startService'd, but it will in
-        # the future.
-        ss.setNodeID(serverid)
+        # TODO: ss.setServiceParent(self), but first deal with the fact that
+        # all StorageServers are named 'storage'. At the moment, Storage
+        # doesn't really need to be startService'd, but it will in the
+        # future.
+        #ss.setServiceParent(self)
         self.servers_by_number[i] = ss
         self.servers_by_id[serverid] = wrap(ss, "storage")
         self.all_servers = frozenset(self.servers_by_id.items())
index 7da3c018fef5d92e9aaef2f71afdc2111e658059..16b632790d29ac0ecef03a6a3f6c8d8e3ab8dfe6 100644 (file)
@@ -1804,8 +1804,7 @@ class LessFakeClient(FakeClient):
         for peerid in self._peerids:
             peerdir = os.path.join(basedir, idlib.shortnodeid_b2a(peerid))
             make_dirs(peerdir)
-            ss = StorageServer(peerdir)
-            ss.setNodeID(peerid)
+            ss = StorageServer(peerdir, peerid)
             lw = LocalWrapper(ss)
             self._connections[peerid] = lw
         self.nodeid = "fakenodeid"
index e8721b038d77c408df310340e826806b4614db07..f2c9ac5be19da1729fd5b4172d79ea66de180ce0 100644 (file)
@@ -236,9 +236,8 @@ class Server(unittest.TestCase):
 
     def create(self, name, reserved_space=0, klass=StorageServer):
         workdir = self.workdir(name)
-        ss = klass(workdir, reserved_space=reserved_space,
+        ss = klass(workdir, "\x00" * 20, reserved_space=reserved_space,
                    stats_provider=FakeStatsProvider())
-        ss.setNodeID("\x00" * 20)
         ss.setServiceParent(self.sparent)
         return ss
 
@@ -586,8 +585,7 @@ class Server(unittest.TestCase):
 
     def test_readonly(self):
         workdir = self.workdir("test_readonly")
-        ss = StorageServer(workdir, readonly_storage=True)
-        ss.setNodeID("\x00" * 20)
+        ss = StorageServer(workdir, "\x00" * 20, readonly_storage=True)
         ss.setServiceParent(self.sparent)
 
         already,writers = self.allocate(ss, "vid", [0,1,2], 75)
@@ -606,8 +604,7 @@ class Server(unittest.TestCase):
     def test_discard(self):
         # discard is really only used for other tests, but we test it anyways
         workdir = self.workdir("test_discard")
-        ss = StorageServer(workdir, discard_storage=True)
-        ss.setNodeID("\x00" * 20)
+        ss = StorageServer(workdir, "\x00" * 20, discard_storage=True)
         ss.setServiceParent(self.sparent)
 
         canary = FakeCanary()
@@ -626,8 +623,7 @@ class Server(unittest.TestCase):
 
     def test_advise_corruption(self):
         workdir = self.workdir("test_advise_corruption")
-        ss = StorageServer(workdir, discard_storage=True)
-        ss.setNodeID("\x00" * 20)
+        ss = StorageServer(workdir, "\x00" * 20, discard_storage=True)
         ss.setServiceParent(self.sparent)
 
         si0_s = base32.b2a("si0")
@@ -685,9 +681,8 @@ class MutableServer(unittest.TestCase):
 
     def create(self, name):
         workdir = self.workdir(name)
-        ss = StorageServer(workdir)
+        ss = StorageServer(workdir, "\x00" * 20)
         ss.setServiceParent(self.sparent)
-        ss.setNodeID("\x00" * 20)
         return ss
 
     def test_create(self):
@@ -1235,8 +1230,7 @@ class Stats(unittest.TestCase):
 
     def create(self, name):
         workdir = self.workdir(name)
-        ss = StorageServer(workdir)
-        ss.setNodeID("\x00" * 20)
+        ss = StorageServer(workdir, "\x00" * 20)
         ss.setServiceParent(self.sparent)
         return ss