ut_bip39.py 6.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143
  1. #!/usr/bin/env python3
  2. """
  3. test/unit_tests_d/ut_bip39: BIP39 unit test for the MMGen suite
  4. """
  5. from mmgen.util import msg,msg_r
  6. from ..include.common import cfg,qmsg,vmsg
  7. class unit_test:
  8. vectors = (
  9. ( "00000000000000000000000000000000",
  10. "abandon abandon abandon abandon abandon abandon abandon abandon abandon abandon abandon about"
  11. ),
  12. ( "7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f",
  13. "legal winner thank year wave sausage worth useful legal winner thank yellow"
  14. ),
  15. ( "80808080808080808080808080808080",
  16. "letter advice cage absurd amount doctor acoustic avoid letter advice cage above"
  17. ),
  18. ( "ffffffffffffffffffffffffffffffff",
  19. "zoo zoo zoo zoo zoo zoo zoo zoo zoo zoo zoo wrong"
  20. ),
  21. ( "000000000000000000000000000000000000000000000000",
  22. "abandon abandon abandon abandon abandon abandon abandon abandon abandon abandon abandon abandon abandon abandon abandon abandon abandon agent"
  23. ),
  24. ( "7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f",
  25. "legal winner thank year wave sausage worth useful legal winner thank year wave sausage worth useful legal will"
  26. ),
  27. ( "808080808080808080808080808080808080808080808080",
  28. "letter advice cage absurd amount doctor acoustic avoid letter advice cage absurd amount doctor acoustic avoid letter always"
  29. ),
  30. ( "ffffffffffffffffffffffffffffffffffffffffffffffff",
  31. "zoo zoo zoo zoo zoo zoo zoo zoo zoo zoo zoo zoo zoo zoo zoo zoo zoo when"
  32. ),
  33. ( "0000000000000000000000000000000000000000000000000000000000000000",
  34. "abandon abandon abandon abandon abandon abandon abandon abandon abandon abandon abandon abandon abandon abandon abandon abandon abandon abandon abandon abandon abandon abandon abandon art"
  35. ),
  36. ( "7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f",
  37. "legal winner thank year wave sausage worth useful legal winner thank year wave sausage worth useful legal winner thank year wave sausage worth title"
  38. ),
  39. ( "8080808080808080808080808080808080808080808080808080808080808080",
  40. "letter advice cage absurd amount doctor acoustic avoid letter advice cage absurd amount doctor acoustic avoid letter advice cage absurd amount doctor acoustic bless"
  41. ),
  42. ( "ffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff",
  43. "zoo zoo zoo zoo zoo zoo zoo zoo zoo zoo zoo zoo zoo zoo zoo zoo zoo zoo zoo zoo zoo zoo zoo vote"
  44. ),
  45. ( "9e885d952ad362caeb4efe34a8e91bd2",
  46. "ozone drill grab fiber curtain grace pudding thank cruise elder eight picnic"
  47. ),
  48. ( "6610b25967cdcca9d59875f5cb50b0ea75433311869e930b",
  49. "gravity machine north sort system female filter attitude volume fold club stay feature office ecology stable narrow fog"
  50. ),
  51. ( "68a79eaca2324873eacc50cb9c6eca8cc68ea5d936f98787c60c7ebc74e6ce7c",
  52. "hamster diagram private dutch cause delay private meat slide toddler razor book happy fancy gospel tennis maple dilemma loan word shrug inflict delay length"
  53. ),
  54. ( "c0ba5a8e914111210f2bd131f3d5e08d",
  55. "scheme spot photo card baby mountain device kick cradle pact join borrow"
  56. ),
  57. ( "6d9be1ee6ebd27a258115aad99b7317b9c8d28b6d76431c3",
  58. "horn tenant knee talent sponsor spell gate clip pulse soap slush warm silver nephew swap uncle crack brave"
  59. ),
  60. ( "9f6a2878b2520799a44ef18bc7df394e7061a224d2c33cd015b157d746869863",
  61. "panda eyebrow bullet gorilla call smoke muffin taste mesh discover soft ostrich alcohol speed nation flash devote level hobby quick inner drive ghost inside"
  62. ),
  63. ( "23db8160a31d3e0dca3688ed941adbf3",
  64. "cat swing flag economy stadium alone churn speed unique patch report train"
  65. ),
  66. ( "8197a4a47f0425faeaa69deebc05ca29c0a5b5cc76ceacc0",
  67. "light rule cinnamon wrap drastic word pride squirrel upgrade then income fatal apart sustain crack supply proud access"
  68. ),
  69. ( "066dca1a2bb7e8a1db2832148ce9933eea0f3ac9548d793112d9a95c9407efad",
  70. "all hour make first leader extend hole alien behind guard gospel lava path output census museum junior mass reopen famous sing advance salt reform"
  71. ),
  72. ( "f30f8c1da665478f49b001d94c5fc452",
  73. "vessel ladder alter error federal sibling chat ability sun glass valve picture"
  74. ),
  75. ( "c10ec20dc3cd9f652c7fac2f1230f7a3c828389a14392f05",
  76. "scissors invite lock maple supreme raw rapid void congress muscle digital elegant little brisk hair mango congress clump"
  77. ),
  78. ( "f585c11aec520db57dd353c69554b21a89b20fb0650966fa0a9d6f74fd989d8f",
  79. "void come effort suffer camp survey warrior heavy shoot primary clutch crush open amazing screen patrol group space point ten exist slush involve unfold"
  80. )
  81. )
  82. def run_test(self,name,ut):
  83. msg_r('Testing BIP39 conversion routines...')
  84. qmsg('')
  85. from mmgen.bip39 import bip39
  86. b = bip39()
  87. b.check_wordlist(cfg)
  88. vmsg('')
  89. qmsg('Checking seed to mnemonic conversion:')
  90. for v in self.vectors:
  91. chk = tuple(v[1].split())
  92. vmsg(' '+v[1])
  93. res = b.fromhex( v[0] )
  94. assert res == chk, f'mismatch:\nres: {res}\nchk: {chk}'
  95. vmsg('')
  96. qmsg('Checking mnemonic to seed conversion:')
  97. for v in self.vectors:
  98. chk = v[0]
  99. vmsg(' '+chk)
  100. res = b.tohex( v[1].split() )
  101. assert res == chk, f'mismatch:\nres: {res}\nchk: {chk}'
  102. vmsg('')
  103. qmsg('Checking error handling:')
  104. good_mn = "zoo zoo zoo zoo zoo zoo zoo zoo zoo zoo zoo wrong".split()
  105. bad_len_mn = "zoo zoo zoo".split()
  106. bad_chksum_mn = "zoo zoo zoo zoo zoo zoo zoo zoo zoo zoo zoo zoo".split()
  107. bad_word_mn = "admire zoo zoo zoo zoo zoo zoo zoo zoo zoo zoo zoo".split()
  108. bad_seed = 'deadbeef'
  109. good_seed = 'deadbeef' * 4
  110. th = b.tohex
  111. fh = b.fromhex
  112. bad_data = (
  113. ('hex', 'AssertionError', 'not a hexadecimal',lambda:fh('xx')),
  114. ('seed len', 'AssertionError', 'invalid seed bit', lambda:fh(bad_seed)),
  115. ('mnemonic type', 'AssertionError', 'must be list', lambda:th('string')),
  116. ('arg (tostr=True)', 'AssertionError', "'tostr' must be", lambda:fh(good_seed,tostr=True)),
  117. ('pad len (fromhex)','AssertionError', "invalid 'pad' arg",lambda:fh(good_seed,pad=23)),
  118. ('pad len (tohex)', 'AssertionError', "invalid 'pad' arg",lambda:th(good_mn,pad=23)),
  119. ('word', 'MnemonicError', "not in the BIP39", lambda:th(bad_word_mn)),
  120. ('checksum', 'MnemonicError', "checksum", lambda:th(bad_chksum_mn)),
  121. ('seed phrase len', 'MnemonicError', "phrase len", lambda:th(bad_len_mn)),
  122. )
  123. ut.process_bad_data(bad_data)
  124. vmsg('')
  125. msg('OK')
  126. return True