U
    Mfԑ                     @   s   d dl Z d dlmZ d dlmZ d dlm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
 ZG dd de jZG dd de jZG dd de jZG dd de jZi fddZedkrdd Ze jdd dS )    N	unhexlify)list_test_cases)load_test_vectors_wycheproof)tobytesbchr)AES)SHAKE128)strxorc                 C   s   t jt| d|S )N)data)r	   newr   read)taglength r   G/tmp/pip-unpacked-wheel-l_0d1exj/Cryptodome/SelfTest/Cipher/test_CCM.pyget_tag_random+   s    r   c                   @   s   e Zd ZeddZeddZeddZdd Zd	d
 Zdd Z	dd Z
dd Zdd Zdd Zdd Zdd Zdd Zdd Zdd Zdd  Zd!d" Zd#d$ Zd%d& Zd'd( Zd)d* Zd+d, Zd-d. Zd/d0 Zd1d2 Zd3d4 Zd5S )6CcmTestskey_128   	nonce_128   r      c                 C   sZ   t j| jt j| jd}tdd}||}t j| jt j| jd}||}| || d S )Nnonce	plaintexti@  )	r   r   r   MODE_CCMnonce_96r   encryptdecryptassertEqual)selfcipherptctpt2r   r   r   test_loopback_1285   s    


zCcmTests.test_loopback_128c                 C   s   t | jt j}|j}t | jt j}|j}| t|d | || t | jt j| j}|	| j
}t j| jt j| jd}| ||	| j
 d S )N   r   )r   r   r   r   r   r    lenassertNotEqualr   r   r   )r!   r"   nonce1nonce2r$   r   r   r   
test_nonce>   s    zCcmTests.test_noncec                 C   s   | j ttj| jtjdd d S )NZtest12345678r   )assertRaises	TypeErrorr   r   r   r   r!   r   r   r   test_nonce_must_be_bytesM   s    z!CcmTests.test_nonce_must_be_bytesc                 C   s   | j ttj| jtjdd | j ttj| jtjtdd d | j ttj| jtjtdd d tddD ] }tj| jtjtd| d qhd S )N    r               )r-   
ValueErrorr   r   r   r   r   range)r!   xr   r   r   test_nonce_lengthQ   s    

zCcmTests.test_nonce_lengthc                 C   s*   t j| jt j| jd}| |jt j d S Nr   )r   r   r   r   r   r    
block_sizer!   r"   r   r   r   test_block_size[   s    zCcmTests.test_block_sizec                 C   sj   t j| jt j| jd}| |j| j t | jt jj}t | jt jj}| t|d | || d S )Nr   r'   )	r   r   r   r   r   r    r   r(   r)   )r!   r"   r*   r+   r   r   r   test_nonce_attribute_   s    zCcmTests.test_nonce_attributec                 C   sV   |  ttj| jtj| jd | j ttj| jtj| jdd tj| jtj| jdd d S )Nr5   )r   unknownF)r   Z	use_aesni)r-   r.   r   r   r   r   r   r/   r   r   r   test_unknown_parametersi   s      z CcmTests.test_unknown_parametersc                 C   s>   dD ]4}t j| jt j| jd}t||d}| |d qd S )Nr   r   r   r1   )r   r   r   r   r   getattrr    )r!   funcr"   resultr   r   r   test_null_encryption_decryptiont   s    z(CcmTests.test_null_encryption_decryptionc                 C   sd   t j| jt j| jd}|d | t|jd t j| jt j| jd}|d | t|jd d S )Nr   r1   )	r   r   r   r   r   r   r-   r.   r   r<   r   r   r   test_either_encrypt_or_decryptz   s    

