More passing tests.
This commit is contained in:
parent
5ad5b79cdd
commit
50007ac868
|
@ -1,3 +1,4 @@
|
||||||
|
from past.utils import old_div
|
||||||
|
|
||||||
import struct
|
import struct
|
||||||
from allmydata.mutable.common import NeedMoreDataError, UnknownVersionError, \
|
from allmydata.mutable.common import NeedMoreDataError, UnknownVersionError, \
|
||||||
|
@ -180,11 +181,11 @@ def pack_offsets(verification_key_length, signature_length,
|
||||||
def pack_share(prefix, verification_key, signature,
|
def pack_share(prefix, verification_key, signature,
|
||||||
share_hash_chain, block_hash_tree,
|
share_hash_chain, block_hash_tree,
|
||||||
share_data, encprivkey):
|
share_data, encprivkey):
|
||||||
share_hash_chain_s = "".join([struct.pack(">H32s", i, share_hash_chain[i])
|
share_hash_chain_s = b"".join([struct.pack(">H32s", i, share_hash_chain[i])
|
||||||
for i in sorted(share_hash_chain.keys())])
|
for i in sorted(share_hash_chain.keys())])
|
||||||
for h in block_hash_tree:
|
for h in block_hash_tree:
|
||||||
assert len(h) == 32
|
assert len(h) == 32
|
||||||
block_hash_tree_s = "".join(block_hash_tree)
|
block_hash_tree_s = b"".join(block_hash_tree)
|
||||||
|
|
||||||
offsets = pack_offsets(len(verification_key),
|
offsets = pack_offsets(len(verification_key),
|
||||||
len(signature),
|
len(signature),
|
||||||
|
@ -192,14 +193,14 @@ def pack_share(prefix, verification_key, signature,
|
||||||
len(block_hash_tree_s),
|
len(block_hash_tree_s),
|
||||||
len(share_data),
|
len(share_data),
|
||||||
len(encprivkey))
|
len(encprivkey))
|
||||||
final_share = "".join([prefix,
|
final_share = b"".join([prefix,
|
||||||
offsets,
|
offsets,
|
||||||
verification_key,
|
verification_key,
|
||||||
signature,
|
signature,
|
||||||
share_hash_chain_s,
|
share_hash_chain_s,
|
||||||
block_hash_tree_s,
|
block_hash_tree_s,
|
||||||
share_data,
|
share_data,
|
||||||
encprivkey])
|
encprivkey])
|
||||||
return final_share
|
return final_share
|
||||||
|
|
||||||
def pack_prefix(seqnum, root_hash, IV,
|
def pack_prefix(seqnum, root_hash, IV,
|
||||||
|
@ -255,7 +256,7 @@ class SDMFSlotWriteProxy(object):
|
||||||
self._required_shares)
|
self._required_shares)
|
||||||
assert expected_segment_size == segment_size
|
assert expected_segment_size == segment_size
|
||||||
|
|
||||||
self._block_size = self._segment_size / self._required_shares
|
self._block_size = old_div(self._segment_size, self._required_shares)
|
||||||
|
|
||||||
# This is meant to mimic how SDMF files were built before MDMF
|
# This is meant to mimic how SDMF files were built before MDMF
|
||||||
# entered the picture: we generate each share in its entirety,
|
# entered the picture: we generate each share in its entirety,
|
||||||
|
@ -343,7 +344,7 @@ class SDMFSlotWriteProxy(object):
|
||||||
assert len(h) == HASH_SIZE
|
assert len(h) == HASH_SIZE
|
||||||
|
|
||||||
# serialize the blockhashes, then set them.
|
# serialize the blockhashes, then set them.
|
||||||
blockhashes_s = "".join(blockhashes)
|
blockhashes_s = b"".join(blockhashes)
|
||||||
self._share_pieces['block_hash_tree'] = blockhashes_s
|
self._share_pieces['block_hash_tree'] = blockhashes_s
|
||||||
|
|
||||||
return defer.succeed(None)
|
return defer.succeed(None)
|
||||||
|
@ -354,12 +355,12 @@ class SDMFSlotWriteProxy(object):
|
||||||
Add the share hash chain to the share.
|
Add the share hash chain to the share.
|
||||||
"""
|
"""
|
||||||
assert isinstance(sharehashes, dict)
|
assert isinstance(sharehashes, dict)
|
||||||
for h in sharehashes.itervalues():
|
for h in sharehashes.values():
|
||||||
assert len(h) == HASH_SIZE
|
assert len(h) == HASH_SIZE
|
||||||
|
|
||||||
# serialize the sharehashes, then set them.
|
# serialize the sharehashes, then set them.
|
||||||
sharehashes_s = "".join([struct.pack(">H32s", i, sharehashes[i])
|
sharehashes_s = b"".join([struct.pack(">H32s", i, sharehashes[i])
|
||||||
for i in sorted(sharehashes.keys())])
|
for i in sorted(sharehashes.keys())])
|
||||||
self._share_pieces['share_hash_chain'] = sharehashes_s
|
self._share_pieces['share_hash_chain'] = sharehashes_s
|
||||||
|
|
||||||
return defer.succeed(None)
|
return defer.succeed(None)
|
||||||
|
@ -383,7 +384,7 @@ class SDMFSlotWriteProxy(object):
|
||||||
assert len(salt) == SALT_SIZE
|
assert len(salt) == SALT_SIZE
|
||||||
|
|
||||||
self._share_pieces['salt'] = salt
|
self._share_pieces['salt'] = salt
|
||||||
self._share_pieces['sharedata'] = ""
|
self._share_pieces['sharedata'] = b""
|
||||||
|
|
||||||
|
|
||||||
def get_signable(self):
|
def get_signable(self):
|
||||||
|
@ -519,14 +520,14 @@ class SDMFSlotWriteProxy(object):
|
||||||
# to the remote server in one write.
|
# to the remote server in one write.
|
||||||
offsets = self._pack_offsets()
|
offsets = self._pack_offsets()
|
||||||
prefix = self.get_signable()
|
prefix = self.get_signable()
|
||||||
final_share = "".join([prefix,
|
final_share = b"".join([prefix,
|
||||||
offsets,
|
offsets,
|
||||||
self._share_pieces['verification_key'],
|
self._share_pieces['verification_key'],
|
||||||
self._share_pieces['signature'],
|
self._share_pieces['signature'],
|
||||||
self._share_pieces['share_hash_chain'],
|
self._share_pieces['share_hash_chain'],
|
||||||
self._share_pieces['block_hash_tree'],
|
self._share_pieces['block_hash_tree'],
|
||||||
self._share_pieces['sharedata'],
|
self._share_pieces['sharedata'],
|
||||||
self._share_pieces['encprivkey']])
|
self._share_pieces['encprivkey']])
|
||||||
|
|
||||||
# Our only data vector is going to be writing the final share,
|
# Our only data vector is going to be writing the final share,
|
||||||
# in its entirely.
|
# in its entirely.
|
||||||
|
@ -788,7 +789,7 @@ class MDMFSlotWriteProxy(object):
|
||||||
# and also because it provides a useful amount of bounds checking.
|
# and also because it provides a useful amount of bounds checking.
|
||||||
self._num_segments = mathutil.div_ceil(self._data_length,
|
self._num_segments = mathutil.div_ceil(self._data_length,
|
||||||
self._segment_size)
|
self._segment_size)
|
||||||
self._block_size = self._segment_size / self._required_shares
|
self._block_size = old_div(self._segment_size, self._required_shares)
|
||||||
# We also calculate the share size, to help us with block
|
# We also calculate the share size, to help us with block
|
||||||
# constraints later.
|
# constraints later.
|
||||||
tail_size = self._data_length % self._segment_size
|
tail_size = self._data_length % self._segment_size
|
||||||
|
@ -797,7 +798,7 @@ class MDMFSlotWriteProxy(object):
|
||||||
else:
|
else:
|
||||||
self._tail_block_size = mathutil.next_multiple(tail_size,
|
self._tail_block_size = mathutil.next_multiple(tail_size,
|
||||||
self._required_shares)
|
self._required_shares)
|
||||||
self._tail_block_size /= self._required_shares
|
self._tail_block_size = old_div(self._tail_block_size, self._required_shares)
|
||||||
|
|
||||||
# We already know where the sharedata starts; right after the end
|
# We already know where the sharedata starts; right after the end
|
||||||
# of the header (which is defined as the signable part + the offsets)
|
# of the header (which is defined as the signable part + the offsets)
|
||||||
|
@ -868,7 +869,7 @@ class MDMFSlotWriteProxy(object):
|
||||||
else:
|
else:
|
||||||
checkstring = seqnum_or_checkstring
|
checkstring = seqnum_or_checkstring
|
||||||
|
|
||||||
if checkstring == "":
|
if checkstring == b"":
|
||||||
# We special-case this, since len("") = 0, but we need
|
# We special-case this, since len("") = 0, but we need
|
||||||
# length of 1 for the case of an empty share to work on the
|
# length of 1 for the case of an empty share to work on the
|
||||||
# storage server, which is what a checkstring that is the
|
# storage server, which is what a checkstring that is the
|
||||||
|
@ -876,7 +877,7 @@ class MDMFSlotWriteProxy(object):
|
||||||
self._testvs = []
|
self._testvs = []
|
||||||
else:
|
else:
|
||||||
self._testvs = []
|
self._testvs = []
|
||||||
self._testvs.append((0, len(checkstring), "eq", checkstring))
|
self._testvs.append((0, len(checkstring), b"eq", checkstring))
|
||||||
|
|
||||||
|
|
||||||
def __repr__(self):
|
def __repr__(self):
|
||||||
|
@ -893,7 +894,7 @@ class MDMFSlotWriteProxy(object):
|
||||||
if self._root_hash:
|
if self._root_hash:
|
||||||
roothash = self._root_hash
|
roothash = self._root_hash
|
||||||
else:
|
else:
|
||||||
roothash = "\x00" * 32
|
roothash = b"\x00" * 32
|
||||||
return struct.pack(MDMFCHECKSTRING,
|
return struct.pack(MDMFCHECKSTRING,
|
||||||
1,
|
1,
|
||||||
self._seqnum,
|
self._seqnum,
|
||||||
|
@ -964,7 +965,7 @@ class MDMFSlotWriteProxy(object):
|
||||||
|
|
||||||
assert isinstance(blockhashes, list)
|
assert isinstance(blockhashes, list)
|
||||||
|
|
||||||
blockhashes_s = "".join(blockhashes)
|
blockhashes_s = b"".join(blockhashes)
|
||||||
self._offsets['EOF'] = self._offsets['block_hash_tree'] + len(blockhashes_s)
|
self._offsets['EOF'] = self._offsets['block_hash_tree'] + len(blockhashes_s)
|
||||||
|
|
||||||
self._writevs.append(tuple([self._offsets['block_hash_tree'],
|
self._writevs.append(tuple([self._offsets['block_hash_tree'],
|
||||||
|
@ -998,7 +999,7 @@ class MDMFSlotWriteProxy(object):
|
||||||
if "verification_key" in self._offsets:
|
if "verification_key" in self._offsets:
|
||||||
raise LayoutInvalid("You must write the share hash chain "
|
raise LayoutInvalid("You must write the share hash chain "
|
||||||
"before you write the signature")
|
"before you write the signature")
|
||||||
sharehashes_s = "".join([struct.pack(">H32s", i, sharehashes[i])
|
sharehashes_s = b"".join([struct.pack(">H32s", i, sharehashes[i])
|
||||||
for i in sorted(sharehashes.keys())])
|
for i in sorted(sharehashes.keys())])
|
||||||
self._offsets['signature'] = self._offsets['share_hash_chain'] + \
|
self._offsets['signature'] = self._offsets['share_hash_chain'] + \
|
||||||
len(sharehashes_s)
|
len(sharehashes_s)
|
||||||
|
@ -1149,7 +1150,7 @@ class MDMFSlotWriteProxy(object):
|
||||||
tw_vectors = {}
|
tw_vectors = {}
|
||||||
if not self._testvs:
|
if not self._testvs:
|
||||||
self._testvs = []
|
self._testvs = []
|
||||||
self._testvs.append(tuple([0, 1, "eq", ""]))
|
self._testvs.append(tuple([0, 1, b"eq", b""]))
|
||||||
if not self._written:
|
if not self._written:
|
||||||
# Write a new checkstring to the share when we write it, so
|
# Write a new checkstring to the share when we write it, so
|
||||||
# that we have something to check later.
|
# that we have something to check later.
|
||||||
|
@ -1157,7 +1158,7 @@ class MDMFSlotWriteProxy(object):
|
||||||
datavs.append((0, new_checkstring))
|
datavs.append((0, new_checkstring))
|
||||||
def _first_write():
|
def _first_write():
|
||||||
self._written = True
|
self._written = True
|
||||||
self._testvs = [(0, len(new_checkstring), "eq", new_checkstring)]
|
self._testvs = [(0, len(new_checkstring), b"eq", new_checkstring)]
|
||||||
on_success = _first_write
|
on_success = _first_write
|
||||||
tw_vectors[self.shnum] = (self._testvs, datavs, None)
|
tw_vectors[self.shnum] = (self._testvs, datavs, None)
|
||||||
d = self._storage_server.slot_testv_and_readv_and_writev(
|
d = self._storage_server.slot_testv_and_readv_and_writev(
|
||||||
|
@ -1317,7 +1318,7 @@ class MDMFSlotReadProxy(object):
|
||||||
self._segment_size = segsize
|
self._segment_size = segsize
|
||||||
self._data_length = datalen
|
self._data_length = datalen
|
||||||
|
|
||||||
self._block_size = self._segment_size / self._required_shares
|
self._block_size = old_div(self._segment_size, self._required_shares)
|
||||||
# We can upload empty files, and need to account for this fact
|
# We can upload empty files, and need to account for this fact
|
||||||
# so as to avoid zero-division and zero-modulo errors.
|
# so as to avoid zero-division and zero-modulo errors.
|
||||||
if datalen > 0:
|
if datalen > 0:
|
||||||
|
@ -1329,7 +1330,7 @@ class MDMFSlotReadProxy(object):
|
||||||
else:
|
else:
|
||||||
self._tail_block_size = mathutil.next_multiple(tail_size,
|
self._tail_block_size = mathutil.next_multiple(tail_size,
|
||||||
self._required_shares)
|
self._required_shares)
|
||||||
self._tail_block_size /= self._required_shares
|
self._tail_block_size = old_div(self._tail_block_size, self._required_shares)
|
||||||
|
|
||||||
return encoding_parameters
|
return encoding_parameters
|
||||||
|
|
||||||
|
|
|
@ -1451,22 +1451,22 @@ class MDMFProxies(unittest.TestCase, ShouldFailMixin):
|
||||||
self.ss = self.create("MDMFProxies storage test server")
|
self.ss = self.create("MDMFProxies storage test server")
|
||||||
self.rref = RemoteBucket(self.ss)
|
self.rref = RemoteBucket(self.ss)
|
||||||
self.storage_server = _StorageServer(lambda: self.rref)
|
self.storage_server = _StorageServer(lambda: self.rref)
|
||||||
self.secrets = (self.write_enabler("we_secret"),
|
self.secrets = (self.write_enabler(b"we_secret"),
|
||||||
self.renew_secret("renew_secret"),
|
self.renew_secret(b"renew_secret"),
|
||||||
self.cancel_secret("cancel_secret"))
|
self.cancel_secret(b"cancel_secret"))
|
||||||
self.segment = "aaaaaa"
|
self.segment = b"aaaaaa"
|
||||||
self.block = "aa"
|
self.block = b"aa"
|
||||||
self.salt = "a" * 16
|
self.salt = b"a" * 16
|
||||||
self.block_hash = "a" * 32
|
self.block_hash = b"a" * 32
|
||||||
self.block_hash_tree = [self.block_hash for i in xrange(6)]
|
self.block_hash_tree = [self.block_hash for i in range(6)]
|
||||||
self.share_hash = self.block_hash
|
self.share_hash = self.block_hash
|
||||||
self.share_hash_chain = dict([(i, self.share_hash) for i in xrange(6)])
|
self.share_hash_chain = dict([(i, self.share_hash) for i in range(6)])
|
||||||
self.signature = "foobarbaz"
|
self.signature = b"foobarbaz"
|
||||||
self.verification_key = "vvvvvv"
|
self.verification_key = b"vvvvvv"
|
||||||
self.encprivkey = "private"
|
self.encprivkey = b"private"
|
||||||
self.root_hash = self.block_hash
|
self.root_hash = self.block_hash
|
||||||
self.salt_hash = self.root_hash
|
self.salt_hash = self.root_hash
|
||||||
self.salt_hash_tree = [self.salt_hash for i in xrange(6)]
|
self.salt_hash_tree = [self.salt_hash for i in range(6)]
|
||||||
self.block_hash_tree_s = self.serialize_blockhashes(self.block_hash_tree)
|
self.block_hash_tree_s = self.serialize_blockhashes(self.block_hash_tree)
|
||||||
self.share_hash_chain_s = self.serialize_sharehashes(self.share_hash_chain)
|
self.share_hash_chain_s = self.serialize_sharehashes(self.share_hash_chain)
|
||||||
# blockhashes and salt hashes are serialized in the same way,
|
# blockhashes and salt hashes are serialized in the same way,
|
||||||
|
@ -1481,15 +1481,19 @@ class MDMFProxies(unittest.TestCase, ShouldFailMixin):
|
||||||
|
|
||||||
|
|
||||||
def write_enabler(self, we_tag):
|
def write_enabler(self, we_tag):
|
||||||
return hashutil.tagged_hash("we_blah", we_tag)
|
return hashutil.tagged_hash(b"we_blah", we_tag)
|
||||||
|
|
||||||
|
|
||||||
def renew_secret(self, tag):
|
def renew_secret(self, tag):
|
||||||
return hashutil.tagged_hash("renew_blah", str(tag))
|
if isinstance(tag, int):
|
||||||
|
tag = b"%d" % tag
|
||||||
|
return hashutil.tagged_hash(b"renew_blah", tag)
|
||||||
|
|
||||||
|
|
||||||
def cancel_secret(self, tag):
|
def cancel_secret(self, tag):
|
||||||
return hashutil.tagged_hash("cancel_blah", str(tag))
|
if isinstance(tag, int):
|
||||||
|
tag = b"%d" % tag
|
||||||
|
return hashutil.tagged_hash(b"cancel_blah", tag)
|
||||||
|
|
||||||
|
|
||||||
def workdir(self, name):
|
def workdir(self, name):
|
||||||
|
@ -1531,14 +1535,14 @@ class MDMFProxies(unittest.TestCase, ShouldFailMixin):
|
||||||
6,
|
6,
|
||||||
36)
|
36)
|
||||||
# Now we'll build the offsets.
|
# Now we'll build the offsets.
|
||||||
sharedata = ""
|
sharedata = b""
|
||||||
if not tail_segment and not empty:
|
if not tail_segment and not empty:
|
||||||
for i in xrange(6):
|
for i in range(6):
|
||||||
sharedata += self.salt + self.block
|
sharedata += self.salt + self.block
|
||||||
elif tail_segment:
|
elif tail_segment:
|
||||||
for i in xrange(5):
|
for i in range(5):
|
||||||
sharedata += self.salt + self.block
|
sharedata += self.salt + self.block
|
||||||
sharedata += self.salt + "a"
|
sharedata += self.salt + b"a"
|
||||||
|
|
||||||
# The encrypted private key comes after the shares + salts
|
# The encrypted private key comes after the shares + salts
|
||||||
offset_size = struct.calcsize(MDMFOFFSETS)
|
offset_size = struct.calcsize(MDMFOFFSETS)
|
||||||
|
@ -1592,7 +1596,7 @@ class MDMFProxies(unittest.TestCase, ShouldFailMixin):
|
||||||
# and the verification key
|
# and the verification key
|
||||||
data += self.verification_key
|
data += self.verification_key
|
||||||
# Then we'll add in gibberish until we get to the right point.
|
# Then we'll add in gibberish until we get to the right point.
|
||||||
nulls = b"".join([b" " for i in xrange(len(data), share_data_offset)])
|
nulls = b"".join([b" " for i in range(len(data), share_data_offset)])
|
||||||
data += nulls
|
data += nulls
|
||||||
|
|
||||||
# Then the share data
|
# Then the share data
|
||||||
|
@ -1626,11 +1630,11 @@ class MDMFProxies(unittest.TestCase, ShouldFailMixin):
|
||||||
|
|
||||||
def build_test_sdmf_share(self, empty=False):
|
def build_test_sdmf_share(self, empty=False):
|
||||||
if empty:
|
if empty:
|
||||||
sharedata = ""
|
sharedata = b""
|
||||||
else:
|
else:
|
||||||
sharedata = self.segment * 6
|
sharedata = self.segment * 6
|
||||||
self.sharedata = sharedata
|
self.sharedata = sharedata
|
||||||
blocksize = len(sharedata) / 3
|
blocksize = len(sharedata) // 3
|
||||||
block = sharedata[:blocksize]
|
block = sharedata[:blocksize]
|
||||||
self.blockdata = block
|
self.blockdata = block
|
||||||
prefix = struct.pack(">BQ32s16s BBQQ",
|
prefix = struct.pack(">BQ32s16s BBQQ",
|
||||||
|
@ -1691,7 +1695,7 @@ class MDMFProxies(unittest.TestCase, ShouldFailMixin):
|
||||||
|
|
||||||
|
|
||||||
def test_read(self):
|
def test_read(self):
|
||||||
self.write_test_share_to_server("si1")
|
self.write_test_share_to_server(b"si1")
|
||||||
mr = MDMFSlotReadProxy(self.storage_server, b"si1", 0)
|
mr = MDMFSlotReadProxy(self.storage_server, b"si1", 0)
|
||||||
# Check that every method equals what we expect it to.
|
# Check that every method equals what we expect it to.
|
||||||
d = defer.succeed(None)
|
d = defer.succeed(None)
|
||||||
|
@ -1700,7 +1704,7 @@ class MDMFProxies(unittest.TestCase, ShouldFailMixin):
|
||||||
self.failUnlessEqual(block, self.block)
|
self.failUnlessEqual(block, self.block)
|
||||||
self.failUnlessEqual(salt, self.salt)
|
self.failUnlessEqual(salt, self.salt)
|
||||||
|
|
||||||
for i in xrange(6):
|
for i in range(6):
|
||||||
d.addCallback(lambda ignored, i=i:
|
d.addCallback(lambda ignored, i=i:
|
||||||
mr.get_block_and_salt(i))
|
mr.get_block_and_salt(i))
|
||||||
d.addCallback(_check_block_and_salt)
|
d.addCallback(_check_block_and_salt)
|
||||||
|
@ -1763,7 +1767,7 @@ class MDMFProxies(unittest.TestCase, ShouldFailMixin):
|
||||||
|
|
||||||
|
|
||||||
def test_read_with_different_tail_segment_size(self):
|
def test_read_with_different_tail_segment_size(self):
|
||||||
self.write_test_share_to_server("si1", tail_segment=True)
|
self.write_test_share_to_server(b"si1", tail_segment=True)
|
||||||
mr = MDMFSlotReadProxy(self.storage_server, b"si1", 0)
|
mr = MDMFSlotReadProxy(self.storage_server, b"si1", 0)
|
||||||
d = mr.get_block_and_salt(5)
|
d = mr.get_block_and_salt(5)
|
||||||
def _check_tail_segment(results):
|
def _check_tail_segment(results):
|
||||||
|
@ -1775,7 +1779,7 @@ class MDMFProxies(unittest.TestCase, ShouldFailMixin):
|
||||||
|
|
||||||
|
|
||||||
def test_get_block_with_invalid_segnum(self):
|
def test_get_block_with_invalid_segnum(self):
|
||||||
self.write_test_share_to_server("si1")
|
self.write_test_share_to_server(b"si1")
|
||||||
mr = MDMFSlotReadProxy(self.storage_server, b"si1", 0)
|
mr = MDMFSlotReadProxy(self.storage_server, b"si1", 0)
|
||||||
d = defer.succeed(None)
|
d = defer.succeed(None)
|
||||||
d.addCallback(lambda ignored:
|
d.addCallback(lambda ignored:
|
||||||
|
@ -1786,7 +1790,7 @@ class MDMFProxies(unittest.TestCase, ShouldFailMixin):
|
||||||
|
|
||||||
|
|
||||||
def test_get_encoding_parameters_first(self):
|
def test_get_encoding_parameters_first(self):
|
||||||
self.write_test_share_to_server("si1")
|
self.write_test_share_to_server(b"si1")
|
||||||
mr = MDMFSlotReadProxy(self.storage_server, b"si1", 0)
|
mr = MDMFSlotReadProxy(self.storage_server, b"si1", 0)
|
||||||
d = mr.get_encoding_parameters()
|
d = mr.get_encoding_parameters()
|
||||||
def _check_encoding_parameters(args):
|
def _check_encoding_parameters(args):
|
||||||
|
@ -1800,7 +1804,7 @@ class MDMFProxies(unittest.TestCase, ShouldFailMixin):
|
||||||
|
|
||||||
|
|
||||||
def test_get_seqnum_first(self):
|
def test_get_seqnum_first(self):
|
||||||
self.write_test_share_to_server("si1")
|
self.write_test_share_to_server(b"si1")
|
||||||
mr = MDMFSlotReadProxy(self.storage_server, b"si1", 0)
|
mr = MDMFSlotReadProxy(self.storage_server, b"si1", 0)
|
||||||
d = mr.get_seqnum()
|
d = mr.get_seqnum()
|
||||||
d.addCallback(lambda seqnum:
|
d.addCallback(lambda seqnum:
|
||||||
|
@ -1809,7 +1813,7 @@ class MDMFProxies(unittest.TestCase, ShouldFailMixin):
|
||||||
|
|
||||||
|
|
||||||
def test_get_root_hash_first(self):
|
def test_get_root_hash_first(self):
|
||||||
self.write_test_share_to_server("si1")
|
self.write_test_share_to_server(b"si1")
|
||||||
mr = MDMFSlotReadProxy(self.storage_server, b"si1", 0)
|
mr = MDMFSlotReadProxy(self.storage_server, b"si1", 0)
|
||||||
d = mr.get_root_hash()
|
d = mr.get_root_hash()
|
||||||
d.addCallback(lambda root_hash:
|
d.addCallback(lambda root_hash:
|
||||||
|
@ -1818,7 +1822,7 @@ class MDMFProxies(unittest.TestCase, ShouldFailMixin):
|
||||||
|
|
||||||
|
|
||||||
def test_get_checkstring_first(self):
|
def test_get_checkstring_first(self):
|
||||||
self.write_test_share_to_server("si1")
|
self.write_test_share_to_server(b"si1")
|
||||||
mr = MDMFSlotReadProxy(self.storage_server, b"si1", 0)
|
mr = MDMFSlotReadProxy(self.storage_server, b"si1", 0)
|
||||||
d = mr.get_checkstring()
|
d = mr.get_checkstring()
|
||||||
d.addCallback(lambda checkstring:
|
d.addCallback(lambda checkstring:
|
||||||
|
@ -1832,9 +1836,9 @@ class MDMFProxies(unittest.TestCase, ShouldFailMixin):
|
||||||
# the test vectors failed, this read vector can help us to
|
# the test vectors failed, this read vector can help us to
|
||||||
# diagnose the problem. This test ensures that the read vector
|
# diagnose the problem. This test ensures that the read vector
|
||||||
# is working appropriately.
|
# is working appropriately.
|
||||||
mw = self._make_new_mw("si1", 0)
|
mw = self._make_new_mw(b"si1", 0)
|
||||||
|
|
||||||
for i in xrange(6):
|
for i in range(6):
|
||||||
mw.put_block(self.block, i, self.salt)
|
mw.put_block(self.block, i, self.salt)
|
||||||
mw.put_encprivkey(self.encprivkey)
|
mw.put_encprivkey(self.encprivkey)
|
||||||
mw.put_blockhashes(self.block_hash_tree)
|
mw.put_blockhashes(self.block_hash_tree)
|
||||||
|
@ -1849,7 +1853,7 @@ class MDMFProxies(unittest.TestCase, ShouldFailMixin):
|
||||||
self.failUnless(result)
|
self.failUnless(result)
|
||||||
self.failIf(readv)
|
self.failIf(readv)
|
||||||
self.old_checkstring = mw.get_checkstring()
|
self.old_checkstring = mw.get_checkstring()
|
||||||
mw.set_checkstring("")
|
mw.set_checkstring(b"")
|
||||||
d.addCallback(_then)
|
d.addCallback(_then)
|
||||||
d.addCallback(lambda ignored:
|
d.addCallback(lambda ignored:
|
||||||
mw.finish_publishing())
|
mw.finish_publishing())
|
||||||
|
@ -1866,9 +1870,9 @@ class MDMFProxies(unittest.TestCase, ShouldFailMixin):
|
||||||
|
|
||||||
|
|
||||||
def test_private_key_after_share_hash_chain(self):
|
def test_private_key_after_share_hash_chain(self):
|
||||||
mw = self._make_new_mw("si1", 0)
|
mw = self._make_new_mw(b"si1", 0)
|
||||||
d = defer.succeed(None)
|
d = defer.succeed(None)
|
||||||
for i in xrange(6):
|
for i in range(6):
|
||||||
d.addCallback(lambda ignored, i=i:
|
d.addCallback(lambda ignored, i=i:
|
||||||
mw.put_block(self.block, i, self.salt))
|
mw.put_block(self.block, i, self.salt))
|
||||||
d.addCallback(lambda ignored:
|
d.addCallback(lambda ignored:
|
||||||
|
@ -1885,10 +1889,10 @@ class MDMFProxies(unittest.TestCase, ShouldFailMixin):
|
||||||
|
|
||||||
|
|
||||||
def test_signature_after_verification_key(self):
|
def test_signature_after_verification_key(self):
|
||||||
mw = self._make_new_mw("si1", 0)
|
mw = self._make_new_mw(b"si1", 0)
|
||||||
d = defer.succeed(None)
|
d = defer.succeed(None)
|
||||||
# Put everything up to and including the verification key.
|
# Put everything up to and including the verification key.
|
||||||
for i in xrange(6):
|
for i in range(6):
|
||||||
d.addCallback(lambda ignored, i=i:
|
d.addCallback(lambda ignored, i=i:
|
||||||
mw.put_block(self.block, i, self.salt))
|
mw.put_block(self.block, i, self.salt))
|
||||||
d.addCallback(lambda ignored:
|
d.addCallback(lambda ignored:
|
||||||
|
@ -1915,8 +1919,8 @@ class MDMFProxies(unittest.TestCase, ShouldFailMixin):
|
||||||
# Make two mutable writers, both pointing to the same storage
|
# Make two mutable writers, both pointing to the same storage
|
||||||
# server, both at the same storage index, and try writing to the
|
# server, both at the same storage index, and try writing to the
|
||||||
# same share.
|
# same share.
|
||||||
mw1 = self._make_new_mw("si1", 0)
|
mw1 = self._make_new_mw(b"si1", 0)
|
||||||
mw2 = self._make_new_mw("si1", 0)
|
mw2 = self._make_new_mw(b"si1", 0)
|
||||||
|
|
||||||
def _check_success(results):
|
def _check_success(results):
|
||||||
result, readvs = results
|
result, readvs = results
|
||||||
|
@ -1927,7 +1931,7 @@ class MDMFProxies(unittest.TestCase, ShouldFailMixin):
|
||||||
self.failIf(result)
|
self.failIf(result)
|
||||||
|
|
||||||
def _write_share(mw):
|
def _write_share(mw):
|
||||||
for i in xrange(6):
|
for i in range(6):
|
||||||
mw.put_block(self.block, i, self.salt)
|
mw.put_block(self.block, i, self.salt)
|
||||||
mw.put_encprivkey(self.encprivkey)
|
mw.put_encprivkey(self.encprivkey)
|
||||||
mw.put_blockhashes(self.block_hash_tree)
|
mw.put_blockhashes(self.block_hash_tree)
|
||||||
|
@ -1947,9 +1951,9 @@ class MDMFProxies(unittest.TestCase, ShouldFailMixin):
|
||||||
def test_invalid_salt_size(self):
|
def test_invalid_salt_size(self):
|
||||||
# Salts need to be 16 bytes in size. Writes that attempt to
|
# Salts need to be 16 bytes in size. Writes that attempt to
|
||||||
# write more or less than this should be rejected.
|
# write more or less than this should be rejected.
|
||||||
mw = self._make_new_mw("si1", 0)
|
mw = self._make_new_mw(b"si1", 0)
|
||||||
invalid_salt = "a" * 17 # 17 bytes
|
invalid_salt = b"a" * 17 # 17 bytes
|
||||||
another_invalid_salt = "b" * 15 # 15 bytes
|
another_invalid_salt = b"b" * 15 # 15 bytes
|
||||||
d = defer.succeed(None)
|
d = defer.succeed(None)
|
||||||
d.addCallback(lambda ignored:
|
d.addCallback(lambda ignored:
|
||||||
self.shouldFail(LayoutInvalid, "salt too big",
|
self.shouldFail(LayoutInvalid, "salt too big",
|
||||||
|
@ -1977,9 +1981,9 @@ class MDMFProxies(unittest.TestCase, ShouldFailMixin):
|
||||||
res, d = results
|
res, d = results
|
||||||
self.failUnless(results)
|
self.failUnless(results)
|
||||||
|
|
||||||
mw = self._make_new_mw("si1", 0)
|
mw = self._make_new_mw(b"si1", 0)
|
||||||
mw.set_checkstring("this is a lie")
|
mw.set_checkstring(b"this is a lie")
|
||||||
for i in xrange(6):
|
for i in range(6):
|
||||||
mw.put_block(self.block, i, self.salt)
|
mw.put_block(self.block, i, self.salt)
|
||||||
mw.put_encprivkey(self.encprivkey)
|
mw.put_encprivkey(self.encprivkey)
|
||||||
mw.put_blockhashes(self.block_hash_tree)
|
mw.put_blockhashes(self.block_hash_tree)
|
||||||
|
@ -1990,7 +1994,7 @@ class MDMFProxies(unittest.TestCase, ShouldFailMixin):
|
||||||
d = mw.finish_publishing()
|
d = mw.finish_publishing()
|
||||||
d.addCallback(_check_failure)
|
d.addCallback(_check_failure)
|
||||||
d.addCallback(lambda ignored:
|
d.addCallback(lambda ignored:
|
||||||
mw.set_checkstring(""))
|
mw.set_checkstring(b""))
|
||||||
d.addCallback(lambda ignored:
|
d.addCallback(lambda ignored:
|
||||||
mw.finish_publishing())
|
mw.finish_publishing())
|
||||||
d.addCallback(_check_success)
|
d.addCallback(_check_success)
|
||||||
|
@ -2010,7 +2014,7 @@ class MDMFProxies(unittest.TestCase, ShouldFailMixin):
|
||||||
def test_write(self):
|
def test_write(self):
|
||||||
# This translates to a file with 6 6-byte segments, and with 2-byte
|
# This translates to a file with 6 6-byte segments, and with 2-byte
|
||||||
# blocks.
|
# blocks.
|
||||||
mw = self._make_new_mw("si1", 0)
|
mw = self._make_new_mw(b"si1", 0)
|
||||||
# Test writing some blocks.
|
# Test writing some blocks.
|
||||||
read = self.ss.remote_slot_readv
|
read = self.ss.remote_slot_readv
|
||||||
expected_private_key_offset = struct.calcsize(MDMFHEADER)
|
expected_private_key_offset = struct.calcsize(MDMFHEADER)
|
||||||
|
@ -2021,7 +2025,7 @@ class MDMFProxies(unittest.TestCase, ShouldFailMixin):
|
||||||
SHARE_HASH_CHAIN_SIZE
|
SHARE_HASH_CHAIN_SIZE
|
||||||
written_block_size = 2 + len(self.salt)
|
written_block_size = 2 + len(self.salt)
|
||||||
written_block = self.block + self.salt
|
written_block = self.block + self.salt
|
||||||
for i in xrange(6):
|
for i in range(6):
|
||||||
mw.put_block(self.block, i, self.salt)
|
mw.put_block(self.block, i, self.salt)
|
||||||
|
|
||||||
mw.put_encprivkey(self.encprivkey)
|
mw.put_encprivkey(self.encprivkey)
|
||||||
|
@ -2035,35 +2039,35 @@ class MDMFProxies(unittest.TestCase, ShouldFailMixin):
|
||||||
self.failUnlessEqual(len(results), 2)
|
self.failUnlessEqual(len(results), 2)
|
||||||
result, ign = results
|
result, ign = results
|
||||||
self.failUnless(result, "publish failed")
|
self.failUnless(result, "publish failed")
|
||||||
for i in xrange(6):
|
for i in range(6):
|
||||||
self.failUnlessEqual(read("si1", [0], [(expected_sharedata_offset + (i * written_block_size), written_block_size)]),
|
self.failUnlessEqual(read(b"si1", [0], [(expected_sharedata_offset + (i * written_block_size), written_block_size)]),
|
||||||
{0: [written_block]})
|
{0: [written_block]})
|
||||||
|
|
||||||
self.failUnlessEqual(len(self.encprivkey), 7)
|
self.failUnlessEqual(len(self.encprivkey), 7)
|
||||||
self.failUnlessEqual(read("si1", [0], [(expected_private_key_offset, 7)]),
|
self.failUnlessEqual(read(b"si1", [0], [(expected_private_key_offset, 7)]),
|
||||||
{0: [self.encprivkey]})
|
{0: [self.encprivkey]})
|
||||||
|
|
||||||
expected_block_hash_offset = expected_sharedata_offset + \
|
expected_block_hash_offset = expected_sharedata_offset + \
|
||||||
(6 * written_block_size)
|
(6 * written_block_size)
|
||||||
self.failUnlessEqual(len(self.block_hash_tree_s), 32 * 6)
|
self.failUnlessEqual(len(self.block_hash_tree_s), 32 * 6)
|
||||||
self.failUnlessEqual(read("si1", [0], [(expected_block_hash_offset, 32 * 6)]),
|
self.failUnlessEqual(read(b"si1", [0], [(expected_block_hash_offset, 32 * 6)]),
|
||||||
{0: [self.block_hash_tree_s]})
|
{0: [self.block_hash_tree_s]})
|
||||||
|
|
||||||
expected_share_hash_offset = expected_private_key_offset + len(self.encprivkey)
|
expected_share_hash_offset = expected_private_key_offset + len(self.encprivkey)
|
||||||
self.failUnlessEqual(read("si1", [0],[(expected_share_hash_offset, (32 + 2) * 6)]),
|
self.failUnlessEqual(read(b"si1", [0],[(expected_share_hash_offset, (32 + 2) * 6)]),
|
||||||
{0: [self.share_hash_chain_s]})
|
{0: [self.share_hash_chain_s]})
|
||||||
|
|
||||||
self.failUnlessEqual(read("si1", [0], [(9, 32)]),
|
self.failUnlessEqual(read(b"si1", [0], [(9, 32)]),
|
||||||
{0: [self.root_hash]})
|
{0: [self.root_hash]})
|
||||||
expected_signature_offset = expected_share_hash_offset + \
|
expected_signature_offset = expected_share_hash_offset + \
|
||||||
len(self.share_hash_chain_s)
|
len(self.share_hash_chain_s)
|
||||||
self.failUnlessEqual(len(self.signature), 9)
|
self.failUnlessEqual(len(self.signature), 9)
|
||||||
self.failUnlessEqual(read("si1", [0], [(expected_signature_offset, 9)]),
|
self.failUnlessEqual(read(b"si1", [0], [(expected_signature_offset, 9)]),
|
||||||
{0: [self.signature]})
|
{0: [self.signature]})
|
||||||
|
|
||||||
expected_verification_key_offset = expected_signature_offset + len(self.signature)
|
expected_verification_key_offset = expected_signature_offset + len(self.signature)
|
||||||
self.failUnlessEqual(len(self.verification_key), 6)
|
self.failUnlessEqual(len(self.verification_key), 6)
|
||||||
self.failUnlessEqual(read("si1", [0], [(expected_verification_key_offset, 6)]),
|
self.failUnlessEqual(read(b"si1", [0], [(expected_verification_key_offset, 6)]),
|
||||||
{0: [self.verification_key]})
|
{0: [self.verification_key]})
|
||||||
|
|
||||||
signable = mw.get_signable()
|
signable = mw.get_signable()
|
||||||
|
@ -2082,49 +2086,49 @@ class MDMFProxies(unittest.TestCase, ShouldFailMixin):
|
||||||
|
|
||||||
# Check the version number to make sure that it is correct.
|
# Check the version number to make sure that it is correct.
|
||||||
expected_version_number = struct.pack(">B", 1)
|
expected_version_number = struct.pack(">B", 1)
|
||||||
self.failUnlessEqual(read("si1", [0], [(0, 1)]),
|
self.failUnlessEqual(read(b"si1", [0], [(0, 1)]),
|
||||||
{0: [expected_version_number]})
|
{0: [expected_version_number]})
|
||||||
# Check the sequence number to make sure that it is correct
|
# Check the sequence number to make sure that it is correct
|
||||||
expected_sequence_number = struct.pack(">Q", 0)
|
expected_sequence_number = struct.pack(">Q", 0)
|
||||||
self.failUnlessEqual(read("si1", [0], [(1, 8)]),
|
self.failUnlessEqual(read(b"si1", [0], [(1, 8)]),
|
||||||
{0: [expected_sequence_number]})
|
{0: [expected_sequence_number]})
|
||||||
# Check that the encoding parameters (k, N, segement size, data
|
# Check that the encoding parameters (k, N, segement size, data
|
||||||
# length) are what they should be. These are 3, 10, 6, 36
|
# length) are what they should be. These are 3, 10, 6, 36
|
||||||
expected_k = struct.pack(">B", 3)
|
expected_k = struct.pack(">B", 3)
|
||||||
self.failUnlessEqual(read("si1", [0], [(41, 1)]),
|
self.failUnlessEqual(read(b"si1", [0], [(41, 1)]),
|
||||||
{0: [expected_k]})
|
{0: [expected_k]})
|
||||||
expected_n = struct.pack(">B", 10)
|
expected_n = struct.pack(">B", 10)
|
||||||
self.failUnlessEqual(read("si1", [0], [(42, 1)]),
|
self.failUnlessEqual(read(b"si1", [0], [(42, 1)]),
|
||||||
{0: [expected_n]})
|
{0: [expected_n]})
|
||||||
expected_segment_size = struct.pack(">Q", 6)
|
expected_segment_size = struct.pack(">Q", 6)
|
||||||
self.failUnlessEqual(read("si1", [0], [(43, 8)]),
|
self.failUnlessEqual(read(b"si1", [0], [(43, 8)]),
|
||||||
{0: [expected_segment_size]})
|
{0: [expected_segment_size]})
|
||||||
expected_data_length = struct.pack(">Q", 36)
|
expected_data_length = struct.pack(">Q", 36)
|
||||||
self.failUnlessEqual(read("si1", [0], [(51, 8)]),
|
self.failUnlessEqual(read(b"si1", [0], [(51, 8)]),
|
||||||
{0: [expected_data_length]})
|
{0: [expected_data_length]})
|
||||||
expected_offset = struct.pack(">Q", expected_private_key_offset)
|
expected_offset = struct.pack(">Q", expected_private_key_offset)
|
||||||
self.failUnlessEqual(read("si1", [0], [(59, 8)]),
|
self.failUnlessEqual(read(b"si1", [0], [(59, 8)]),
|
||||||
{0: [expected_offset]})
|
{0: [expected_offset]})
|
||||||
expected_offset = struct.pack(">Q", expected_share_hash_offset)
|
expected_offset = struct.pack(">Q", expected_share_hash_offset)
|
||||||
self.failUnlessEqual(read("si1", [0], [(67, 8)]),
|
self.failUnlessEqual(read(b"si1", [0], [(67, 8)]),
|
||||||
{0: [expected_offset]})
|
{0: [expected_offset]})
|
||||||
expected_offset = struct.pack(">Q", expected_signature_offset)
|
expected_offset = struct.pack(">Q", expected_signature_offset)
|
||||||
self.failUnlessEqual(read("si1", [0], [(75, 8)]),
|
self.failUnlessEqual(read(b"si1", [0], [(75, 8)]),
|
||||||
{0: [expected_offset]})
|
{0: [expected_offset]})
|
||||||
expected_offset = struct.pack(">Q", expected_verification_key_offset)
|
expected_offset = struct.pack(">Q", expected_verification_key_offset)
|
||||||
self.failUnlessEqual(read("si1", [0], [(83, 8)]),
|
self.failUnlessEqual(read(b"si1", [0], [(83, 8)]),
|
||||||
{0: [expected_offset]})
|
{0: [expected_offset]})
|
||||||
expected_offset = struct.pack(">Q", expected_verification_key_offset + len(self.verification_key))
|
expected_offset = struct.pack(">Q", expected_verification_key_offset + len(self.verification_key))
|
||||||
self.failUnlessEqual(read("si1", [0], [(91, 8)]),
|
self.failUnlessEqual(read(b"si1", [0], [(91, 8)]),
|
||||||
{0: [expected_offset]})
|
{0: [expected_offset]})
|
||||||
expected_offset = struct.pack(">Q", expected_sharedata_offset)
|
expected_offset = struct.pack(">Q", expected_sharedata_offset)
|
||||||
self.failUnlessEqual(read("si1", [0], [(99, 8)]),
|
self.failUnlessEqual(read(b"si1", [0], [(99, 8)]),
|
||||||
{0: [expected_offset]})
|
{0: [expected_offset]})
|
||||||
expected_offset = struct.pack(">Q", expected_block_hash_offset)
|
expected_offset = struct.pack(">Q", expected_block_hash_offset)
|
||||||
self.failUnlessEqual(read("si1", [0], [(107, 8)]),
|
self.failUnlessEqual(read(b"si1", [0], [(107, 8)]),
|
||||||
{0: [expected_offset]})
|
{0: [expected_offset]})
|
||||||
expected_offset = struct.pack(">Q", expected_eof_offset)
|
expected_offset = struct.pack(">Q", expected_eof_offset)
|
||||||
self.failUnlessEqual(read("si1", [0], [(115, 8)]),
|
self.failUnlessEqual(read(b"si1", [0], [(115, 8)]),
|
||||||
{0: [expected_offset]})
|
{0: [expected_offset]})
|
||||||
d.addCallback(_check_publish)
|
d.addCallback(_check_publish)
|
||||||
return d
|
return d
|
||||||
|
@ -2140,13 +2144,13 @@ class MDMFProxies(unittest.TestCase, ShouldFailMixin):
|
||||||
|
|
||||||
|
|
||||||
def test_write_rejected_with_too_many_blocks(self):
|
def test_write_rejected_with_too_many_blocks(self):
|
||||||
mw = self._make_new_mw("si0", 0)
|
mw = self._make_new_mw(b"si0", 0)
|
||||||
|
|
||||||
# Try writing too many blocks. We should not be able to write
|
# Try writing too many blocks. We should not be able to write
|
||||||
# more than 6
|
# more than 6
|
||||||
# blocks into each share.
|
# blocks into each share.
|
||||||
d = defer.succeed(None)
|
d = defer.succeed(None)
|
||||||
for i in xrange(6):
|
for i in range(6):
|
||||||
d.addCallback(lambda ignored, i=i:
|
d.addCallback(lambda ignored, i=i:
|
||||||
mw.put_block(self.block, i, self.salt))
|
mw.put_block(self.block, i, self.salt))
|
||||||
d.addCallback(lambda ignored:
|
d.addCallback(lambda ignored:
|
||||||
|
@ -2159,8 +2163,8 @@ class MDMFProxies(unittest.TestCase, ShouldFailMixin):
|
||||||
def test_write_rejected_with_invalid_salt(self):
|
def test_write_rejected_with_invalid_salt(self):
|
||||||
# Try writing an invalid salt. Salts are 16 bytes -- any more or
|
# Try writing an invalid salt. Salts are 16 bytes -- any more or
|
||||||
# less should cause an error.
|
# less should cause an error.
|
||||||
mw = self._make_new_mw("si1", 0)
|
mw = self._make_new_mw(b"si1", 0)
|
||||||
bad_salt = "a" * 17 # 17 bytes
|
bad_salt = b"a" * 17 # 17 bytes
|
||||||
d = defer.succeed(None)
|
d = defer.succeed(None)
|
||||||
d.addCallback(lambda ignored:
|
d.addCallback(lambda ignored:
|
||||||
self.shouldFail(LayoutInvalid, "test_invalid_salt",
|
self.shouldFail(LayoutInvalid, "test_invalid_salt",
|
||||||
|
@ -2171,15 +2175,15 @@ class MDMFProxies(unittest.TestCase, ShouldFailMixin):
|
||||||
def test_write_rejected_with_invalid_root_hash(self):
|
def test_write_rejected_with_invalid_root_hash(self):
|
||||||
# Try writing an invalid root hash. This should be SHA256d, and
|
# Try writing an invalid root hash. This should be SHA256d, and
|
||||||
# 32 bytes long as a result.
|
# 32 bytes long as a result.
|
||||||
mw = self._make_new_mw("si2", 0)
|
mw = self._make_new_mw(b"si2", 0)
|
||||||
# 17 bytes != 32 bytes
|
# 17 bytes != 32 bytes
|
||||||
invalid_root_hash = "a" * 17
|
invalid_root_hash = b"a" * 17
|
||||||
d = defer.succeed(None)
|
d = defer.succeed(None)
|
||||||
# Before this test can work, we need to put some blocks + salts,
|
# Before this test can work, we need to put some blocks + salts,
|
||||||
# a block hash tree, and a share hash tree. Otherwise, we'll see
|
# a block hash tree, and a share hash tree. Otherwise, we'll see
|
||||||
# failures that match what we are looking for, but are caused by
|
# failures that match what we are looking for, but are caused by
|
||||||
# the constraints imposed on operation ordering.
|
# the constraints imposed on operation ordering.
|
||||||
for i in xrange(6):
|
for i in range(6):
|
||||||
d.addCallback(lambda ignored, i=i:
|
d.addCallback(lambda ignored, i=i:
|
||||||
mw.put_block(self.block, i, self.salt))
|
mw.put_block(self.block, i, self.salt))
|
||||||
d.addCallback(lambda ignored:
|
d.addCallback(lambda ignored:
|
||||||
|
@ -2199,8 +2203,8 @@ class MDMFProxies(unittest.TestCase, ShouldFailMixin):
|
||||||
# _make_new_mw is 2bytes -- any more or any less than this
|
# _make_new_mw is 2bytes -- any more or any less than this
|
||||||
# should be cause for failure, unless it is the tail segment, in
|
# should be cause for failure, unless it is the tail segment, in
|
||||||
# which case it may not be failure.
|
# which case it may not be failure.
|
||||||
invalid_block = "a"
|
invalid_block = b"a"
|
||||||
mw = self._make_new_mw("si3", 0, 33) # implies a tail segment with
|
mw = self._make_new_mw(b"si3", 0, 33) # implies a tail segment with
|
||||||
# one byte blocks
|
# one byte blocks
|
||||||
# 1 bytes != 2 bytes
|
# 1 bytes != 2 bytes
|
||||||
d = defer.succeed(None)
|
d = defer.succeed(None)
|
||||||
|
@ -2214,7 +2218,7 @@ class MDMFProxies(unittest.TestCase, ShouldFailMixin):
|
||||||
self.shouldFail(LayoutInvalid, "test blocksize too large",
|
self.shouldFail(LayoutInvalid, "test blocksize too large",
|
||||||
None,
|
None,
|
||||||
mw.put_block, invalid_block, 0, self.salt))
|
mw.put_block, invalid_block, 0, self.salt))
|
||||||
for i in xrange(5):
|
for i in range(5):
|
||||||
d.addCallback(lambda ignored, i=i:
|
d.addCallback(lambda ignored, i=i:
|
||||||
mw.put_block(self.block, i, self.salt))
|
mw.put_block(self.block, i, self.salt))
|
||||||
# Try to put an invalid tail segment
|
# Try to put an invalid tail segment
|
||||||
|
@ -2222,7 +2226,7 @@ class MDMFProxies(unittest.TestCase, ShouldFailMixin):
|
||||||
self.shouldFail(LayoutInvalid, "test invalid tail segment",
|
self.shouldFail(LayoutInvalid, "test invalid tail segment",
|
||||||
None,
|
None,
|
||||||
mw.put_block, self.block, 5, self.salt))
|
mw.put_block, self.block, 5, self.salt))
|
||||||
valid_block = "a"
|
valid_block = b"a"
|
||||||
d.addCallback(lambda ignored:
|
d.addCallback(lambda ignored:
|
||||||
mw.put_block(valid_block, 5, self.salt))
|
mw.put_block(valid_block, 5, self.salt))
|
||||||
return d
|
return d
|
||||||
|
@ -2247,10 +2251,10 @@ class MDMFProxies(unittest.TestCase, ShouldFailMixin):
|
||||||
# - share hashes and block hashes before root hash
|
# - share hashes and block hashes before root hash
|
||||||
# - root hash before signature
|
# - root hash before signature
|
||||||
# - signature before verification key
|
# - signature before verification key
|
||||||
mw0 = self._make_new_mw("si0", 0)
|
mw0 = self._make_new_mw(b"si0", 0)
|
||||||
# Write some shares
|
# Write some shares
|
||||||
d = defer.succeed(None)
|
d = defer.succeed(None)
|
||||||
for i in xrange(6):
|
for i in range(6):
|
||||||
d.addCallback(lambda ignored, i=i:
|
d.addCallback(lambda ignored, i=i:
|
||||||
mw0.put_block(self.block, i, self.salt))
|
mw0.put_block(self.block, i, self.salt))
|
||||||
|
|
||||||
|
@ -2315,11 +2319,11 @@ class MDMFProxies(unittest.TestCase, ShouldFailMixin):
|
||||||
|
|
||||||
|
|
||||||
def test_end_to_end(self):
|
def test_end_to_end(self):
|
||||||
mw = self._make_new_mw("si1", 0)
|
mw = self._make_new_mw(b"si1", 0)
|
||||||
# Write a share using the mutable writer, and make sure that the
|
# Write a share using the mutable writer, and make sure that the
|
||||||
# reader knows how to read everything back to us.
|
# reader knows how to read everything back to us.
|
||||||
d = defer.succeed(None)
|
d = defer.succeed(None)
|
||||||
for i in xrange(6):
|
for i in range(6):
|
||||||
d.addCallback(lambda ignored, i=i:
|
d.addCallback(lambda ignored, i=i:
|
||||||
mw.put_block(self.block, i, self.salt))
|
mw.put_block(self.block, i, self.salt))
|
||||||
d.addCallback(lambda ignored:
|
d.addCallback(lambda ignored:
|
||||||
|
@ -2337,13 +2341,13 @@ class MDMFProxies(unittest.TestCase, ShouldFailMixin):
|
||||||
d.addCallback(lambda ignored:
|
d.addCallback(lambda ignored:
|
||||||
mw.finish_publishing())
|
mw.finish_publishing())
|
||||||
|
|
||||||
mr = MDMFSlotReadProxy(self.storage_server, "si1", 0)
|
mr = MDMFSlotReadProxy(self.storage_server, b"si1", 0)
|
||||||
def _check_block_and_salt(block_and_salt):
|
def _check_block_and_salt(block_and_salt):
|
||||||
(block, salt) = block_and_salt
|
(block, salt) = block_and_salt
|
||||||
self.failUnlessEqual(block, self.block)
|
self.failUnlessEqual(block, self.block)
|
||||||
self.failUnlessEqual(salt, self.salt)
|
self.failUnlessEqual(salt, self.salt)
|
||||||
|
|
||||||
for i in xrange(6):
|
for i in range(6):
|
||||||
d.addCallback(lambda ignored, i=i:
|
d.addCallback(lambda ignored, i=i:
|
||||||
mr.get_block_and_salt(i))
|
mr.get_block_and_salt(i))
|
||||||
d.addCallback(_check_block_and_salt)
|
d.addCallback(_check_block_and_salt)
|
||||||
|
@ -2404,7 +2408,7 @@ class MDMFProxies(unittest.TestCase, ShouldFailMixin):
|
||||||
# The MDMFSlotReadProxy should also know how to read SDMF files,
|
# The MDMFSlotReadProxy should also know how to read SDMF files,
|
||||||
# since it will encounter them on the grid. Callers use the
|
# since it will encounter them on the grid. Callers use the
|
||||||
# is_sdmf method to test this.
|
# is_sdmf method to test this.
|
||||||
self.write_sdmf_share_to_server("si1")
|
self.write_sdmf_share_to_server(b"si1")
|
||||||
mr = MDMFSlotReadProxy(self.storage_server, "si1", 0)
|
mr = MDMFSlotReadProxy(self.storage_server, "si1", 0)
|
||||||
d = mr.is_sdmf()
|
d = mr.is_sdmf()
|
||||||
d.addCallback(lambda issdmf:
|
d.addCallback(lambda issdmf:
|
||||||
|
@ -2415,7 +2419,7 @@ class MDMFProxies(unittest.TestCase, ShouldFailMixin):
|
||||||
def test_reads_sdmf(self):
|
def test_reads_sdmf(self):
|
||||||
# The slot read proxy should, naturally, know how to tell us
|
# The slot read proxy should, naturally, know how to tell us
|
||||||
# about data in the SDMF format
|
# about data in the SDMF format
|
||||||
self.write_sdmf_share_to_server("si1")
|
self.write_sdmf_share_to_server(b"si1")
|
||||||
mr = MDMFSlotReadProxy(self.storage_server, "si1", 0)
|
mr = MDMFSlotReadProxy(self.storage_server, "si1", 0)
|
||||||
d = defer.succeed(None)
|
d = defer.succeed(None)
|
||||||
d.addCallback(lambda ignored:
|
d.addCallback(lambda ignored:
|
||||||
|
@ -2486,7 +2490,7 @@ class MDMFProxies(unittest.TestCase, ShouldFailMixin):
|
||||||
# SDMF shares have only one segment, so it doesn't make sense to
|
# SDMF shares have only one segment, so it doesn't make sense to
|
||||||
# read more segments than that. The reader should know this and
|
# read more segments than that. The reader should know this and
|
||||||
# complain if we try to do that.
|
# complain if we try to do that.
|
||||||
self.write_sdmf_share_to_server("si1")
|
self.write_sdmf_share_to_server(b"si1")
|
||||||
mr = MDMFSlotReadProxy(self.storage_server, "si1", 0)
|
mr = MDMFSlotReadProxy(self.storage_server, "si1", 0)
|
||||||
d = defer.succeed(None)
|
d = defer.succeed(None)
|
||||||
d.addCallback(lambda ignored:
|
d.addCallback(lambda ignored:
|
||||||
|
@ -2507,7 +2511,7 @@ class MDMFProxies(unittest.TestCase, ShouldFailMixin):
|
||||||
# finding out which shares are on the remote peer so that it
|
# finding out which shares are on the remote peer so that it
|
||||||
# doesn't waste round trips.
|
# doesn't waste round trips.
|
||||||
mdmf_data = self.build_test_mdmf_share()
|
mdmf_data = self.build_test_mdmf_share()
|
||||||
self.write_test_share_to_server("si1")
|
self.write_test_share_to_server(b"si1")
|
||||||
def _make_mr(ignored, length):
|
def _make_mr(ignored, length):
|
||||||
mr = MDMFSlotReadProxy(self.storage_server, "si1", 0, mdmf_data[:length])
|
mr = MDMFSlotReadProxy(self.storage_server, "si1", 0, mdmf_data[:length])
|
||||||
return mr
|
return mr
|
||||||
|
@ -2568,7 +2572,7 @@ class MDMFProxies(unittest.TestCase, ShouldFailMixin):
|
||||||
|
|
||||||
def test_read_with_prefetched_sdmf_data(self):
|
def test_read_with_prefetched_sdmf_data(self):
|
||||||
sdmf_data = self.build_test_sdmf_share()
|
sdmf_data = self.build_test_sdmf_share()
|
||||||
self.write_sdmf_share_to_server("si1")
|
self.write_sdmf_share_to_server(b"si1")
|
||||||
def _make_mr(ignored, length):
|
def _make_mr(ignored, length):
|
||||||
mr = MDMFSlotReadProxy(self.storage_server, "si1", 0, sdmf_data[:length])
|
mr = MDMFSlotReadProxy(self.storage_server, "si1", 0, sdmf_data[:length])
|
||||||
return mr
|
return mr
|
||||||
|
@ -2635,7 +2639,7 @@ class MDMFProxies(unittest.TestCase, ShouldFailMixin):
|
||||||
# Some tests upload a file with no contents to test things
|
# Some tests upload a file with no contents to test things
|
||||||
# unrelated to the actual handling of the content of the file.
|
# unrelated to the actual handling of the content of the file.
|
||||||
# The reader should behave intelligently in these cases.
|
# The reader should behave intelligently in these cases.
|
||||||
self.write_test_share_to_server("si1", empty=True)
|
self.write_test_share_to_server(b"si1", empty=True)
|
||||||
mr = MDMFSlotReadProxy(self.storage_server, "si1", 0)
|
mr = MDMFSlotReadProxy(self.storage_server, "si1", 0)
|
||||||
# We should be able to get the encoding parameters, and they
|
# We should be able to get the encoding parameters, and they
|
||||||
# should be correct.
|
# should be correct.
|
||||||
|
@ -2661,7 +2665,7 @@ class MDMFProxies(unittest.TestCase, ShouldFailMixin):
|
||||||
|
|
||||||
|
|
||||||
def test_read_with_empty_sdmf_file(self):
|
def test_read_with_empty_sdmf_file(self):
|
||||||
self.write_sdmf_share_to_server("si1", empty=True)
|
self.write_sdmf_share_to_server(b"si1", empty=True)
|
||||||
mr = MDMFSlotReadProxy(self.storage_server, "si1", 0)
|
mr = MDMFSlotReadProxy(self.storage_server, "si1", 0)
|
||||||
# We should be able to get the encoding parameters, and they
|
# We should be able to get the encoding parameters, and they
|
||||||
# should be correct
|
# should be correct
|
||||||
|
@ -2687,7 +2691,7 @@ class MDMFProxies(unittest.TestCase, ShouldFailMixin):
|
||||||
|
|
||||||
|
|
||||||
def test_verinfo_with_sdmf_file(self):
|
def test_verinfo_with_sdmf_file(self):
|
||||||
self.write_sdmf_share_to_server("si1")
|
self.write_sdmf_share_to_server(b"si1")
|
||||||
mr = MDMFSlotReadProxy(self.storage_server, "si1", 0)
|
mr = MDMFSlotReadProxy(self.storage_server, "si1", 0)
|
||||||
# We should be able to get the version information.
|
# We should be able to get the version information.
|
||||||
d = defer.succeed(None)
|
d = defer.succeed(None)
|
||||||
|
@ -2728,7 +2732,7 @@ class MDMFProxies(unittest.TestCase, ShouldFailMixin):
|
||||||
|
|
||||||
|
|
||||||
def test_verinfo_with_mdmf_file(self):
|
def test_verinfo_with_mdmf_file(self):
|
||||||
self.write_test_share_to_server("si1")
|
self.write_test_share_to_server(b"si1")
|
||||||
mr = MDMFSlotReadProxy(self.storage_server, "si1", 0)
|
mr = MDMFSlotReadProxy(self.storage_server, "si1", 0)
|
||||||
d = defer.succeed(None)
|
d = defer.succeed(None)
|
||||||
d.addCallback(lambda ignored:
|
d.addCallback(lambda ignored:
|
||||||
|
@ -2804,7 +2808,7 @@ class MDMFProxies(unittest.TestCase, ShouldFailMixin):
|
||||||
def _then(ignored):
|
def _then(ignored):
|
||||||
self.failUnlessEqual(self.rref.write_count, 1)
|
self.failUnlessEqual(self.rref.write_count, 1)
|
||||||
read = self.ss.remote_slot_readv
|
read = self.ss.remote_slot_readv
|
||||||
self.failUnlessEqual(read("si1", [0], [(0, len(data))]),
|
self.failUnlessEqual(read(b"si1", [0], [(0, len(data))]),
|
||||||
{0: [data]})
|
{0: [data]})
|
||||||
d.addCallback(_then)
|
d.addCallback(_then)
|
||||||
return d
|
return d
|
||||||
|
@ -2812,7 +2816,7 @@ class MDMFProxies(unittest.TestCase, ShouldFailMixin):
|
||||||
|
|
||||||
def test_sdmf_writer_preexisting_share(self):
|
def test_sdmf_writer_preexisting_share(self):
|
||||||
data = self.build_test_sdmf_share()
|
data = self.build_test_sdmf_share()
|
||||||
self.write_sdmf_share_to_server("si1")
|
self.write_sdmf_share_to_server(b"si1")
|
||||||
|
|
||||||
# Now there is a share on the storage server. To successfully
|
# Now there is a share on the storage server. To successfully
|
||||||
# write, we need to set the checkstring correctly. When we
|
# write, we need to set the checkstring correctly. When we
|
||||||
|
@ -2861,9 +2865,9 @@ class MDMFProxies(unittest.TestCase, ShouldFailMixin):
|
||||||
def _then_again(results):
|
def _then_again(results):
|
||||||
self.failUnless(results[0])
|
self.failUnless(results[0])
|
||||||
read = self.ss.remote_slot_readv
|
read = self.ss.remote_slot_readv
|
||||||
self.failUnlessEqual(read("si1", [0], [(1, 8)]),
|
self.failUnlessEqual(read(b"si1", [0], [(1, 8)]),
|
||||||
{0: [struct.pack(">Q", 1)]})
|
{0: [struct.pack(">Q", 1)]})
|
||||||
self.failUnlessEqual(read("si1", [0], [(9, len(data) - 9)]),
|
self.failUnlessEqual(read(b"si1", [0], [(9, len(data) - 9)]),
|
||||||
{0: [data[9:]]})
|
{0: [data[9:]]})
|
||||||
d.addCallback(_then_again)
|
d.addCallback(_then_again)
|
||||||
return d
|
return d
|
||||||
|
|
Loading…
Reference in New Issue