make IServer instances retain identity in copy() and deepcopy()

This commit is contained in:
Brian Warner 2012-04-04 11:14:09 -07:00
parent b38cfd0235
commit 55973e61e5
2 changed files with 18 additions and 1 deletions

View File

@ -200,6 +200,15 @@ class NativeStorageServer:
self._reconnector = None self._reconnector = None
self._trigger_cb = None self._trigger_cb = None
# Special methods used by copy.copy() and copy.deepcopy(). When those are
# used in allmydata.immutable.filenode to copy CheckResults during
# repair, we want it to treat the IServer instances as singletons, and
# not attempt to duplicate them..
def __copy__(self):
return self
def __deepcopy__(self, memodict):
return self
def __repr__(self): def __repr__(self):
return "<NativeStorageServer for %s>" % self.get_name() return "<NativeStorageServer for %s>" % self.get_name()
def get_serverid(self): def get_serverid(self):

View File

@ -26,7 +26,7 @@ from allmydata.storage.server import StorageServer, storage_index_to_dir
from allmydata.util import fileutil, idlib, hashutil from allmydata.util import fileutil, idlib, hashutil
from allmydata.util.hashutil import sha1 from allmydata.util.hashutil import sha1
from allmydata.test.common_web import HTTPClientGETFactory from allmydata.test.common_web import HTTPClientGETFactory
from allmydata.interfaces import IStorageBroker from allmydata.interfaces import IStorageBroker, IServer
from allmydata.test.common import TEST_RSA_KEY_SIZE from allmydata.test.common import TEST_RSA_KEY_SIZE
@ -120,11 +120,19 @@ def wrap_storage_server(original):
return wrapper return wrapper
class NoNetworkServer: class NoNetworkServer:
implements(IServer)
def __init__(self, serverid, rref): def __init__(self, serverid, rref):
self.serverid = serverid self.serverid = serverid
self.rref = rref self.rref = rref
def __repr__(self): def __repr__(self):
return "<NoNetworkServer for %s>" % self.get_name() return "<NoNetworkServer for %s>" % self.get_name()
# Special method used by copy.copy() and copy.deepcopy(). When those are
# used in allmydata.immutable.filenode to copy CheckResults during
# repair, we want it to treat the IServer instances as singletons.
def __copy__(self):
return self
def __deepcopy__(self, memodict):
return self
def get_serverid(self): def get_serverid(self):
return self.serverid return self.serverid
def get_permutation_seed(self): def get_permutation_seed(self):