U
    gO>                  |   @   s(  d Z ddlZddlmZ dZdZddded	fd
dedfddedfddedfddedfddedfddedfddedfdd ed!fd"d#ed$fd%d&ed'fd(d)ed*fd+d,ed-fd.d/ed0fd1d2ed3fd4d5ed6fd7d8ed9fd:d;ed<fd=d>ed?fd@dAedBfdCdDedEfdFdGedHfdIdJedKfdLdMedNfdOdPedQfdRdSedTfdUdVedWfdXdYedZfd[d\ed]fd^d_ed`fdadbedcfdddeedffdgdhedifdjdkedlfdmdnedofdpdqedrfdsdtedufdvdwedxfdydzed{fd|d}ed~fddedfddedfddedfddedfddedfddedfddedfddedfddedfddedfddedfddedfddedfddedfddedfddedfddedfddedfddedfddedfddedfddedfddedfddedfedddfedddfedddfedddfedddfedddfedddfedddfedddfedddfedddfedddfedddfedddfedddfedddfedddfedddfedddfed ddfedddfedddfed	d
dfedddfedddfedddfedddfedddfedddfeddd fed!d"d#fed$d%d&fed'd(d)fed*d+d,fed-d.d/fed0d1d2fed3d4d5fed6d7d8fed9d:d;fed<d=d>fed?d@dAfedBdCdDfedEdFdGfedHdIdJfedKdLdMfedNdOdPfedQdRdSfedTdUdVfedWdXdYfedZd[d\fed]d^d_fed`dadbfedcdddefedfdgdhfedidjdkfedldmdnfgyZG dodp dpejZG dqdr drejZ	i fdsdtZ
edukr$ddlZdvdw Zejdxdy dS (z  z)Self-test suite for Cryptodome.Cipher.DES    N)DESZ01010101010101010000000000000000)r   Z82dcbafbdeab6602Z10316e028c8f3b4azNIST SP800-17 AZ8000000000000000Z95f8a5e5dd31d900zNIST SP800-17 B.1 #0Z4000000000000000Zdd7f121ca5015619zNIST SP800-17 B.1 #1Z2000000000000000Z2e8653104f3834eazNIST SP800-17 B.1 #2Z1000000000000000Z4bd388ff6cd81d4fzNIST SP800-17 B.1 #3Z0800000000000000Z20b9e767b2fb1456zNIST SP800-17 B.1 #4Z0400000000000000Z55579380d77138efzNIST SP800-17 B.1 #5Z0200000000000000Z6cc5defaaf04512fzNIST SP800-17 B.1 #6Z0100000000000000Z0d9f279ba5d87260zNIST SP800-17 B.1 #7Z0080000000000000Zd9031b0271bd5a0azNIST SP800-17 B.1 #8Z0040000000000000Z424250b37c3dd951zNIST SP800-17 B.1 #9Z0020000000000000Zb8061b7ecd9a21e5zNIST SP800-17 B.1 #10Z0010000000000000Zf15d0f286b65bd28zNIST SP800-17 B.1 #11Z0008000000000000Zadd0cc8d6e5deba1zNIST SP800-17 B.1 #12Z0004000000000000Ze6d5f82752ad63d1zNIST SP800-17 B.1 #13Z0002000000000000Zecbfe3bd3f591a5ezNIST SP800-17 B.1 #14Z0001000000000000Zf356834379d165cdzNIST SP800-17 B.1 #15Z0000800000000000Z2b9f982f20037fa9zNIST SP800-17 B.1 #16Z0000400000000000Z889de068a16f0be6zNIST SP800-17 B.1 #17Z0000200000000000Ze19e275d846a1298zNIST SP800-17 B.1 #18Z0000100000000000Z329a8ed523d71aeczNIST SP800-17 B.1 #19Z0000080000000000Ze7fce22557d23c97zNIST SP800-17 B.1 #20Z0000040000000000Z12a9f5817ff2d65dzNIST SP800-17 B.1 #21Z0000020000000000Za484c3ad38dc9c19zNIST SP800-17 B.1 #22Z0000010000000000Zfbe00a8a1ef8ad72zNIST SP800-17 B.1 #23Z0000008000000000Z750d079407521363zNIST SP800-17 B.1 #24Z0000004000000000Z64feed9c724c2fafzNIST SP800-17 B.1 #25Z0000002000000000Zf02b263b328e2b60zNIST SP800-17 B.1 #26Z0000001000000000Z9d64555a9a10b852zNIST SP800-17 B.1 #27Z0000000800000000Zd106ff0bed5255d7zNIST SP800-17 B.1 #28Z0000000400000000Ze1652c6b138c64a5zNIST SP800-17 B.1 #29Z0000000200000000Ze428581186ec8f46zNIST SP800-17 B.1 #30Z0000000100000000Zaeb5f5ede22d1a36zNIST SP800-17 B.1 #31Z0000000080000000Ze943d7568aec0c5czNIST SP800-17 B.1 #32Z0000000040000000Zdf98c8276f54b04bzNIST SP800-17 B.1 #33Z0000000020000000Zb160e4680f6c696fzNIST SP800-17 B.1 #34Z0000000010000000Zfa0752b07d9c4ab8zNIST SP800-17 B.1 #35Z0000000008000000Zca3a2b036dbc8502zNIST SP800-17 B.1 #36Z0000000004000000Z5e0905517bb59bcfzNIST SP800-17 B.1 #37Z0000000002000000Z814eeb3b91d90726zNIST SP800-17 B.1 #38Z0000000001000000Z4d49db1532919c9fzNIST SP800-17 B.1 #39Z0000000000800000Z25eb5fc3f8cf0621zNIST SP800-17 B.1 #40Z0000000000400000Zab6a20c0620d1c6fzNIST SP800-17 B.1 #41Z0000000000200000Z79e90dbc98f92ccazNIST SP800-17 B.1 #42Z0000000000100000Z866ecedd8072bb0ezNIST SP800-17 B.1 #43Z0000000000080000Z8b54536f2f3e64a8zNIST SP800-17 B.1 #44Z0000000000040000Zea51d3975595b86bzNIST SP800-17 B.1 #45Z0000000000020000Zcaffc6ac4542de31zNIST SP800-17 B.1 #46Z0000000000010000Z8dd45a2ddf90796czNIST SP800-17 B.1 #47Z0000000000008000Z1029d55e880ec2d0zNIST SP800-17 B.1 #48Z0000000000004000Z5d86cb23639dbea9zNIST SP800-17 B.1 #49Z0000000000002000Z1d1ca853ae7c0c5fzNIST SP800-17 B.1 #50Z0000000000001000Zce332329248f3228zNIST SP800-17 B.1 #51Z0000000000000800Z8405d1abe24fb942zNIST SP800-17 B.1 #52Z0000000000000400Ze643d78090ca4207zNIST SP800-17 B.1 #53Z0000000000000200Z48221b9937748a23zNIST SP800-17 B.1 #54Z0000000000000100Zdd7c0bbd61fafd54zNIST SP800-17 B.1 #55Z0000000000000080Z2fbc291a570db5c4zNIST SP800-17 B.1 #56Z0000000000000040Ze07c30d7e4e26e12zNIST SP800-17 B.1 #57Z0000000000000020Z0953e2258e8e90a1zNIST SP800-17 B.1 #58Z0000000000000010Z5b711bc4ceebf2eezNIST SP800-17 B.1 #59Z0000000000000008Zcc083f1e6d9e85f6zNIST SP800-17 B.1 #60Z0000000000000004Zd2fd8867d50d2dfezNIST SP800-17 B.1 #61Z0000000000000002Z06e7ea22ce92708fzNIST SP800-17 B.1 #62Z0000000000000001Z166b40b44aba4bd6zNIST SP800-17 B.1 #63Z95a8d72813daa94dZ8001010101010101zNIST SP800-17 B.2 #0Z0eec1487dd8c26d5Z4001010101010101zNIST SP800-17 B.2 #1Z7ad16ffb79c45926Z2001010101010101zNIST SP800-17 B.2 #2Zd3746294ca6a6cf3Z1001010101010101zNIST SP800-17 B.2 #3Z809f5f873c1fd761Z0801010101010101zNIST SP800-17 B.2 #4Zc02faffec989d1fcZ0401010101010101zNIST SP800-17 B.2 #5Z4615aa1d33e72f10Z0201010101010101zNIST SP800-17 B.2 #6Z2055123350c00858Z0180010101010101zNIST SP800-17 B.2 #7Zdf3b99d6577397c8Z0140010101010101zNIST SP800-17 B.2 #8Z31fe17369b5288c9Z0120010101010101zNIST SP800-17 B.2 #9Zdfdd3cc64dae1642Z0110010101010101zNIST SP800-17 B.2 #10Z178c83ce2b399d94Z0108010101010101zNIST SP800-17 B.2 #11Z50f636324a9b7f80Z0104010101010101zNIST SP800-17 B.2 #12Za8468ee3bc18f06dZ0102010101010101zNIST SP800-17 B.2 #13Za2dc9e92fd3cde92Z0101800101010101zNIST SP800-17 B.2 #14Zcac09f797d031287Z0101400101010101zNIST SP800-17 B.2 #15Z90ba680b22aeb525Z0101200101010101zNIST SP800-17 B.2 #16Zce7a24f350e280b6Z0101100101010101zNIST SP800-17 B.2 #17Z882bff0aa01a0b87Z0101080101010101zNIST SP800-17 B.2 #18Z25610288924511c2Z0101040101010101zNIST SP800-17 B.2 #19Zc71516c29c75d170Z0101020101010101zNIST SP800-17 B.2 #20Z5199c29a52c9f059Z0101018001010101zNIST SP800-17 B.2 #21Zc22f0a294a71f29fZ0101014001010101zNIST SP800-17 B.2 #22Zee371483714c02eaZ0101012001010101zNIST SP800-17 B.2 #23Za81fbd448f9e522fZ0101011001010101zNIST SP800-17 B.2 #24Z4f644c92e192dfedZ0101010801010101zNIST SP800-17 B.2 #25Z1afa9a66a6df92aeZ0101010401010101zNIST SP800-17 B.2 #26Zb3c1cc715cb879d8Z0101010201010101zNIST SP800-17 B.2 #27Z19d032e64ab0bd8bZ0101010180010101zNIST SP800-17 B.2 #28Z3cfaa7a7dc8720dcZ0101010140010101zNIST SP800-17 B.2 #29Zb7265f7f447ac6f3Z0101010120010101zNIST SP800-17 B.2 #30Z9db73b3c0d163f54Z0101010110010101zNIST SP800-17 B.2 #31Z8181b65babf4a975Z0101010108010101zNIST SP800-17 B.2 #32Z93c9b64042eaa240Z0101010104010101zNIST SP800-17 B.2 #33Z5570530829705592Z0101010102010101zNIST SP800-17 B.2 #34Z8638809e878787a0Z0101010101800101zNIST SP800-17 B.2 #35Z41b9a79af79ac208Z0101010101400101zNIST SP800-17 B.2 #36Z7a9be42f2009a892Z0101010101200101zNIST SP800-17 B.2 #37Z29038d56ba6d2745Z0101010101100101zNIST SP800-17 B.2 #38Z5495c6abf1e5df51Z0101010101080101zNIST SP800-17 B.2 #39Zae13dbd561488933Z0101010101040101zNIST SP800-17 B.2 #40Z024d1ffa8904e389Z0101010101020101zNIST SP800-17 B.2 #41Zd1399712f99bf02eZ0101010101018001zNIST SP800-17 B.2 #42Z14c1d7c1cffec79eZ0101010101014001zNIST SP800-17 B.2 #43Z1de5279dae3bed6fZ0101010101012001zNIST SP800-17 B.2 #44Ze941a33f85501303Z0101010101011001zNIST SP800-17 B.2 #45Zda99dbbc9a03f379Z0101010101010801zNIST SP800-17 B.2 #46Zb7fc92f91d8e92e9Z0101010101010401zNIST SP800-17 B.2 #47Zae8e5caa3ca04e85Z0101010101010201zNIST SP800-17 B.2 #48Z9cc62df43b6eed74Z0101010101010180zNIST SP800-17 B.2 #49Zd863dbb5c59a91a0Z0101010101010140zNIST SP800-17 B.2 #50Za1ab2190545b91d7Z0101010101010120zNIST SP800-17 B.2 #51Z0875041e64c570f7Z0101010101010110zNIST SP800-17 B.2 #52Z5a594528bebef1ccZ0101010101010108zNIST SP800-17 B.2 #53Zfcdb3291de21f0c0Z0101010101010104zNIST SP800-17 B.2 #54Z869efd7f9f265a09Z0101010101010102zNIST SP800-17 B.2 #55c                   @   s   e Zd ZdZdd ZdS )RonRivestTesta   Ronald L. Rivest's DES test, see
        http://people.csail.mit.edu/rivest/Destest.txt
    ABSTRACT
    --------

    We present a simple way to test the correctness of a DES implementation:
    Use the recurrence relation:

        X0      =       9474B8E8C73BCA7D (hexadecimal)

        X(i+1)  =       IF  (i is even)  THEN  E(Xi,Xi)  ELSE  D(Xi,Xi)

    to compute a sequence of 64-bit values:  X0, X1, X2, ..., X16.  Here
    E(X,K)  denotes the DES encryption of  X  using key  K, and  D(X,K)  denotes
    the DES decryption of  X  using key  K.  If you obtain

        X16     =       1B1A2DDB4C642438

    your implementation does not have any of the 36,568 possible single-fault
    errors described herein.
    c                 C   s   ddl m} g }dg|dd < tdD ]X}t|| tj}|d@ sb||| g||d d < q&||| g||d d < q&| ||d |d d S )Nr   )b2a_hexs   t;}      s   -Ld$8)	binasciir   ranger   newMODE_ECBencryptdecryptassertEqual)selfr   Xic r   G/tmp/pip-unpacked-wheel-_q8s9isk/Cryptodome/SelfTest/Cipher/test_DES.pyrunTest6  s    zRonRivestTest.runTestN)__name__
