
    ¿ig2W                     ,   d dl Z d dlmZmZ d dlmZ d dlmZ d dlm	Z
 d dlmZmZmZmZmZmZmZmZ d dlmZ d dlmZ d d	lmZmZ d
 Zd Z G d de j                  Z G d de j                  Zi fdZ e!dk    rd Z" e j#        d           dS dS )    N)list_test_casesa2b_hexload_test_vectors_wycheproof)RSA)
PKCS1_OAEP)MD2MD5SHA1SHA256	RIPEMD160SHA224SHA384SHA512)Random)MGF1)bbchrc                 <    dD ]}|                      |d          } | S )z6Remove white spaces, tabs, and new lines from a string)
	  )replace)tcs     f/var/www/html/afkarena/venv/lib/python3.11/site-packages/Cryptodome/SelfTest/Cipher/test_pkcs1_oaep.pyrwsr   %   s+      IIaH    c                     t          |           }t          |          dz  dk    rt          d          t          |          S )z=Convert a text string with bytes in hex form to a byte string      z"Even number of characters expected)r   len
ValueErrorr   )r   cleans     r   t2br&   ,   s=    FFE
5zzA~=>>>5>>r   c                       e Zd Zd Zdddddddefd	d
dddddefdd
dddddefdd
dddddeffZd Zd Zd Zd Z	d Z
d Zd Zd  Zd! Zd" Zd#S )$PKCS1_OAEP_Testsc                 ~    t          j                    j        | _        t	          j        d| j                  | _        d S )Ni   )r   newreadrngr   generatekey1024selfs    r   setUpzPKCS1_OAEP_Tests.setUp6   s+    !:<<,"|D$(;;r   a  bb f8 2f 09 06 82 ce 9c 23 38 ac 2b 9d a8 71 f7
                36 8d 07 ee d4 10 43 a4 40 d6 b6 f0 74 54 f5 1f
                b8 df ba af 03 5c 02 ab 61 ea 48 ce eb 6f cd 48
                76 ed 52 0d 60 e1 ec 46 19 71 9d 8a 5b 8b 80 7f
                af b8 e0 a3 df c7 37 72 3e e6 b4 b7 d9 3a 25 84
                ee 6a 64 9d 06 09 53 74 88 34 b2 45 45 98 39 4e
                e0 aa b1 2d 7b 61 a5 1f 52 7a 9a 41 f6 c1 68 7f
                e2 53 72 98 ca 2a 8f 59 46 f8 e5 fd 09 1d bd cb11aU  a5dafc5341faf289c4b988db30c1cdf83f31251e0
                668b42784813801579641b29410b3c7998d6bc465745e5c3
                92669d6870da2c082a939e37fdcb82ec93edac97ff3ad595
                0accfbc111c76f1a9529444e56aaf68c56c092cd38dc3bef
                5d20a939926ed4f74a13eddfbe1a1cecc4894af9428c2b7b
                8883fe4463a4bc85b1cb3c1nedz/d4 36 e9 95 69 fd 32 a7 c8 a0 5b bc 90 d3 2c 49a  12 53 e0 4d c0 a5 39 7b b4 4a 7a b8 7e 9b f2 a0
                39 a3 3d 1e 99 6f c8 2a 94 cc d3 00 74 c9 5d f7
                63 72 20 17 06 9e 52 68 da 5d 1c 0b 4f 87 2c f6
                53 c1 1d f8 23 14 a6 79 68 df ea e2 8d ef 04 bb
                6d 84 b1 c3 1d 65 4a 19 70 e5 78 3b d6 eb 96 a0
                24 c2 ca 2f 4a 90 fe 9f 2e f5 c9 c1 40 e5 bb 48
                da 95 36 ad 87 00 c8 4f c9 13 0a de a7 4e 55 8d
                51 a7 4d df 85 d8 b5 0d e9 68 38 d6 06 3e 09 55zKaa fd 12 f6 59 ca e6 34 89 b4 79 e5 07 6d de c2
                f0 6c b5 8fa  a8 b3 b2 84 af 8e b5 0b 38 70 34 a8 60 f1 46 c4
                91 9f 31 87 63 cd 6c 55 98 c8 ae 48 11 a1 e0 ab
                c4 c7 e0 b0 82 d6 93 a5 e7 fc ed 67 5c f4 66 85
                12 77 2c 0c bc 64 a7 42 c6 c6 30 f5 33 c8 cc 72
                f6 2a e8 33 c4 0b f2 58 42 e9 84 bb 78 bd bf 97
                c0 10 7d 55 bd b6 62 f5 c4 e0 fa b9 84 5c b5 14
                8e f7 39 2d d3 aa ff 93 ae 1e 6b 66 7b b3 d4 24
                76 16 d4 f5 ba 10 d4 cf d2 26 de 88 d3 9f 16 fbz01 00 01a  53 33 9c fd b7 9f c8 46 6a 65 5c 73 16 ac a8 5c
                55 fd 8f 6d d8 98 fd af 11 95 17 ef 4f 52 e8 fd
                8e 25 8d f9 3f ee 18 0f a0 e4 ab 29 69 3c d8 3b
                15 2a 55 3d 4a c4 d1 81 2b 8b 9f a5 af 0e 7f 55
                fe 73 04 df 41 57 09 26 f3 31 1f 15 c4 d6 5a 73
                2c 48 31 16 ee 3d 3d 2d 0a f3 54 9a d9 bf 7c bf
                b7 8a d8 84 f8 4d 5b eb 04 72 4d c7 36 9b 31 de
                f3 7d 0c f5 39 e9 cf cd d3 de 65 37 29 ea d5 d1 zc66 28 19 4e 12 07 3d b0 3b a9 4c da 9e f9 53 23
                97 d5 0d ba 79 b9 87 00 4a fe fe 34a  35 4f e6 7b 4a 12 6d 5d 35 fe 36 c7 77 79 1a 3f
                7b a1 3d ef 48 4e 2d 39 08 af f7 22 fa d4 68 fb
                21 69 6d e9 5d 0b e9 11 c2 d3 17 4f 8a fc c2 01
                03 5f 7b 6d 8e 69 40 2d e5 45 16 18 c2 1a 53 5f
                a9 d7 bf c5 b8 dd 9f c2 43 f8 cf 92 7d b3 13 22
                d6 e8 81 ea a9 1a 99 61 70 e6 57 a0 5a 26 64 26
                d9 8c 88 00 3f 84 77 c1 22 70 94 a0 d9 fa 1e 8c
                40 24 30 9c e1 ec cc b5 21 00 35 d4 7a c7 2e 8azK18 b7 76 ea 21 06 9d 69 77 6a 33 e9 6b ad 48 e1
                dd a0 a5 efa  01 94 7c 7f ce 90 42 5f 47 27 9e 70 85 1f 25 d5
                e6 23 16 fe 8a 1d f1 93 71 e3 e6 28 e2 60 54 3e
                49 01 ef 60 81 f6 8c 0b 81 41 19 0d 2a e8 da ba
                7d 12 50 ec 6d b6 36 e9 44 ec 37 22 87 7c 7c 1d
                0a 67 f1 4b 16 94 c5 f0 37 94 51 a4 3e 49 a3 2d
                de 83 67 0b 73 da 91 a1 c9 9b c2 3b 43 6a 60 05
                5c 61 0f 0b af 99 c1 a0 79 56 5b 95 a3 f1 52 66
                32 d1 d4 da 60 f2 0e da 25 e6 53 c4 f0 02 76 6f
                45a  08 23 f2 0f ad b5 da 89 08 8a 9d 00 89 3e 21 fa
                4a 1b 11 fb c9 3c 64 a3 be 0b aa ea 97 fb 3b 93
                c3 ff 71 37 04 c1 9c 96 3c 1d 10 7a ae 99 05 47
                39 f7 9e 02 e1 86 de 86 f8 7a 6d de fe a6 d8 cc
                d1 d3 c8 1a 47 bf a7 25 5b e2 06 01 a4 a4 b2 f0
                8a 16 7b 5e 27 9d 71 5b 1b 45 5b dd 7e ab 24 59
                41 d9 76 8b 9a ce fb 3c cd a5 95 2d a3 ce e7 25
                25 b4 50 16 63 a8 ee 15 c9 e9 92 d9 24 62 fe 39z`8f f0 0c aa 60 5c 70 28 30 63 4d 9a 6c 3d 42 c6
                52 b5 8c f1 d9 2f ec 57 0b ee e7a  01 81 af 89 22 b9 fc b4 d7 9d 92 eb e1 98 15 99
                2f c0 c1 43 9d 8b cd 49 13 98 a0 f4 ad 3a 32 9a
                5b d9 38 55 60 db 53 26 83 c8 b7 da 04 e4 b1 2a
                ed 6a ac df 47 1c 34 c9 cd a8 91 ad dc c2 df 34
                56 65 3a a6 38 2e 9a e5 9b 54 45 52 57 eb 09 9d
                56 2b be 10 45 3f 2b 6d 13 c5 9c 02 e1 0f 1f 8a
                bb 5d a0 d0 57 09 32 da cf 2d 09 01 db 72 9d 0f
                ef cc 05 4e 70 96 8e a5 40 c8 1b 04 bc ae fe 72
                0ezK8c 40 7b 5e c2 89 9e 50 99 c5 3e 8c e7 93 bf 94
                e7 1b 17 82a  ae 45 ed 56 01 ce c6 b8 cc 05 f8 03 93 5c 67 4d
                db e0 d7 5c 4c 09 fd 79 51 fc 6b 0c ae c3 13 a8
                df 39 97 0c 51 8b ff ba 5e d6 8f 3f 0d 7f 22 a4
                02 9d 41 3f 1a e0 7e 4e be 9e 41 77 ce 23 e7 f5
                40 4b 56 9e 4e e1 bd cf 3c 1f b0 3e f1 13 80 2d
                4f 85 5e b9 b5 13 4b 5a 7c 80 85 ad ca e6 fa 2f
                a1 41 7e c3 76 3b e1 71 b0 c6 2b 76 0e de 23 c1
                2a d9 2b 98 08 84 c6 41 f5 a8 fa c2 6b da d4 a0
                33 81 a2 2f e1 b7 54 88 50 94 c8 25 06 d4 01 9a
                53 5a 28 6a fe b2 71 bb 9b a5 92 de 18 dc f6 00
                c2 ae ea e5 6e 02 f7 cf 79 fc 14 cf 3b dc 7c d8
                4f eb bb f9 50 ca 90 30 4b 22 19 a7 aa 06 3a ef
                a2 c3 c1 98 0e 56 0c d6 4a fe 77 95 85 b6 10 76
                57 b9 57 85 7e fd e6 01 09 88 ab 7d e4 17 fc 88
                d8 f3 84 c4 e6 e7 2c 3f 94 3e 0c 31 c0 c4 a5 cc
                36 f8 79 d8 a3 ac 9d 7d 59 86 0e aa da 6b 83 bba  05 6b 04 21 6f e5 f3 54 ac 77 25 0a 4b 6b 0c 85
                25 a8 5c 59 b0 bd 80 c5 64 50 a2 2d 5f 43 8e 59
                6a 33 3a a8 75 e2 91 dd 43 f4 8c b8 8b 9d 5f c0
                d4 99 f9 fc d1 c3 97 f9 af c0 70 cd 9e 39 8c 8d
                19 e6 1d b7 c7 41 0a 6b 26 75 df bf 5d 34 5b 80
                4d 20 1a dd 50 2d 5c e2 df cb 09 1c e9 99 7b be
                be 57 30 6f 38 3e 4d 58 81 03 f0 36 f7 e8 5d 19
                34 d1 52 a3 23 e4 a8 db 45 1d 6f 4a 5b 1b 0f 10
                2c c1 50 e0 2f ee e2 b8 8d ea 4a d4 c1 ba cc b2
                4d 84 07 2d 14 e1 d2 4a 67 71 f7 40 8e e3 05 64
                fb 86 d4 39 3a 34 bc f0 b7 88 50 1d 19 33 03 f1
                3a 22 84 b0 01 f0 f6 49 ea f7 93 28 d4 ac 5c 43
                0a b4 41 49 20 a9 46 0e d1 b7 bc 40 ec 65 3e 87
                6d 09 ab c5 09 ae 45 b5 25 19 01 16 a0 c2 61 01
                84 82 98 50 9c 1c 3b f3 a4 83 e7 27 40 54 e1 5e
                97 07 50 36 e9 89 f6 09 32 80 7b 52 57 75 1e 79zc8b ba 6b f8 2a 6c 0f 86 d5 f1 75 6e 97 95 68 70
                b0 89 53 b0 6b 4e b2 05 bc 16 94 eea  53 ea 5d c0 8c d2 60 fb 3b 85 85 67 28 7f a9 15
                52 c3 0b 2f eb fb a2 13 f0 ae 87 70 2d 06 8d 19
                ba b0 7f e5 74 52 3d fb 42 13 9d 68 c3 c5 af ee
                e0 bf e4 cb 79 69 cb f3 82 b8 04 d6 e6 13 96 14
                4e 2d 0e 60 74 1f 89 93 c3 01 4b 58 b9 b1 95 7a
                8b ab cd 23 af 85 4f 4c 35 6f b1 66 2a a7 2b fc
                c7 e5 86 55 9d c4 28 0d 16 0c 12 67 85 a7 23 eb
                ee be ff 71 f1 15 94 44 0a ae f8 7d 10 79 3a 87
                74 a2 39 d4 a0 4c 87 fe 14 67 b9 da f8 52 08 ec
                6c 72 55 79 4a 96 cc 29 14 2f 9a 8b d4 18 e3 c1
                fd 67 34 4b 0c d0 82 9d f3 b2 be c6 02 53 19 62
                93 c6 b3 4d 3f 75 d3 2f 21 3d d4 5c 62 73 d5 05
                ad f4 cc ed 10 57 cb 75 8f c2 6a ee fa 44 12 55
                ed 4e 64 c1 99 ee 07 5e 7f 16 64 61 82 fd b4 64
                73 9b 68 ab 5d af f0 e6 3e 95 52 01 68 24 f0 54
                bf 4d 3c 8c 90 a9 7b b6 b6 55 32 84 eb 42 9f cczK47 e1 ab 71 19 fe e5 6c 95 ee 5e aa d8 6f 40 d0
                aa 63 bd 33c                    | j         D ]fddD             }t          j        |          } G d d          }t          j        |d          |t          d                                       }|                    t          d                             }|                     |t          d	                              d S )
Nc                 b    g | ]+}t          t          d          |                   d          ,S r      intr   .0xtests     r   
<listcomp>z1PKCS1_OAEP_Tests.testEncrypt1.<locals>.<listcomp>  s1    FFFaSa__b11FFFr   )r4   r5   c                       e Zd Zd Zd ZdS ).PKCS1_OAEP_Tests.testEncrypt1.<locals>.randGenc                 "    || _         d| _        d S )Nr   dataidx)r0   rF   s     r   __init__z7PKCS1_OAEP_Tests.testEncrypt1.<locals>.randGen.__init__  s    $(	#$r   c                 N    | j         | j        |         }| xj        |z  c_        |S NrE   )r0   Nrs      r   __call__z7PKCS1_OAEP_Tests.testEncrypt1.<locals>.randGen.__call__  s(     Idhqj1A r   N)__name__
__module____qualname__rH   rM    r   r   randGenrC     s2        % % %! ! ! ! !r   rR         randfuncr"   r!   )	_testDatar   	constructPKCSr*   r&   encryptassertEqual)r0   compskeyrR   cipherctr@   s         @r   testEncrypt1zPKCS1_OAEP_Tests.testEncrypt1  s     3 3FFFF:FFFmE**	! 	! 	! 	! 	! 	! 	! 	! #tAwT!W9N9NOOO^^CQLL11  Sa\\2222+3 3r   c                 ~    d}t          j        | j                  }|                     t          |j        |           d S )NzW                                                                                       )rY   r*   r.   assertRaisesr$   rZ   )r0   ptr^   s      r   testEncrypt2zPKCS1_OAEP_Tests.testEncrypt2'  s8    &BXdl++Fj&."=====r   c                 8   | j         D ]fddD             }t          j        |          }t          j        |d                   }|                    t          d                             }|                     |t          d                              d S )Nc                 b    g | ]+}t          t          d          |                   d          ,S r9   r;   r=   s     r   rA   z1PKCS1_OAEP_Tests.testDecrypt1.<locals>.<listcomp>1  s1    JJJQSa__R00JJJr   r3   rS   r!   r"   )rW   r   rX   rY   r*   decryptr&   r[   )r0   r\   r]   r^   rc   r@   s        @r   testDecrypt1zPKCS1_OAEP_Tests.testDecrypt1-  s     3 3JJJJ/JJJmE**#tAw//^^CQLL11  Sa\\22223 3r   c                     dD ]L}t          j        | j                  }|                     t          |j        t          d          |z             Md S )N)         r   )rY   r*   r.   rb   r$   rg   r   )r0   ct_sizer^   s      r   testDecrypt2zPKCS1_OAEP_Tests.testDecrypt28  sX    * R R$,//!!*fnd4jj>PQQQQR Rr   c                    t          dd          D ]p}|                     |          }t          j        | j                  }|                    |          }|                    |          }|                     ||           qd S )Nr   V   )ranger,   rY   r*   r.   rZ   rg   r[   )r0   pt_lenrc   r^   r_   pt2s         r   testEncryptDecrypt1z$PKCS1_OAEP_Tests.testEncryptDecrypt1>  s    :.. * *XXf%%$,//^^B''nnR((  S))))* *r   c                 z     fd}t           t          t          t          t          fD ]}da                     d          }t          j         j	        ||          }|
                    |          }                     |                    |          |                                t
          |j                   d S )Nc                 B    t           | z  a                     |           S rJ   )askedr,   )rK   r0   s    r   localRngz6PKCS1_OAEP_Tests.testEncryptDecrypt2.<locals>.localRngK  s    
xx{{"r   r   (   rU   )r	   r
   r   r   r   rw   r,   rY   r*   r.   rZ   r[   rg   digest_size)r0   rx   hashmodrc   r^   r_   s   `     r   testEncryptDecrypt2z$PKCS1_OAEP_Tests.testEncryptDecrypt2G  s    # # # # #  dFI> = = XXb\\$,(KKK^^B''  !3!3R888  (;<<<<= =r   c                    |                      d          }|                      d          }t          j        | j        |          }|                    |          }|                     |                    |          |           d S )N#      )label)r,   rY   r*   r.   rZ   r[   rg   )r0   rc   xlabelr^   r_   s        r   testEncryptDecrypt3z$PKCS1_OAEP_Tests.testEncryptDecrypt3[  so    "BXXb\\FXdl&999F##BV^^B//44444r   c                 "   d }da |                     d          }t          j        | j        |          }|                    |          }|                     t           d           |                     |                    |          |           d S )Nc                      t           dz  a d|z  S )Nr"       )mgfcalls)seedmaskLens     r   newMGFz4PKCS1_OAEP_Tests.testEncryptDecrypt4.<locals>.newMGFh  s    A((r   r       )mgfuncr!   )r   r,   rY   r*   r.   rZ   r[   rg   )r0   r   rc   r^   r_   s        r   testEncryptDecrypt4z$PKCS1_OAEP_Tests.testEncryptDecrypt4c  s    
) ) )
 H"BXdl6:::F##BXq)))V^^B//44444r   c                 
   t          d          }t          j        | j                  }|                    t          |                    }|                    t          |                    }|                     ||           d S NXER)r   rY   r*   r.   rZ   	bytearrayrg   r[   r0   rc   r^   r_   rs   s        r   testByteArrayzPKCS1_OAEP_Tests.testByteArrayt  sh    5BXdl++F	"..B..2//CR%%%%%r   c                 >   t          d          }t          j        | j                  }|                    t          t          |                              }|                    t          t          |                              }|                     ||           d S r   )	r   rY   r*   r.   rZ   
memoryviewr   rg   r[   r   s        r   testMemoryviewzPKCS1_OAEP_Tests.testMemoryview{  sx    5BXdl++F
9R== 9 9::B..IbMM!:!:;;CR%%%%%r   N)rN   rO   rP   r1   r   rW   r`   rd   rh   rn   rt   r|   r   r   r   r   rQ   r   r   r(   r(   4   s       	< 	< 	<*C + , FC M'`C #D *7CK&^ #C *4M'`C  #C%" "H7C"y=YJ
	X	3 	3 	32	> 	> 	>		3 		3 		3	R 	R 	R	* 	* 	*	= 	= 	=(	5 	5 	5	5 	5 	5"	& 	& 	&	& 	& 	& 	& 	&r   r(   c                   8    e Zd Zd Zd Zd Zd Zd Zd Zd Z	dS )	TestVectorsWycheproofc                 n    t           j                            |            || _        || _        d| _        d S )NNone)unittestTestCaserH   _wycheproof_warnings_skip_slow_tests_id)r0   wycheproof_warningsskip_slow_testss      r   rH   zTestVectorsWycheproof.__init__  s4    ""4((($7! /r   c           
      T    d }d }d }d }t          d|d|z  ||||d          }|S )	Nc                 6    t          j        | d                   S )NprivateKeyPem)r   
