Detect truncated ASN data as UnparsableKeyError
This commit is contained in:
@@ -0,0 +1 @@
|
||||
v=DKIM1; g=*; k=rsa; p=MIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQDkHlOQoBTzWRiGs5V6NpP3idY6Wk08a5qhdR6wy5bdOKb2jLQiY/J16JYi0Qvx/byYzCNb3W91y3FutACDfzwQ/BC/e/8uBsCR+yz1Lxj+PL6lHvqMKrM3rG4hstT5QjvHO9PzoxZyVYLzBfO2EeC3Ip3G+2kryOTIKT+l/K4w3QIDAQA=
|
||||
@@ -23,6 +23,7 @@ import unittest
|
||||
|
||||
from dkim.crypto import (
|
||||
DigestTooLargeError,
|
||||
UnparsableKeyError,
|
||||
EMSA_PKCS1_v1_5_encode,
|
||||
int2str,
|
||||
parse_pem_private_key,
|
||||
@@ -108,7 +109,11 @@ class TestParseKeys(unittest.TestCase):
|
||||
key = parse_public_key(base64.b64decode(parse_tag_value(data)[b'p']))
|
||||
self.assertEqual(key['modulus'], TEST_KEY_MODULUS)
|
||||
self.assertEqual(key['publicExponent'], TEST_KEY_PUBLIC_EXPONENT)
|
||||
|
||||
try:
|
||||
data = read_test_data('test_bad.txt')
|
||||
key = parse_public_key(base64.b64decode(parse_tag_value(data)[b'p']))
|
||||
except UnparsableKeyError: return
|
||||
self.fail("failed to reject invalid public key")
|
||||
|
||||
class TestEMSA_PKCS1_v1_5(unittest.TestCase):
|
||||
|
||||
|
||||
Reference in New Issue
Block a user