__module____qualname____doc__r   r   r   r   r   r      s   r   c                   @   s   e Zd Zdd ZdS )
TestOutputc                 C   s  t dt j}d}||}td}|j||d}| || | |d  |j||d}| || | |d  ttd}|j||d | || |j||d | || | jt	|j|dd | jt	|j|dd td}| jt
|j||d | jt
|j||d d S )Ns   44444444s   55555555   )outputs   00000000   )r   r
   r   r   	bytearrayr   r   
memoryviewassertRaises	TypeError
ValueError)r   cipherptctr   resZshorter_outputr   r   r   r   I  s(    
zTestOutput.runTestN)r   r   r   r   r   r   r   r   r   G  s   r   c                 C   s4   ddl m} |tdt}|t g7 }|t g7 }|S )Nr   )make_block_testsr   )commonr'   r   	test_datar   r   )configr'   testsr   r   r   	get_testsi  s
    r,   __main__c                   C   s   t t S )N)unittestZ	TestSuiter,   r   r   r   r   <lambda>s      r/   suite)ZdefaultTest)r   r.   ZCryptodome.Cipherr   ZSP800_17_B1_KEYZSP800_17_B2_PTr)   ZTestCaser   r   r,   r   r1   mainr   r   r   r   <module>   s  




































    '"