import_keygroups    r   
filter_rsaz4TestVectorsWycheproof.load_tests.<locals>.filter_rsa  s    >%"8999r   c                     | d         dk    rt           S | d         dk    rt          S | d         dk    rt          S | d         dk    rt          S | d         dk    rt          S t          d| d         z             )NshaSHA-1SHA-224SHA-256SHA-384SHA-512zUnknown sha )r   r   r   r   r   r$   r   s    r   
filter_shaz4TestVectorsWycheproof.load_tests.<locals>.filter_sha  s}    U|w&&u**u**u**u** %,!>???r   c                     | d         dk    rd S | d         dk    rd S | d         dk    rd S | d         dk    rd	 S | d         d
k    rd S t          d| d         z             )NmgfShar   c                 .    t          | |t                    S rJ   )r   r   r?   ys     r   <lambda>zFTestVectorsWycheproof.load_tests.<locals>.filter_mgf.<locals>.<lambda>  s    DAt$4$4 r   r   c                 .    t          | |t                    S rJ   )r   r   r   s     r   r   zFTestVectorsWycheproof.load_tests.<locals>.filter_mgf.<locals>.<lambda>      DAv$6$6 r   r   c                 .    t          | |t                    S rJ   )r   r   r   s     r   r   zFTestVectorsWycheproof.load_tests.<locals>.filter_mgf.<locals>.<lambda>  r   r   r   c                 .    t          | |t                    S rJ   )r   r   r   s     r   r   zFTestVectorsWycheproof.load_tests.<locals>.filter_mgf.<locals>.<lambda>  r   r   r   c                 .    t          | |t                    S rJ   )r   r   r   s     r   r   zFTestVectorsWycheproof.load_tests.<locals>.filter_mgf.<locals>.<lambda>  r   r   zUnknown mgf/sha )r$   r   s    r   
filter_mgfz4TestVectorsWycheproof.load_tests.<locals>.filter_mgf  s    X'))444xI--666xI--666xI--666xI--666 !3eHo!EFFFr   c                 (    | d         d| d         S )Nr   z with MGF1/r   rQ   r   s    r   filter_algoz5TestVectorsWycheproof.load_tests.<locals>.filter_algo  s    (-eeHooFFr   )Cipher
wycheproofzWycheproof PKCS#1 OAEP (%s))rsa_keyhash_modmgfalgo)	group_tagr   )r0   filenamer   r   r   r   results          r   
load_testsz TestVectorsWycheproof.load_tests  s    	: 	: 	:	@ 	@ 	@	G 	G 	G	G 	G 	G ..F.6.Kh.VDNEO@JAL9N 9N0 0 0 r   c                    g | _         | j                             |                     d                     | j                             |                     d                     | j                             |                     d                     | j                             |                     d                     | j                             |                     d                     | j                             |                     d                     | j                             |                     d                     | j                             |                     d                     | j                             |                     d	                     | j        s| j                             |                     d
                     | j                             |                     d                     | j                             |                     d                     | j                             |                     d                     | j                             |                     d                     | j                             |                     d                     | j                             |                     d                     | j                             |                     d                     | j                             |                     d                     | j                             |                     d                     d S d S )Nz%rsa_oaep_2048_sha1_mgf1sha1_test.jsonz'rsa_oaep_2048_sha224_mgf1sha1_test.jsonz)rsa_oaep_2048_sha224_mgf1sha224_test.jsonz'rsa_oaep_2048_sha256_mgf1sha1_test.jsonz)rsa_oaep_2048_sha256_mgf1sha256_test.jsonz'rsa_oaep_2048_sha384_mgf1sha1_test.jsonz)rsa_oaep_2048_sha384_mgf1sha384_test.jsonz'rsa_oaep_2048_sha512_mgf1sha1_test.jsonz)rsa_oaep_2048_sha512_mgf1sha512_test.jsonz'rsa_oaep_3072_sha256_mgf1sha1_test.jsonz)rsa_oaep_3072_sha256_mgf1sha256_test.jsonz'rsa_oaep_3072_sha512_mgf1sha1_test.jsonz)rsa_oaep_3072_sha512_mgf1sha512_test.jsonz'rsa_oaep_4096_sha256_mgf1sha1_test.jsonz)rsa_oaep_4096_sha256_mgf1sha256_test.jsonz'rsa_oaep_4096_sha512_mgf1sha1_test.jsonz)rsa_oaep_4096_sha512_mgf1sha512_test.jsonzrsa_oaep_misc_test.json)tvextendr   r   r/   s    r   r1   zTestVectorsWycheproof.setUp  s   t'NOOPPPt'PQQRRRt'RSSTTTt'PQQRRRt'RSSTTTt'PQQRRRt'RSSTTTt'PQQRRRt'RSSTTT$ 
	GGNN4??+TUUVVVGNN4??+VWWXXXGNN4??+TUUVVVGNN4??+VWWXXXGNN4??+TUUVVVGNN4??+VWWXXXGNN4??+TUUVVVGNN4??+VWWXXXGNN4??+VWWXXXGNN4??+DEEFFFFF
	G 
	Gr   c                     | j         S rJ   )r   r/   s    r   shortDescriptionz&TestVectorsWycheproof.shortDescription  s	    xr   c                 ~    |j         r3| j        r.dd l}|                    d| j        d|j        d           d S d S d S )Nr   zWycheproof warning: z ())warningr   warningswarnr   comment)r0   r   r   s      r   r   zTestVectorsWycheproof.warn  sd    : 	R$3 	ROOOMMM4888RZZZPQQQQQ	R 	R 	R 	Rr   c                 h   d|j         d|j        | _        t          j        |j        |j        |j        |j                  }	 |	                    |j
                  }|j        sJ |                     ||j                   |                     |           d S # t          $ r |j        rJ Y d S w xY w)NzWycheproof Decrypt z Test #)hashAlgor   r   )r   idr   rY   r*   r   r   r   r   rg   r_   validr[   msgr   r$   )r0   r   r^   rc   s       r   test_decryptz"TestVectorsWycheproof.test_decrypt  s     79wwwF"*r{26QSQYZZZ	&&B 8OOOR(((IIbMMMMM  	  	  	 x	 s   B B10B1c                 D    | j         D ]}|                     |           d S rJ   )r   r   )r0   r   s     r   runTestzTestVectorsWycheproof.runTest  s4    ' 	" 	"Bb!!!!	" 	"r   N)
