mirror of
https://github.com/tahoe-lafs/tahoe-lafs.git
synced 2025-01-03 19:54:09 +00:00
Merge branch '3415.storage-server-python-3' into 3416.test-encode-python-3
This commit is contained in:
commit
b784f9654c
0
newsfragments/3415.minor
Normal file
0
newsfragments/3415.minor
Normal file
@ -1,4 +1,18 @@
|
|||||||
from future.utils import bytes_to_native_str
|
"""
|
||||||
|
Ported to Python 3.
|
||||||
|
"""
|
||||||
|
from __future__ import division
|
||||||
|
from __future__ import absolute_import
|
||||||
|
from __future__ import print_function
|
||||||
|
from __future__ import unicode_literals
|
||||||
|
|
||||||
|
from future.utils import bytes_to_native_str, PY2
|
||||||
|
if PY2:
|
||||||
|
# Omit open() to get native behavior where open("w") always accepts native
|
||||||
|
# strings. Omit bytes so we don't leak future's custom bytes.
|
||||||
|
from future.builtins import filter, map, zip, ascii, chr, hex, input, next, oct, pow, round, super, dict, list, object, range, str, max, min # noqa: F401
|
||||||
|
|
||||||
|
|
||||||
import os, re, struct, time
|
import os, re, struct, time
|
||||||
import weakref
|
import weakref
|
||||||
import six
|
import six
|
||||||
@ -228,16 +242,18 @@ class StorageServer(service.MultiService, Referenceable):
|
|||||||
# We're on a platform that has no API to get disk stats.
|
# We're on a platform that has no API to get disk stats.
|
||||||
remaining_space = 2**64
|
remaining_space = 2**64
|
||||||
|
|
||||||
version = { "http://allmydata.org/tahoe/protocols/storage/v1" :
|
# Unicode strings might be nicer, but for now sticking to bytes since
|
||||||
{ "maximum-immutable-share-size": remaining_space,
|
# this is what the wire protocol has always been.
|
||||||
"maximum-mutable-share-size": MAX_MUTABLE_SHARE_SIZE,
|
version = { b"http://allmydata.org/tahoe/protocols/storage/v1" :
|
||||||
"available-space": remaining_space,
|
{ b"maximum-immutable-share-size": remaining_space,
|
||||||
"tolerates-immutable-read-overrun": True,
|
b"maximum-mutable-share-size": MAX_MUTABLE_SHARE_SIZE,
|
||||||
"delete-mutable-shares-with-zero-length-writev": True,
|
b"available-space": remaining_space,
|
||||||
"fills-holes-with-zero-bytes": True,
|
b"tolerates-immutable-read-overrun": True,
|
||||||
"prevents-read-past-end-of-share-data": True,
|
b"delete-mutable-shares-with-zero-length-writev": True,
|
||||||
|
b"fills-holes-with-zero-bytes": True,
|
||||||
|
b"prevents-read-past-end-of-share-data": True,
|
||||||
},
|
},
|
||||||
"application-version": str(allmydata.__full_version__),
|
b"application-version": allmydata.__full_version__.encode("utf-8"),
|
||||||
}
|
}
|
||||||
return version
|
return version
|
||||||
|
|
||||||
@ -671,7 +687,7 @@ class StorageServer(service.MultiService, Referenceable):
|
|||||||
filename = os.path.join(bucketdir, sharenum_s)
|
filename = os.path.join(bucketdir, sharenum_s)
|
||||||
msf = MutableShareFile(filename, self)
|
msf = MutableShareFile(filename, self)
|
||||||
datavs[sharenum] = msf.readv(readv)
|
datavs[sharenum] = msf.readv(readv)
|
||||||
log.msg("returning shares %s" % (datavs.keys(),),
|
log.msg("returning shares %s" % (list(datavs.keys()),),
|
||||||
facility="tahoe.storage", level=log.NOISY, parent=lp)
|
facility="tahoe.storage", level=log.NOISY, parent=lp)
|
||||||
self.add_latency("readv", time.time() - start)
|
self.add_latency("readv", time.time() - start)
|
||||||
return datavs
|
return datavs
|
||||||
|
@ -123,7 +123,7 @@ class ShouldFailMixin(object):
|
|||||||
class ReallyEqualMixin(object):
|
class ReallyEqualMixin(object):
|
||||||
def failUnlessReallyEqual(self, a, b, msg=None):
|
def failUnlessReallyEqual(self, a, b, msg=None):
|
||||||
self.assertEqual(a, b, msg)
|
self.assertEqual(a, b, msg)
|
||||||
self.assertEqual(type(a), type(b), "a :: %r, b :: %r, %r" % (a, b, msg))
|
self.assertEqual(type(a), type(b), "a :: %r (%s), b :: %r (%s), %r" % (a, type(a), b, type(b), msg))
|
||||||
|
|
||||||
|
|
||||||
def skip_if_cannot_represent_filename(u):
|
def skip_if_cannot_represent_filename(u):
|
||||||
|
@ -1,3 +1,4 @@
|
|||||||
|
from future.utils import native_str
|
||||||
|
|
||||||
import os, json, urllib
|
import os, json, urllib
|
||||||
from twisted.trial import unittest
|
from twisted.trial import unittest
|
||||||
@ -945,7 +946,7 @@ class DeepCheckWebBad(DeepCheckBase, unittest.TestCase):
|
|||||||
def _corrupt_some_shares(self, node):
|
def _corrupt_some_shares(self, node):
|
||||||
for (shnum, serverid, sharefile) in self.find_uri_shares(node.get_uri()):
|
for (shnum, serverid, sharefile) in self.find_uri_shares(node.get_uri()):
|
||||||
if shnum in (0,1):
|
if shnum in (0,1):
|
||||||
yield run_cli("debug", "corrupt-share", sharefile)
|
yield run_cli("debug", "corrupt-share", native_str(sharefile))
|
||||||
|
|
||||||
def _delete_most_shares(self, node):
|
def _delete_most_shares(self, node):
|
||||||
self.delete_shares_numbered(node.get_uri(), range(1,10))
|
self.delete_shares_numbered(node.get_uri(), range(1,10))
|
||||||
|
@ -740,6 +740,12 @@ class Server(unittest.TestCase):
|
|||||||
leases = list(ss.get_leases(b"si3"))
|
leases = list(ss.get_leases(b"si3"))
|
||||||
self.failUnlessEqual(len(leases), 2)
|
self.failUnlessEqual(len(leases), 2)
|
||||||
|
|
||||||
|
def test_have_shares(self):
|
||||||
|
"""By default the StorageServer has no shares."""
|
||||||
|
workdir = self.workdir("test_have_shares")
|
||||||
|
ss = StorageServer(workdir, b"\x00" * 20, readonly_storage=True)
|
||||||
|
self.assertFalse(ss.have_shares())
|
||||||
|
|
||||||
def test_readonly(self):
|
def test_readonly(self):
|
||||||
workdir = self.workdir("test_readonly")
|
workdir = self.workdir("test_readonly")
|
||||||
ss = StorageServer(workdir, b"\x00" * 20, readonly_storage=True)
|
ss = StorageServer(workdir, b"\x00" * 20, readonly_storage=True)
|
||||||
|
@ -41,6 +41,7 @@ PORTED_MODULES = [
|
|||||||
"allmydata.storage.immutable",
|
"allmydata.storage.immutable",
|
||||||
"allmydata.storage.lease",
|
"allmydata.storage.lease",
|
||||||
"allmydata.storage.mutable",
|
"allmydata.storage.mutable",
|
||||||
|
"allmydata.storage.server",
|
||||||
"allmydata.storage.shares",
|
"allmydata.storage.shares",
|
||||||
"allmydata.test.common_py3",
|
"allmydata.test.common_py3",
|
||||||
"allmydata.test.no_network",
|
"allmydata.test.no_network",
|
||||||
|
@ -10,7 +10,8 @@ from __future__ import unicode_literals
|
|||||||
|
|
||||||
from future.utils import PY2
|
from future.utils import PY2
|
||||||
if PY2:
|
if PY2:
|
||||||
from builtins import filter, map, zip, ascii, chr, hex, input, next, oct, open, pow, round, super, bytes, dict, list, object, range, str, max, min # noqa: F401
|
# Don't import bytes to prevent leaking future's bytes.
|
||||||
|
from builtins import filter, map, zip, ascii, chr, hex, input, next, oct, open, pow, round, super, dict, list, object, range, str, max, min # noqa: F401
|
||||||
|
|
||||||
from past.builtins import chr as byteschr
|
from past.builtins import chr as byteschr
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user