diff options
| author | Paul Kehrer <paul.l.kehrer@gmail.com> | 2015-10-27 16:47:55 +0900 | 
|---|---|---|
| committer | Paul Kehrer <paul.l.kehrer@gmail.com> | 2015-10-27 20:35:13 +0900 | 
| commit | 13d4e74b13832b495ddfdff043376144d8ada66a (patch) | |
| tree | 8100b54337d32b0442c9ff1315e24e1f64b0a58c /tests/hazmat/primitives/test_ec.py | |
| parent | e4150bcc07fb2c68e3c860c31766b4282bba8740 (diff) | |
| download | cryptography-13d4e74b13832b495ddfdff043376144d8ada66a.tar.gz cryptography-13d4e74b13832b495ddfdff043376144d8ada66a.tar.bz2 cryptography-13d4e74b13832b495ddfdff043376144d8ada66a.zip | |
modify approach to use EllipticCurvePublicNumbers methods
Diffstat (limited to 'tests/hazmat/primitives/test_ec.py')
| -rw-r--r-- | tests/hazmat/primitives/test_ec.py | 74 | 
1 files changed, 74 insertions, 0 deletions
| diff --git a/tests/hazmat/primitives/test_ec.py b/tests/hazmat/primitives/test_ec.py index 4c4d5b90..ac1ba27a 100644 --- a/tests/hazmat/primitives/test_ec.py +++ b/tests/hazmat/primitives/test_ec.py @@ -4,6 +4,7 @@  from __future__ import absolute_import, division, print_function +import binascii  import itertools  import os @@ -148,6 +149,79 @@ def test_ec_numbers():          ) +def test_encode_point(): +    # secp256r1 point +    x = int( +        '233ea3b0027127084cd2cd336a13aeef69c598d8af61369a36454a17c6c22aec', +        16 +    ) +    y = int( +        '3ea2c10a84153862be4ec82940f0543f9ba866af9751a6ee79d38460b35f442e', +        16 +    ) +    pn = ec.EllipticCurvePublicNumbers(x, y, ec.SECP256R1()) +    data = pn.encode_point() +    assert data == binascii.unhexlify( +        "04233ea3b0027127084cd2cd336a13aeef69c598d8af61369a36454a17c6c22ae" +        "c3ea2c10a84153862be4ec82940f0543f9ba866af9751a6ee79d38460b35f442e" +    ) + + +def test_from_encoded_point_null(): +    with pytest.raises(ValueError): +        ec.EllipticCurvePublicNumbers.from_encoded_point( +            ec.SECP384R1(), b"\x00" +        ) + + +def test_from_encoded_point(): +    # secp256r1 point +    data = binascii.unhexlify( +        "04233ea3b0027127084cd2cd336a13aeef69c598d8af61369a36454a17c6c22ae" +        "c3ea2c10a84153862be4ec82940f0543f9ba866af9751a6ee79d38460b35f442e" +    ) +    pn = ec.EllipticCurvePublicNumbers.from_encoded_point( +        ec.SECP256R1(), data +    ) +    assert pn.x == int( +        '233ea3b0027127084cd2cd336a13aeef69c598d8af61369a36454a17c6c22aec', +        16 +    ) +    assert pn.y == int( +        '3ea2c10a84153862be4ec82940f0543f9ba866af9751a6ee79d38460b35f442e', +        16 +    ) + + +def test_from_encoded_point_invalid_length(): +    bad_data = binascii.unhexlify( +        "04233ea3b0027127084cd2cd336a13aeef69c598d8af61369a36454a17c6c22ae" +        "c3ea2c10a84153862be4ec82940f0543f9ba866af9751a6ee79d38460" +    ) +    with pytest.raises(ValueError): +        ec.EllipticCurvePublicNumbers.from_encoded_point( +            ec.SECP384R1(), bad_data +        ) + + +def test_from_encoded_point_unsupported_point_type(): +    # set to point type 2. +    unsupported_type = binascii.unhexlify( +        "02233ea3b0027127084cd2cd336a13aeef69c598d8af61369a36454a17c6c22a" +    ) +    with pytest.raises(ValueError): +        ec.EllipticCurvePublicNumbers.from_encoded_point( +            ec.SECP256R1(), unsupported_type +        ) + + +def test_from_encoded_point_not_a_curve(): +    with pytest.raises(TypeError): +        ec.EllipticCurvePublicNumbers.from_encoded_point( +            "notacurve", b"\x04data" +        ) + +  @pytest.mark.requires_backend_interface(interface=EllipticCurveBackend)  class TestECWithNumbers(object):      @pytest.mark.parametrize( | 
