tahoe-lafs/src/allmydata/test/test_base62.py

96 lines
3.2 KiB
Python
Raw Normal View History

2020-07-14 14:34:53 +00:00
"""
Tests for allmydata.util.base62.
Ported to Python 3.
"""
from __future__ import absolute_import
from __future__ import division
from __future__ import print_function
from __future__ import unicode_literals
from future.utils import PY2
if PY2:
from builtins import filter, map, zip, ascii, chr, hex, input, next, oct, open, pow, round, super, bytes, dict, int, list, object, range, str, max, min # noqa: F401
2020-07-13 20:21:15 +00:00
from past.builtins import chr as byteschr
2020-07-14 14:34:53 +00:00
import random, unittest
2020-07-13 20:19:48 +00:00
from hypothesis import (
strategies as st,
given,
)
from allmydata.util import base62, mathutil
def insecurerandstr(n):
2020-07-13 20:21:15 +00:00
return b''.join(map(byteschr, map(random.randrange, [0]*n, [256]*n)))
class T(unittest.TestCase):
def _test_num_octets_that_encode_to_this_many_chars(self, chars, octets):
assert base62.num_octets_that_encode_to_this_many_chars(chars) == octets, "%s != %s <- %s" % (octets, base62.num_octets_that_encode_to_this_many_chars(chars), chars)
def _test_ende(self, bs):
ascii=base62.b2a(bs)
bs2=base62.a2b(ascii)
assert bs2 == bs, "bs2: %s:%s, bs: %s:%s, ascii: %s:%s" % (len(bs2), repr(bs2), len(bs), repr(bs), len(ascii), repr(ascii))
2020-07-14 14:28:22 +00:00
self.assertIsInstance(ascii, bytes)
self.assertIsInstance(bs, bytes)
self.assertIsInstance(bs2, bytes)
2020-07-13 20:19:48 +00:00
@given(input_bytes=st.binary(max_size=100))
def test_roundtrip(self, input_bytes):
self._test_ende(input_bytes)
def test_num_octets_that_encode_to_this_many_chars(self):
return self._test_num_octets_that_encode_to_this_many_chars(2, 1)
return self._test_num_octets_that_encode_to_this_many_chars(3, 2)
return self._test_num_octets_that_encode_to_this_many_chars(5, 3)
return self._test_num_octets_that_encode_to_this_many_chars(6, 4)
def test_ende_0x00(self):
2020-07-13 20:21:15 +00:00
return self._test_ende(b'\x00')
def test_ende_0x01(self):
2020-07-13 20:21:15 +00:00
return self._test_ende(b'\x01')
def test_ende_0x0100(self):
2020-07-13 20:21:15 +00:00
return self._test_ende(b'\x01\x00')
def test_ende_0x000000(self):
2020-07-13 20:21:15 +00:00
return self._test_ende(b'\x00\x00\x00')
def test_ende_0x010000(self):
2020-07-13 20:21:15 +00:00
return self._test_ende(b'\x01\x00\x00')
def test_ende_randstr(self):
return self._test_ende(insecurerandstr(2**4))
def test_ende_longrandstr(self):
return self._test_ende(insecurerandstr(random.randrange(0, 2**10)))
def test_odd_sizes(self):
for j in range(2**6):
lib = random.randrange(1, 2**8)
numos = mathutil.div_ceil(lib, 8)
bs = insecurerandstr(numos)
# zero-out unused least-sig bits
if lib%8:
b=ord(bs[-1])
b = b >> (8 - (lib%8))
b = b << (8 - (lib%8))
2020-07-14 14:34:53 +00:00
bs = bs[:-1] + byteschr(b)
asl = base62.b2a_l(bs, lib)
assert len(asl) == base62.num_chars_that_this_many_octets_encode_to(numos) # the size of the base-62 encoding must be just right
bs2l = base62.a2b_l(asl, lib)
assert len(bs2l) == numos # the size of the result must be just right
assert bs == bs2l
def suite():
suite = unittest.makeSuite(T, 'test')
return suite
if __name__ == "__main__":
unittest.main()