z'CcmTests.test_either_encrypt_or_decryptc                 C   sP   t j| jt j| jd}| t|jd t j| jt j| jd}| t|jd d S )Nr   ztest1234567890-*)	r   r   r   r   r   r-   r.   r   r   r<   r   r   r   test_data_must_be_bytes   s    z CcmTests.test_data_must_be_bytesc              	   C   s   t dddD ]"}| jttj| jtj| j|d qt dddD ]<}tj| jtj| j|d}|| j	\}}| 
t|| q<tj| jtj| jd}|| j	\}}| 
t|d d S )	N         )r   mac_len      r   r   )r7   r-   r6   r   r   r   r   r   encrypt_and_digestr   r    r(   )r!   rK   r"   _macr   r   r   test_mac_len   s     zCcmTests.test_mac_lenc                 C   sh   ddl m} tj| jtj| jd}|| j\}}||d}tj| jtj| jd}| 	t
|j|| d S )Nr   )strxor_cr   r2   )Cryptodome.Util.strxorrR   r   r   r   r   r   rN   r   r-   r6   decrypt_and_verify)r!   rR   r"   r$   rP   Zinvalid_macr   r   r   test_invalid_mac   s    
zCcmTests.test_invalid_macc                 C   sV   t j| jt j| jd}| }| | t| t j| jt j| jd}|	| d S r:   )
r   r   r   r   r   	hexdigestr    digestr   Z	hexverify)r!   r"   Zmac_hexr   r   r   test_hex_mac   s
    zCcmTests.test_hex_macc                 C   sV   t j| jt j| jdd}| t|jd t j| jt j| jdd}| t|j| j d S )Nr   r   	assoc_len   1   )	r   r   r   r   r   r-   r6   updater   r<   r   r   r   $test_longer_assoc_data_than_declared   s    z-CcmTests.test_longer_assoc_data_than_declaredc                 C   s  t | j}tj| jtj| j|d d}|| j | t	|j
| j tj| jtj| j|d d}|| j | t	|j tj| jtj| j|d d}|| j | t	|j| j tj| jtj| jd}|| j | }tj| jtj| j|d d}|| j | t	|j| d S )Nr2   rY   r   )r(   r   r   r   r   r   r   r]   r-   r6   r   rW   r   verify)r!   DATA_LENr"   rP   r   r   r   %test_shorter_assoc_data_than_expected   s0    
z.CcmTests.test_shorter_assoc_data_than_expectedc                 C   sr   t | j}tj| jtj| j|d d}|| j | t	|j
 tj| jtj| j|d d}| t	|j| j d S )Nr2   r   msg_len)r(   r   r   r   r   r   r   r   r-   r6   rW   )r!   r`   r"   r   r   r   /test_shorter_and_longer_plaintext_than_declared   s    
z8CcmTests.test_shorter_and_longer_plaintext_than_declaredc                 C   s   t | j}tj| jtj| jd}|| j\}}tj| jtj| j|d d}|| | 	t
|j| tj| jtj| j|d d}| 	t
|j| d S )Nr   r2   rb   )r(   r   r   r   r   r   r   rN   r   r-   r6   r_   )r!   r`   r"   r$   rP   r   r   r   %test_shorter_ciphertext_than_declared   s    

z.CcmTests.test_shorter_ciphertext_than_declaredc                 C   sB  t dd}t dd}tj| jtj| jd}|| ||\}}dd }dD ]p}tj| jtj| jddd}|||D ]}|| qvd	}	|||D ]}|	||7 }	q| 	||	 |
| qNdD ]x}tj| jtj| jddd}|||D ]}|| qd	}
|||D ]}|
||7 }
q
| 	||
 | 	| | qd S )
Nzauthenticated data   r   r   c                    s     fddt dt D S )Nc                    s   g | ]}||   qS r   r   ).0ichunk_lengthr   r   r   
<listcomp>   s     zBCcmTests.test_message_chunks.<locals>.break_up.<locals>.<listcomp>r   )r7   r(   )r   rj   r   ri   r   break_up   s    z.CcmTests.test_message_chunks.<locals>.break_up)
r2   rJ   rH   r5   
      r   (   P   r   r   rc   rZ   r1   )r   r   r   r   r   r   r]   rN   r   r    r_   r   rW   )r!   	auth_datar   r"   Z
ciphertextZref_macrl   rj   chunkr%   ct2r   r   r   test_message_chunks   s<    


  zCcmTests.test_message_chunksc                 C   sj  t | j}t | j}t | j}t | j}tj| jtj| jd}|| j || j}|	 }tj|tj|d}d|d d< d|d d< || d|d d< ||}	d|d d< |	 }
