aboutsummaryrefslogtreecommitdiff
path: root/test/ec/test_curves.py
blob: 1f6a117ee225efb6cfa6998ea219c53b0dbeaa67 (plain)
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
from unittest import TestCase

from parameterized import parameterized

from pyecsca.ec.curves import get_params


class CurvesTests(TestCase):

    @parameterized.expand([
        ("secg/secp128r1", "projective"),
        ("secg/secp256r1", "projective"),
        ("secg/secp521r1", "projective"),
        ("other/Curve25519", "xz"),
        ("other/Ed25519", "projective"),
        ("other/Ed448", "projective"),
        ("other/E-222", "projective")
    ])
    def test_get_params(self, name, coords):
        group = get_params(*name.split("/"), coords)
        try:
            assert group.curve.is_on_curve(group.generator)
        except NotImplementedError:
            pass

    @parameterized.expand([
        ("no_category/some", "else"),
        ("secg/no_curve", "else"),
        ("secg/secp128r1", "some")
    ])
    def test_unknown(self, name, coords):
        with self.assertRaises(ValueError):
            get_params(*name.split("/"), coords)