Merge branch '3415.storage-server-python-3' into 3416.test-encode-python-3

This commit is contained in:
Itamar Turner-Trauring 2020-09-17 13:12:46 -04:00
commit b784f9654c
7 changed files with 39 additions and 14 deletions

0
newsfragments/3415.minor Normal file
View File

View 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

View File

@ -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):

View File

@ -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))

View File

@ -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)

View File

@ -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",

View File

@ -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