| 
||	 | 
||
 | 
|j|j t | j}t | j}t | j}~tj|tj|d}d|d d< d|d d< || d|d d< |t |	t |
}| 
| j| d S Nr   s   rH   )	bytearrayr   r   r   r   r   r   r]   r   rW   r    r   rT   )r!   Zkey_baZnonce_baZ	header_baZdata_bacipher1r$   r   cipher2ct_testtag_testcipher4pt_testr   r   r   test_bytearray  sN    









zCcmTests.test_bytearrayc                 C   s  t t| j}t t| j}t t| j}t t| j}tj| jtj| jd}|| j |	| j}|
 }tj|tj|d}d|d d< d|d d< || d|d d< |	|}	d|d d< |
 }
| ||	 | ||
 | |j|j t t| j}t t| j}t t| j}~tj|tj|d}d|d d< d|d d< || d|d d< |t |	t |
}| | j| d S rv   )
memoryviewrw   r   r   r   r   r   r   r]   r   rW   r    r   rT   )r!   Zkey_mvZnonce_mvZ	header_mvZdata_mvrx   r$   r   ry   rz   r{   r|   r}   r   r   r   test_memoryviewN  sN    


zCcmTests.test_memoryviewc                 C   s:  d}t j| jt j| jd}||}| }td}t j| jt j| jd}|j||d}| || | |d  t j| jt j| jd}|j	||d}| || | |d  t j| jt j| jd}|j
||d\}}| || | |d  | || t j| jt j| jd}|j|||d}| || | |d  d S Ns   55555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555r   r   output)r   r   r   r   r   r   rW   rw   r    r   rN   rT   )r!   r#   r"   r$   r   r   resZtag_outr   r   r   test_output_param}  s,    
zCcmTests.test_output_paramc                 C   s   d}t j| jt j| jd}||}ttd}t j| jt j| jd}|j||d | || t j| jt j| jd}|j	||d | || d S r   )
r   r   r   r   r   r   r   rw   r    r   )r!   r#   r"   r$   r   r   r   r   test_output_param_memoryview  s    
z%CcmTests.test_output_param_memoryviewc                 C   s   d}t j| jt j| jd}||}t j| jt j| jd}| jt|j|dd t j| jt j| jd}| jt|j|dd t	d}t j| jt j| jd}| jt
|j||d t j| jt j| jd}| jt
|j||d d S )Ns   5555555555555555r   s   0000000000000000r   r\   )r   r   r   r   r   r   r-   r.   r   rw   r6   )r!   r#   r"   r$   Zshorter_outputr   r   r   test_output_param_neg  s    
zCcmTests.test_output_param_negN)__name__
__module____qualname__r   r   r   r   r&   r,   r0   r9   r=   r>   r@   rE   rF   rG   rQ   rU   rX   r^   ra   rd   re   ru   r~   r   r   r   r   r   r   r   r   r   /   s4   


	

	+//r   c                   @   s   e Zd ZeddZeddZeddZdd Zdd	 Zd