rN   rO   rP   rH   r   r1   r   r   r   r   rQ   r   r   r   r     s          , , ,\G G G.  R R R
  " " " " "r   r   c                     |                      d           }|                      d          }g }|t          t                    z  }|t          ||          gz  }|S )N
slow_testsr   )getr   r(   r   )configr   r   testss       r   	get_testsr     s_     **\222O **%:;;E	_-...E	#$7IIJJELr   __main__c                  F    t          j        t                                 d S rJ   )r   	TestSuiter   rQ   r   r   suiter     s    9;;'''''r   r   )defaultTest)$r   Cryptodome.SelfTest.st_commonr   r   Cryptodome.SelfTest.loaderr   Cryptodome.PublicKeyr   Cryptodome.Cipherr   rY   Cryptodome.Hashr	   r
   r   r   r   r   r   r   
Cryptodomer   Cryptodome.Signature.pssr   Cryptodome.Util.py3compatr   r   r   r&   r   r(   r   r   rN   r   mainrQ   r   r   <module>r      s  .  B B B B B B B B C C C C C C $ $ $ $ $ $ 0 0 0 0 0 0 U U U U U U U U U U U U U U U U U U U U       ) ) ) ) ) ) - - - - - - - -    L& L& L& L& L&x( L& L& L&^
e" e" e" e" e"H- e" e" e"P      z( ( (HMg&&&&&& r   