58 lines
1.7 KiB
Python
58 lines
1.7 KiB
Python
"""
|
|
Test if OpenSSL is working correctly
|
|
"""
|
|
import unittest
|
|
|
|
try:
|
|
from pyelliptic.openssl import OpenSSL
|
|
except ImportError:
|
|
from pybitmessage.pyelliptic import OpenSSL
|
|
|
|
try:
|
|
OpenSSL.BN_bn2binpad
|
|
have_pad = True
|
|
except AttributeError:
|
|
have_pad = None
|
|
|
|
|
|
class TestOpenSSL(unittest.TestCase):
|
|
"""
|
|
Test cases for OpenSSL
|
|
"""
|
|
def test_is_odd(self):
|
|
"""Test BN_is_odd implementation"""
|
|
ctx = OpenSSL.BN_CTX_new()
|
|
a = OpenSSL.BN_new()
|
|
group = OpenSSL.EC_GROUP_new_by_curve_name(
|
|
OpenSSL.get_curve("secp256k1"))
|
|
OpenSSL.EC_GROUP_get_order(group, a, ctx)
|
|
|
|
bad = 0
|
|
for _ in range(1024):
|
|
OpenSSL.BN_rand(a, OpenSSL.BN_num_bits(a), 0, 0)
|
|
if not OpenSSL.BN_is_odd(a) == OpenSSL.BN_is_odd_compatible(a):
|
|
bad += 1
|
|
self.assertEqual(bad, 0)
|
|
|
|
@unittest.skipUnless(have_pad, 'Skipping OpenSSL pad test')
|
|
def test_padding(self):
|
|
"""Test an alternative implementation of bn2binpad"""
|
|
|
|
ctx = OpenSSL.BN_CTX_new()
|
|
a = OpenSSL.BN_new()
|
|
n = OpenSSL.BN_new()
|
|
group = OpenSSL.EC_GROUP_new_by_curve_name(
|
|
OpenSSL.get_curve("secp256k1"))
|
|
OpenSSL.EC_GROUP_get_order(group, n, ctx)
|
|
|
|
bad = 0
|
|
for _ in range(1024):
|
|
OpenSSL.BN_rand(a, OpenSSL.BN_num_bits(n), 0, 0)
|
|
b = OpenSSL.malloc(0, OpenSSL.BN_num_bytes(n))
|
|
c = OpenSSL.malloc(0, OpenSSL.BN_num_bytes(a))
|
|
OpenSSL.BN_bn2binpad(a, b, OpenSSL.BN_num_bytes(n))
|
|
OpenSSL.BN_bn2bin(a, c)
|
|
if b.raw != c.raw.rjust(OpenSSL.BN_num_bytes(n), b'\x00'):
|
|
bad += 1
|
|
self.assertEqual(bad, 0)
|