d Z	dd Z
dd Zdd Zdd Zdd Zdd Zdd Zdd Zdd ZdS )CcmFSMTestsr   r   r   r   r   c              	   C   s~   dD ]t}d t | jfD ]`}tj| jtj| j||d}|| j}| }tj| jtj| j||d}|	| |
| qqd S N)Nr   r   rZ   rc   )r(   r   r   r   r   r   r   r   rW   r   r_   r!   rZ   rc   r"   r$   rP   r   r   r   -test_valid_init_encrypt_decrypt_digest_verify  s     
z9CcmFSMTests.test_valid_init_encrypt_decrypt_digest_verifyc              	   C   s   d t | jfD ]l}dD ]b}tj| jtj| j||d}|| j | }tj| jtj| j||d}|| j |	| qqd S r   )
r(   r   r   r   r   r   r   r]   rW   r_   )r!   rZ   rc   r"   rP   r   r   r   $test_valid_init_update_digest_verify  s     z0CcmFSMTests.test_valid_init_update_digest_verifyc              	   C   s   d t | jfD ]}d t | jfD ]x}tj| jtj| j||d}|| j || j}|	 }tj| jtj| j||d}|| j |
| || q qd S )Nr   )r(   r   r   r   r   r   r   r]   r   rW   r   r_   r   r   r   r   test_valid_full_path  s$    
z CcmFSMTests.test_valid_full_pathc                 C   s"   t j| jt j| jd}|  d S r:   )r   r   r   r   r   rW   r<   r   r   r   test_valid_init_digest   s    z"CcmFSMTests.test_valid_init_digestc                 C   sB   t j| jt j| jd}| }t j| jt j| jd}|| d S r:   )r   r   r   r   r   rW   r_   )r!   r"   rP   r   r   r   test_valid_init_verify  s    z"CcmFSMTests.test_valid_init_verifyc              	   C   s   dD ]}d d| j | j d fD ]x}|d kr.d }nt|}tj| jtj| jd|d}|d k	rb|| t||}|| j  || j  || j  || j  qqd S )NrA   s   333   3@   rq   )	r   r(   r   r   r   r   r   r]   rB   )r!   method_namerr   rZ   r"   methodr   r   r   &test_valid_multiple_encrypt_or_decrypt  s&    




z2CcmFSMTests.test_valid_multiple_encrypt_or_decryptc                 C   s   t j| jt j| jd}|| j | }tdD ]}| 	||  q2t j| jt j| jd}|| j tdD ]}|
| qrd S )Nr   rL      )r   r   r   r   r   r]   r   rW   r7   r    r_   )r!   r"   Z	first_macr8   r   r   r   $test_valid_multiple_digest_or_verify"  s    z0CcmFSMTests.test_valid_multiple_digest_or_verifyc                 C   sr   t j| jt j| jd}|| j || j\}}t j| jt j| jd}|| j |||}| 	| j| d S r:   )
r   r   r   r   r   r]   r   rN   rT   r    )r!   r"   r$   rP   r#   r   r   r   0test_valid_encrypt_and_digest_decrypt_and_verify0  s    z<CcmFSMTests.test_valid_encrypt_and_digest_decrypt_and_verifyc                 C   sb   dD ]X}dD ]N}t j| jt j| jd}|r6|| j t||}|| j | t	|| j qqd S )NrA   TFr   
r   r   r   r   r   r]   r   rB   r-   r.   )r!   r   assoc_data_presentr"   r   r   r   r   5test_invalid_multiple_encrypt_decrypt_without_msg_len<  s    

zACcmFSMTests.test_invalid_multiple_encrypt_decrypt_without_msg_lenc                 C   sj   dD ]`\}}dD ]R}t j| jt j| jdd}|r<|| j t||| j | t	t||| j qqd S )N)rA   )r   r   r       rb   r   )r!   Zmethod1_nameZmethod2_namer   r"   r   r   r   #test_invalid_mixing_encrypt_decryptH  s    z/CcmFSMTests.test_invalid_mixing_encrypt_decryptc                 C   sp   dD ]f}t j| jt j| jd}|| j |  | t	t
||| j t j| jt j| jd}|| j qd S )N)r   r]   r   )r   r   r   r   r   r   r   rW   r-   r.   rB   rN   )r!   r   r"   r   r   r   +test_invalid_encrypt_or_update_after_digestV  s    z7CcmFSMTests.test_invalid_encrypt_or_update_after_digestc                 C   s   t j| jt j| jd}|| j}| }dD ]|}t j| jt j| jd}|| |	| | 
tt||| j t j| jt j| jd}||| | 
tt||| j q.d S )Nr   )r   r]   )r   r   r   r   r   r   r   rW   r   r_   r-   r.   rB   rT   )r!   r"   r$   rP   r   r   r   r   +test_invalid_decrypt_or_update_after_verifya  s    

z7CcmFSMTests.test_invalid_decrypt_or_update_after_verifyN)r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r     s   


