Files
@ 8968eab714bc
Branch filter:
Location: Shamira/src/tests/test_shamira.py - annotation
8968eab714bc
3.4 KiB
text/x-python
added license
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 | 8968eab714bc 8968eab714bc 90fb179128d4 90fb179128d4 90fb179128d4 90fb179128d4 90fb179128d4 90fb179128d4 90fb179128d4 90fb179128d4 90fb179128d4 90fb179128d4 90fb179128d4 90fb179128d4 90fb179128d4 90fb179128d4 90fb179128d4 90fb179128d4 90fb179128d4 90fb179128d4 90fb179128d4 90fb179128d4 90fb179128d4 90fb179128d4 90fb179128d4 90fb179128d4 90fb179128d4 90fb179128d4 90fb179128d4 90fb179128d4 90fb179128d4 90fb179128d4 90fb179128d4 90fb179128d4 90fb179128d4 90fb179128d4 90fb179128d4 90fb179128d4 90fb179128d4 90fb179128d4 90fb179128d4 90fb179128d4 90fb179128d4 90fb179128d4 90fb179128d4 90fb179128d4 90fb179128d4 90fb179128d4 90fb179128d4 90fb179128d4 90fb179128d4 90fb179128d4 90fb179128d4 90fb179128d4 90fb179128d4 90fb179128d4 90fb179128d4 90fb179128d4 90fb179128d4 90fb179128d4 90fb179128d4 90fb179128d4 90fb179128d4 90fb179128d4 90fb179128d4 90fb179128d4 90fb179128d4 90fb179128d4 90fb179128d4 90fb179128d4 90fb179128d4 90fb179128d4 90fb179128d4 90fb179128d4 90fb179128d4 90fb179128d4 90fb179128d4 90fb179128d4 90fb179128d4 90fb179128d4 90fb179128d4 90fb179128d4 90fb179128d4 90fb179128d4 90fb179128d4 90fb179128d4 90fb179128d4 90fb179128d4 90fb179128d4 90fb179128d4 90fb179128d4 90fb179128d4 90fb179128d4 90fb179128d4 90fb179128d4 90fb179128d4 90fb179128d4 90fb179128d4 90fb179128d4 90fb179128d4 90fb179128d4 90fb179128d4 90fb179128d4 | # GNU GPLv3, see LICENSE
import random
from unittest import TestCase
from shamira import _shareByte
from shamira import *
class TestShamira(TestCase):
_urandom=os.urandom
@classmethod
def setUpClass(cls):
random.seed(17)
os.urandom=lambda n: bytes(random.randint(0,255) for i in range(n))
@classmethod
def tearDownClass(cls):
os.urandom=cls._urandom
def test_shareByte(self):
with self.assertRaises(AssertionError): # too few shares
_shareByte(b"a",5,4)
with self.assertRaises(AssertionError): # too many shares
_shareByte(b"a",5,255)
with self.assertRaises(ValueError): # not castable to int
_shareByte("x",2,3)
vals=_shareByte(ord(b"a"),2,3)
points=list(zip(range(1,256), vals))
self.assertEqual(gf256.getConstantCoef(*points), ord(b"a"))
self.assertEqual(gf256.getConstantCoef(*points[:2]), ord(b"a"))
self.assertNotEqual(gf256.getConstantCoef(*points[:1]), ord(b"a")) # underdetermined => random
def testGenerateReconstructRaw(self):
for (k,n) in [(2,3), (254,254)]:
shares=generateRaw(b"abcd",k,n)
random.shuffle(shares)
self.assertEqual(reconstructRaw(*shares[:k]), b"abcd")
self.assertNotEqual(reconstructRaw(*shares[:k-1]), b"abcd")
def testGenerateReconstruct(self):
for encoding in ["hex","b32","b64"]:
for secret in [b"abcd","abcde","ěščřžý"]:
for (k,n) in [(2,3), (254,254)]:
raw=isinstance(secret,bytes)
with self.subTest(enc=encoding,r=raw,sec=secret,k=k,n=n):
shares=generate(secret,k,n,encoding)
random.shuffle(shares)
self.assertEqual(reconstruct(*shares[:k],encoding=encoding,raw=raw), secret)
self.assertEqual(reconstruct(*shares[:k],raw=raw), secret)
s=secret if raw else secret.encode("utf-8")
self.assertNotEqual(reconstruct(*shares[:k-1],encoding=encoding,raw=True), s)
shares=generate(b"\xfeaa",2,3)
with self.assertRaises(UnicodeDecodeError):
reconstruct(*shares)
def testEncode(self):
share=(2,b"\x00\x01\x02")
for (encoding,encodedStr) in [("hex",'000102'),("b32",'AAAQE==='),("b64",'AAEC')]:
with self.subTest(enc=encoding):
self.assertEqual(encode(share,encoding), "2."+encodedStr)
def testDecode(self):
with self.assertRaises(ValueError):
decode("AAA")
decode("1.")
decode(".AAA")
decode("1AAA")
decode("1.0001020f","hex")
decode("1.000102030","hex")
decode("1.AAAQEAY")
decode("1.AAAQEAy=")
decode("1.AAECAw=","b64")
decode("1.AAECA?==","b64")
decode("256.00010203","hex")
self.assertEqual(decode("1.00010203","hex"), (1,b"\x00\x01\x02\x03"))
self.assertEqual(decode("2.AAAQEAY=","b32"), (2,b"\x00\x01\x02\x03"))
self.assertEqual(decode("3.AAECAw==","b64"), (3,b"\x00\x01\x02\x03"))
def testDetectEncoding(self):
for shares in [
["1.00010f"], # bad case
["1.000102030"], # bad char count
["1.AAAQEAY"], # no padding
["1.AAAQe==="], # bad case
["1.AAECA?=="], # bad char
["1.AAECAw="], # bad padding
["1.000102","2.AAAQEAY="], # mixed encoding
["1.000102","2.AAECAw=="],
["1.AAECAw==","2.AAAQE==="],
[".00010203"], # no index
["00010203"] # no index
]:
with self.subTest(shares=shares):
with self.assertRaises(ValueError):
detectEncoding(shares)
self.assertEqual(detectEncoding(["10.00010203"]), "hex")
self.assertEqual(detectEncoding(["2.AAAQEAY="]), "b32")
self.assertEqual(detectEncoding(["3.AAECAw=="]), "b64")
self.assertEqual(detectEncoding(["3.AAECAwQF","1.00010203"]), "b64")
|