r   c                   @   s   e Zd ZdZdddddd edd	D d
 dddddfddddddddddddddddd d!d"d#d$d%d&d'gZd(d eD Zd)d* Zd+S ),TestVectorsz`Class exercising the CCM test vectors found in Appendix C
    of NIST SP 800-38C and in RFC 3610)0001020304050607Z20212223Z7162015bZ4dac255d 404142434445464748494a4b4c4d4e4fZ10111213141516)Z 000102030405060708090a0b0c0d0e0fZ 202122232425262728292a2b2c2d2e2fZ d2a1f0e051ea5f62081a7792073d593dZ1fc64fbfaccdr   Z1011121314151617)Z(000102030405060708090a0b0c0d0e0f10111213Z0202122232425262728292a2b2c2d2e2f3031323334353637Z0e3b201a9f5b71a7a9b1ceaeccd97e70b6176aad9a4428aa5Z484392fbc1b09951r   Z101112131415161718191a1b c                 C   s,   g | ]$}t d dD ]}d|d |  qqS )r   r   z%02X)r7   )rg   r8   yr   r   r   rk     s       zTestVectors.<listcomp>r   r      Z@202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3fZ@69915dad1e84c6376a68c2967e4dab615ae0fd1faec44cc484828529463ccf72Zb4ac6bec93e8598e7f0dadbcea5br   Z101112131415161718191a1b1c)r   .08090a0b0c0d0e0f101112131415161718191a1b1c1d1eZ.588c979a61c663d2f066d0c2c0f989806d5f6b61dac384Z17e8d12cfdf926e0 c0c1c2c3c4c5c6c7c8c9cacbcccdcecfZ00000003020100a0a1a2a3a4a5)r   008090a0b0c0d0e0f101112131415161718191a1b1c1d1e1fZ072c91a36e135f8cf291ca894085c87e3cc15c439c9e43a3bZa091d56e10400916r   Z00000004030201a0a1a2a3a4a5)r   208090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f20Z251b1e5f44a197d1da46b0f8e2d282ae871e838bb64da859657Z4adaa76fbd9fb0c5r   Z00000005040302A0A1A2A3A4A5)000102030405060708090a0b&0c0d0e0f101112131415161718191a1b1c1d1eZ&a28c6865939a9a79faaa5c4c2a9d4a91cdac8cZ96c861b9c9e61ef1r   Z00000006050403a0a1a2a3a4a5)r   (0c0d0e0f101112131415161718191a1b1c1d1e1fZ(dcf1fb7b5d9e23fb9d4e131253658ad86ebdca3eZ51e83f077d9c2d93r   Z00000007060504a0a1a2a3a4a5)r   *0c0d0e0f101112131415161718191a1b1c1d1e1f20Z*6fc1b011f006568b5171a42d953d469b2570a4bd87Z405a0443ac91cb94r   Z00000008070605a0a1a2a3a4a5)r   r   Z.0135d1b2c95f41d5d1d4fec185d166b8094e999dfed96cZ048c56602c97acbb7490r   Z00000009080706a0a1a2a3a4a5)r   r   Z07b75399ac0831dd2f0bbd75879a2fd8f6cae6b6cd9b7db24Zc17b4433f434963f34b4r   Z0000000a090807a0a1a2a3a4a5)r   r   Z282531a60cc24945a4b8279181ab5c84df21ce7f9b73f42e197Zea9c07e56b5eb17e5f4er   Z0000000b0a0908a0a1a2a3a4a5)r   r   Z&07342594157785152b074098330abb141b947bZ566aa9406b4d999988ddr   Z0000000c0b0a09a0a1a2a3a4a5)r   r   Z(676bb20380b0e301e8ab79590a396da78b834934Zf53aa2e9107a8b6c022cr   Z0000000d0c0b0aa0a1a2a3a4a5)r   r   Z*c0ffa0d6f05bdb67f24d43a4338d2aa4bed7b20e43Zcd1aa31662e7ad65d6dbr   Z0000000e0d0c0ba0a1a2a3a4a5)Z0be1a88bace018b1Z.08e8cf97d820ea258460e96ad9cf5289054d895ceac47cZ.4cb97f86a2a4689a877947ab8091ef5386a6ffbdd080f8Ze78cf7cb0cddd7b3 d7828d13b2b0bdc325a76236df93cc6bZ00412b4ea9cdbe3c9696766cfa)Z63018f76dc8a1bcbZ09020ea6f91bdd85afa0039ba4baff9bfb79c7028949cd0ecZ04ccb1e7ca981befaa0726c55d378061298c85c92814abc33Zc52ee81d7d77c08ar   Z0033568ef7b2633c9696766cfa)Zaa6cfa36cae86b40Z2b916e0eacc1c00d7dcec68ec0b3bbb1a02de8a2d1aa346132eZ2b1d23a2220ddc0ac900d9aa03c61fcf4a559a4417767089708Za776796edb723506r   Z00103fe41336713c9696766cfa)Zd0d0735c531e1becf049c244Z&12daac5630efa5396f770ce1a66b21f7b2101cZ&14d253c3967b70609b7cbb7c49916028324526Z9a6f49975bcadeafr   Z00764c63b8058e3c9696766cfa)Z77b60f011c03e1525899bcaeZ(e88b6a46c78d63e52eb8c546efb5de6f75e9cc0dZ(5545ff1a085ee2efbf52b2e04bee1e2336c73e3fZ762c0c7744fe7e3cr   Z00f8b678094e3b3c9696766cfa)Zcd9044d2b71fdb8120ea60c0Z*6435acbafb11a82e2f071d7ca4a5ebd93a803ba87fZ*009769ecabdf48625594c59251e6035722675e04c8Z47099e5ae0704551r   Z00d560912d3f703c9696766cfa)Zd85bc7e69f944fb8Z.8a19b950bcf71a018e5e6701c91787659809d67dbedd18Z.bc218daa947427b6db386a99ac1aef23ade0b52939cb6aZ637cf9bec2408897c6bar   Z0042fff8f1951c3c9696766cfa)Z74a0ebc9069f5b37Z01761433c37c5a35fc1f39f406302eb907c6163be38c98437Z05810e6fd25874022e80361a478e3e9cf484ab04f447efff6Zf0a477cc2fc9bf548944r   Z00920f40e56cdc3c9696766cfa)Z44a3aa3aae6475caZ2a434a8e58500c6e41530538862d686ea9e81301b5ae4226bfaZ2f2beed7bc5098e83feb5b31608f8e29c38819a89c8e776f154Z4d4151a4ed3a8b87b9cer   Z0027ca0c7120bc3c9696766cfa)Zec46bb63b02520c33c49fd70Z&b96b49e21d621741632875db7f6c9243d2d7c2Z&31d750a09da3ed7fddd49a2032aabf17ec8ebfZ7d22c8088c666be5c197r   Z005b8ccbcd9af83c9696766cfa)Z47a65ac78b3d594227e85e71Z(e2fcfbb880442c731bf95167c8ffd7895e337076Z(e882f1dbd38ce3eda7c23f04dd65071eb41342acZdf7e00dccec7ae52987dr   Z003ebe94044b9a3c9696766cfa)Z6e37a6ef546d955d34ab6059Z*abf21c0b02feb88f856df4a37381bce3cc128517d4Z*f32905b88a641b04b9c9ffb58cc390900f3da12ab1Z6dce9e82efa16da62059r   Z008d493b30ae8b3c9696766cfac                 C   s   g | ]}d d |D qS )c                 S   s   g | ]}t |qS r   r   )rg   r8   r   r   r   rk   ,  s     z!TestVectors.<listcomp>.<listcomp>r   )rg   tvr   r   r   rk   ,  s     c                 C   s   | j D ]\}}}}}}tj|tj|t|d}|| ||\}}	| || | ||	 tj|tj|t|d}|| |||}
| ||
 qd S )N)rK   )	test_vectorsr   r   r   r(   r]   rN   r    rT   )r!   Z
assoc_datar#   r$   rP   keyr   r"   rt   Zmac2r%   r   r   r   runTest.  s    

zTestVectors.runTestN)	r   r   r   __doc__joinr7   Ztest_vectors_hexr   r   r   r   r   r   r   s  sP     /r   c                   @   sL   e Zd Zdd Zdd Zdd Zdd Zd	d
 Zdd Zdd Z	dd Z
dS )TestVectorsWycheproofc                 K   s"   t j|  || _|| _d| _d S )NNone)unittestTestCase__init___wycheproof_warnings_extra_params_id)r!   wycheproof_warningsZextra_paramsr   r   r   r   @  s    zTestVectorsWycheproof.__init__c                 C   s"   dd }t dddd|id| _d S )Nc                 S   s   | d d S )NZtagSize   r   )groupr   r   r   
filter_tagH  s    z/TestVectorsWycheproof.setUp.<locals>.filter_tag)ZCipherZ
wycheproofzaes_ccm_test.jsonzWycheproof AES CCMtag_size)Z	group_tag)r   r   )r!   r   r   r   r   setUpF  s    zTestVectorsWycheproof.setUpc                 C   s   | j S N)r   r/   r   r   r   shortDescriptionP  s    z&TestVectorsWycheproof.shortDescriptionc                 C   s.   |j r*| jr*dd l}|d| j|jf  d S )Nr   zWycheproof warning: %s (%s))warningr   warningswarnr   comment)r!   r   r   r   r   r   r   S  s    zTestVectorsWycheproof.warnc              
   C   s  dt |j | _z(tj|jtj|jfd|ji| j	}W n t
k
r } zpt|jtdddkrdt |kr|jrvtW Y >d S |jtdddkrd	t |kr|jrtW Y d S |W 5 d }~X Y nX ||j ||j\}}|jr| ||j | ||j | | d S )
NzWycheproof Encrypt CCM Test #rK   r5   r4   rJ   Length of parameter 'nonce'rL   rM   Parameter 'mac_len')stridr   r   r   r   r   ivr   r   r6   r(   r7   validAssertionErrorr]   aadrN   msgr    r$   r   r   )r!   r   r"   er$   r   r   r   r   test_encryptX  s&    
"



z"TestVectorsWycheproof.test_encryptc              
   C   s4  dt |j | _z(tj|jtj|jfd|ji| j	}W n t
k
r } zpt|jtdddkrdt |kr|jrvtW Y >d S |jtdddkrd	t |kr|jrtW Y d S |W 5 d }~X Y nX ||j z||j|j}W n" t
k
r
   |jrtY n&X |jst| ||j | | d S )
NzWycheproof Decrypt CCM Test #rK   r5   r4   rJ   r   rL   rM   r   )r   r   r   r   r   r   r   r   r   r   r6   r(   r7   r   r   r]   r   rT   r$   r   r    r   r   )r!   r   r"   r   r#   r   r   r   test_decryptn  s*    
"



z"TestVectorsWycheproof.test_decryptc                 C   s   dt |j | _t|jtdddks4t|jdkr8d S tj|j	tj
|jfd|ji| j}||j t|jdt|jd  d	 }| t|j||j d S )
Nz%Wycheproof Corrupt Decrypt CCM Test #r5   r4   rJ   r   rK       r2      )r   r   r   r(   r   r7   r$   r   r   r   r   r   r   r]   r   r
   r-   r6   rT   r   )r!   r   r"   Z
ct_corruptr   r   r   test_corrupt_decrypt  s    $z*TestVectorsWycheproof.test_corrupt_decryptc                 C   s.   | j D ]"}| | | | | | qd S r   )r   r   r   r   )r!   r   r   r   r   r     s    


zTestVectorsWycheproof.runTestN)r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   >  s   

r   c                 C   sD   |  d}g }|tt7 }|tt7 }|t g7 }|t|g7 }|S )Nr   )getr   r   r   r   r   )configr   testsr   r   r   	get_tests  s    
r   __main__c                   C   s   t t  d S r   )r   Z	TestSuiter   r   r   r   r   suite  s    r   )ZdefaultTest)r   binasciir   ZCryptodome.SelfTest.st_commonr   ZCryptodome.SelfTest.loaderr   ZCryptodome.Util.py3compatr   r   ZCryptodome.Cipherr   ZCryptodome.Hashr	   rS   r
   r   r   r   r   r   r   r   r   r   mainr   r   r   r   <module>   s*       8 L[