data.py 27 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773
  1. #!/usr/bin/env python3
  2. #
  3. # MMGen Wallet, a terminal-based cryptocurrency wallet
  4. # Copyright (C)2013-2025 The MMGen Project <mmgen@tuta.io>
  5. # Licensed under the GNU General Public License, Version 3:
  6. # https://www.gnu.org/licenses
  7. # Public project repositories:
  8. # https://github.com/mmgen/mmgen-wallet
  9. # https://gitlab.com/mmgen/mmgen-wallet
  10. """
  11. test.tooltest2_d.data: Test vectors for the ‘mmgen-tool’ utility
  12. """
  13. import sys
  14. from decimal import Decimal
  15. from mmgen.key import is_wif
  16. from mmgen.addr import is_coin_addr
  17. from mmgen.util import is_hex_str
  18. from mmgen.bip39 import is_bip39_mnemonic
  19. from mmgen.baseconv import is_mmgen_mnemonic, is_b58_str
  20. from mmgen.xmrseed import is_xmrseed
  21. from ..modtest_d.baseconv import unit_test as baseconv
  22. from ..modtest_d.bip39 import unit_tests as bip39
  23. from ..modtest_d.xmrseed import unit_tests as xmrseed
  24. from ..include.common import cfg, sample_text
  25. proto = cfg._proto
  26. def is_str(s):
  27. return isinstance(s, str)
  28. def is_wif_loc(s):
  29. return is_wif(proto, s)
  30. def is_coin_addr_loc(s):
  31. return is_coin_addr(proto, s)
  32. def md5_hash(s):
  33. from hashlib import md5
  34. return md5(s.encode()).hexdigest()
  35. def md5_hash_strip(s):
  36. import re
  37. s = re.sub('\x1b' + r'\[[;0-9]+?m', '', s) # strip ANSI color sequences
  38. s = s.replace(NL, '\n') # fix DOS newlines
  39. return md5_hash(s.strip())
  40. NL = ('\n', '\r\n')[sys.platform=='win32']
  41. sample_text_hexdump = (
  42. '000000: 5468 6520 5469 6d65 7320 3033 2f4a 616e{n}' +
  43. '000010: 2f32 3030 3920 4368 616e 6365 6c6c 6f72{n}' +
  44. '000020: 206f 6e20 6272 696e 6b20 6f66 2073 6563{n}' +
  45. '000030: 6f6e 6420 6261 696c 6f75 7420 666f 7220{n}' +
  46. '000040: 6261 6e6b 73').format(n=NL)
  47. kafile_opts = ['-p1', '-Ptest/ref/keyaddrfile_password']
  48. btc_wif1 = '5HwzecKMWD82ppJK3qMKpC7ohXXAwcyAN5VgdJ9PLFaAzpBG4sX'
  49. btc_wif2 = 'KwojSzt1VvW343mQfWQi3J537siAt5ktL2qbuCg1ZyKR8BLQ6UJm'
  50. privhex1 = '0000000000000000000000000000000000000000000000000000000000000001'
  51. privhex2 = 'ffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff'
  52. privhex3 = '0fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff'
  53. privhex4 = '00000000000000000000000000000000000000000000000000000000000000ff'
  54. privhex5 = 'ffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff0f'
  55. privhex6 = 'deadbeefdeadbeefdeadbeefdeadbeefdeadbeefdeadbeefdeadbeefdeadbeef'
  56. privhex7 = '118089d66b4a5853765e94923abdd5de4616c6e5118089d66b4a5853765e9492'
  57. pubhash1 = '118089d66b4a5853765e94923abdd5de4616c6e5'
  58. pubhash2 = '3057f66ddd26fa6ef826b0d5ca067ec3e8f3c178'
  59. btc_addr1 = '1C5VPtgq9xQ6AcTgMAR3J6GDrs72HC4pS1'
  60. btc_addr2 = '1Kz9fVSUMshzPejpzW9D95kScgA3rY6QxF'
  61. btc_addr3 = '3AhjTiWHhVJAi1s5CfKMcLzYps12x3gZhg'
  62. btc_addr4 = 'bc1q6pqnfwwakuuejpm9w52ds342f9d5u36v0qnz7c'
  63. btc_addr5 = '12bYUGXS8SRArZneQDN9YEEYAtEa59Rykm'
  64. btc_addr6 = 'bc1qxptlvmwaymaxa7pxkr2u5pn7c0508stcncv7ms'
  65. btc_addr7 = '3Eevao3DRVXnYym3tdrJDqS3Wc39PQzahn'
  66. eth_addr1 = '7e5f4552091a69125d5dfcb7b8c2659029395bdf'
  67. eth_addr2 = 'b92702b3eefb3c2049aeb845b0335b283e11e9c6'
  68. eth_addr3 = 'ad30adc7451c1dace34c5d1f328f8a74a4947534'
  69. eth_addr4 = '5044a80bd3eff58302e638018534bbda8896c48a'
  70. eth_addr5 = '8b10f977e27611516f186980d8161b25f8adca5e'
  71. eth_addr6 = 'c96aaa54e2d44c299564da76e1cd3184a2386b8d'
  72. xmr_addr1 = '42nsXK8WbVGTNayQ6Kjw5UdgqbQY5KCCufdxdCgF7NgTfjC69Mna7DJSYyie77hZTQ8H92G2HwgFhgEUYnDzrnLnQdF28r3'
  73. xmr_addr2 = '49voQEbjouUQSDikRWKUt1PGbS47TBde4hiGyftN46CvTDd8LXCaimjHRGtofCJwY5Ed5QhYwc12P15AH5w7SxUAMCz1nr1'
  74. xmr_addr3 = '45Ee1yJSjXBKuf8aaihf6KgSRGtMBN6NNDtkd9fLJzHiK4ar4NyNxDk6afc7MTRoruAsg6J6792tCJazHqs1sjbv7LuEsLx'
  75. xmr_addr4 = '43aZyywWW4MYt2Az32XioQYirxyT8xeRBP84EBNA7Cra5SqQNmca6iD9pM487pcR9JAEiKrnw2QwvA5uWiFNokEzLJ5coZ9'
  76. xmr_addr5 = '4AeR1owefiJGbrAdSKCbVL73ME4FGv2cpczjV2peqqkxagm5D4gBqAHJta6NpbtxyuRe3ywaTj6QCHD59savvPW69wfW9my'
  77. xmr_addr6 = '41i7saPWA53EoHenmJVRt34dubPxsXwoWMnw8AdMyx4mTD1svf7qYzcVjxxRfteLNdYrAxWUMmiPegFW9EfoNgXx7vDMExv'
  78. zec_addr1 = 'zceQDpyNwek7dKqF5ZuFGj7YrNVxh7X1aPkrVxDLVxWSiZAFDEuy5C7XNV8VhyZ3ghTPQ61xjCGiyLT3wqpiN1Yi6mdmaCq'
  79. zec_addr2 = 'zcY1hqJ3P5ifjnWk1BcXpjrLG5XeJZUSPCiiVTF9LXrejxBzAsFWcNyr6PudwQHm8DnQpD8HEaM3dh8sB6cf91ciAa53YQ1'
  80. zec_addr4 = 'zcck12KgVY34LJwVEDLN8sXhL787zmjKqPsP1uBYRHs75bL9sQu4P7wcc5ZJTjKsL376zaSpsYqGxK94JbiYcNoH8DkeGbN'
  81. zec_addr5 = 'zcJ9hEezG1Jeye5dciqiMDh6SXtYbUsircGmpVyhHWyzyxDVRRDs5Q8M7hG3c7nDcvd5Pw4u4wV9RAQmq5RCBZq5wVyMQV8'
  82. zec_addr6 = 'zchFELwBxqsAubsLQ8yZgPCDDGukjXJssgCbiTPwFNmFwn9haLnDatzfhLdZzJT4PcU4o2yr92B52UFirUzEdF6ZYM2gBkM'
  83. redeem_script1 = '0014d04134b9ddb7399907657514d846aa495b4e474c'
  84. btc_pubhex1 = '024281a85c9ce87279e028410b851410d65136304cfbbbeaaa8e2e3931cf4e9727'
  85. btc_pubhex2 = '044281a85c9ce87279e028410b851410d65136304cfbbbeaaa8e2e3931cf4e972757f3254c322eeaa3cb6bf97cc5ecf8d4387b0df2c0b1e6ee18fe3a6977a7d57a'
  86. eth_pubhex1 = '0479be667ef9dcbbac55a06295ce870b07029bfcdb2dce28d959f2815b16f81798483ada7726a3c4655da4fbfc0e1108a8fd17b448a68554199c47d08ffb10d4b8' # Bitcoin-style '04'-prefixed pubkey
  87. eth_pubhex2 = '9166c289b9f905e55f9e3df9f69d7f356b4a22095f894f4715714aa4b56606aff181eb966be4acb5cff9e16b66d809be94e214f06c93fd091099af98499255e7' # raw pubkey
  88. xmr_pubhex1 = '1ed49357e217e79dab3c5503822f2bdb561e302e24476ee6ff33242c7551d4e78944790c0cfa9998c2f196061be89b2b8387f9d397db20ea8e049899cdc947d1'
  89. zec_pubhex1 = 'e6a4edbff547f21bcc2a825b6cf70f06e266a452d2da9d6dc5c1da3d99d7e996f488704dcdfe8d92cafe47772b3f692a98d59de1e99e00ff815f64ae59910f0c'
  90. rune_addr1 = 'thor1xptlvmwaymaxa7pxkr2u5pn7c0508stcr9tw2z'
  91. tests = {
  92. 'Mnemonic': {
  93. 'hex2mn': (
  94. [([a[0]], b) for a, b in baseconv.vectors['mmgen']] +
  95. [([a, 'fmt=bip39'], b) for a, b in bip39.vectors] +
  96. [([a, 'fmt=xmrseed'], b) for a, b in xmrseed.vectors]
  97. ),
  98. 'mn2hex': (
  99. [([b, 'fmt=mmgen'], a[0]) for a, b in baseconv.vectors['mmgen']] +
  100. [([b, 'fmt=bip39'], a) for a, b in bip39.vectors] +
  101. [([b, 'fmt=xmrseed'], a) for a, b in xmrseed.vectors]
  102. ),
  103. 'mn_rand128': [
  104. ([], is_mmgen_mnemonic, ['-r0']),
  105. (['fmt=mmgen'], is_mmgen_mnemonic, ['-r0']),
  106. (['fmt=bip39'], is_bip39_mnemonic, ['-r0']),
  107. ],
  108. 'mn_rand192': [
  109. (['fmt=mmgen'], is_mmgen_mnemonic, ['-r0']),
  110. (['fmt=bip39'], is_bip39_mnemonic, ['-r0']),
  111. ],
  112. 'mn_rand256': [
  113. (['fmt=mmgen'], is_mmgen_mnemonic, ['-r0']),
  114. (['fmt=bip39'], is_bip39_mnemonic, ['-r0']),
  115. (['fmt=xmrseed'], is_xmrseed, ['-r0']),
  116. ],
  117. 'mn_stats': [
  118. ([], is_str),
  119. (['fmt=mmgen'], is_str),
  120. (['fmt=bip39'], is_str),
  121. (['fmt=xmrseed'], is_str),
  122. ],
  123. 'mn_printlist': [
  124. ([], is_str),
  125. (['fmt=mmgen'], is_str),
  126. (['fmt=bip39'], is_str),
  127. (['fmt=xmrseed', 'enum=true'], is_str),
  128. ],
  129. },
  130. 'Util': {
  131. 'hextob32': [
  132. (['deadbeef'], 'DPK3PXP'),
  133. (['deadbeefdeadbeef'], 'N5LN657PK3PXP'),
  134. (['ffffffffffffffff'], 'P777777777777'),
  135. (['0000000000000000'], 'A'),
  136. (['0000000000000000', 'pad=10'], 'AAAAAAAAAA'),
  137. (['ff', 'pad=10'], 'AAAAAAAAH7'),
  138. ],
  139. 'b32tohex': [
  140. (['DPK3PXP'], 'deadbeef'),
  141. (['N5LN657PK3PXP'], 'deadbeefdeadbeef'),
  142. (['P777777777777'], 'ffffffffffffffff'),
  143. (['A', 'pad=16'], '0000000000000000'),
  144. (['AAAAAAAAAA', 'pad=16'], '0000000000000000'),
  145. (['AAAAAAAAH7', 'pad=2'], 'ff'),
  146. ],
  147. 'hextob6d': [
  148. (['deadbeef'], '25255 24636 426'),
  149. (['deadbeefdeadbeef'], '43263 51255 35545 36422 42642'),
  150. (['ffffffffffffffff'], '46316 33121 21321 15553 55534'),
  151. (['0000000000000000'], '1'),
  152. (['0000000000000000', 'pad=10'], '11111 11111'),
  153. (['ff', 'pad=10'], '11111 12214'),
  154. (
  155. ['ff'*16],
  156. '34164 46464 12666 61652 46515 46546 53354 43666 45555 21414'
  157. ), (
  158. ['ff'*24],
  159. '24611 14114 33323 36422 24655 66552 32465 25661 21541 62342 '
  160. '61351 63525 45161 35543 13654'
  161. ), (
  162. ['ff'*32],
  163. '21325 21653 31261 31341 45131 42346 54146 36252 11413 12253 '
  164. '24246 31114 16424 56513 41632 24121 46151 43214 22425 65134'
  165. ),
  166. ],
  167. 'b6dtohex': [
  168. (['25255 24636 426'], 'deadbeef'),
  169. (['43263 51255 35545 36422 42642'], 'deadbeefdeadbeef'),
  170. (['46316 33121 21321 15553 55534'], 'ffffffffffffffff'),
  171. (['1', 'pad=16'], '0000000000000000'),
  172. (['11111 11111', 'pad=16'], '0000000000000000'),
  173. (['11111 12214', 'pad=2'], 'ff'),
  174. (['22222 22222'], 'b88733'),
  175. (['66666 66666'], '039aa3ff'),
  176. (['6'*50], {
  177. 'len': 34,
  178. 'value':'0260154fc36cbf42778f23ffffffffffff' # 130 bits
  179. }),
  180. (['6'*75], {
  181. 'len': 50,
  182. 'value':'03a92ef1c3432e71a7679561bb6817d7ffffffffffffffffff' # 194 bits
  183. }),
  184. (['6'*100], {
  185. 'len': 66,
  186. 'value':'05a4653ca673768565b41f775d6947d55cf3813d0fffffffffffffffffffffffff' # 259 bits
  187. }),
  188. ],
  189. 'hextob58chk': [
  190. (['deadbeef'], 'eFGDJPketnz'),
  191. (['deadbeefdeadbeef'], '5CizhNNRPYpBjrbYX'),
  192. (['ffffffffffffffff'], '5qCHTcgbQwprzjWrb'),
  193. (['0000000000000000'], '111111114FCKVB'),
  194. (['00'], '1Wh4bh'),
  195. (['000000000000000000000000000000000000000000'], '1111111111111111111114oLvT2'),
  196. ],
  197. 'b58chktohex': [
  198. (['eFGDJPketnz'], 'deadbeef'),
  199. (['5CizhNNRPYpBjrbYX'], 'deadbeefdeadbeef'),
  200. (['5qCHTcgbQwprzjWrb'], 'ffffffffffffffff'),
  201. (['111111114FCKVB'], '0000000000000000'),
  202. (['3QJmnh'], ''),
  203. (['1111111111111111111114oLvT2'], '000000000000000000000000000000000000000000'),
  204. ],
  205. 'bytestob58': [
  206. ([b'\xde\xad\xbe\xef'], '6h8cQN'),
  207. ([b'\xde\xad\xbe\xef\xde\xad\xbe\xef'], 'eFGDJURJykA'),
  208. ([b'\xff\xff\xff\xff\xff\xff\xff\xff'], 'jpXCZedGfVQ'),
  209. ([b'\x00\x00\x00\x00\x00\x00\x00\x00'], '1'),
  210. ([b'\x00\x00\x00\x00\x00\x00\x00\x00', 'pad=10'], '1111111111'),
  211. ([b'\xff', 'pad=10'], '111111115Q'),
  212. ],
  213. 'b58tobytes': [
  214. (['6h8cQN'], b'\xde\xad\xbe\xef'),
  215. (['eFGDJURJykA'], b'\xde\xad\xbe\xef\xde\xad\xbe\xef'),
  216. (['jpXCZedGfVQ'], b'\xff\xff\xff\xff\xff\xff\xff\xff'),
  217. (['1', 'pad=8'], b'\x00\x00\x00\x00\x00\x00\x00\x00'),
  218. (['1111111111', 'pad=8'], b'\x00\x00\x00\x00\x00\x00\x00\x00'),
  219. (['111111115Q', 'pad=1'], b'\xff'),
  220. ],
  221. 'hextob58': [
  222. (['deadbeef'], '6h8cQN'),
  223. (['deadbeefdeadbeef'], 'eFGDJURJykA'),
  224. (['ffffffffffffffff'], 'jpXCZedGfVQ'),
  225. (['0000000000000000'], '1'),
  226. (['0000000000000000', 'pad=10'], '1111111111'),
  227. (['ff', 'pad=10'], '111111115Q'),
  228. ],
  229. 'b58tohex': [
  230. (['6h8cQN'], 'deadbeef'),
  231. (['eFGDJURJykA'], 'deadbeefdeadbeef'),
  232. (['jpXCZedGfVQ'], 'ffffffffffffffff'),
  233. (['1', 'pad=16'], '0000000000000000'),
  234. (['1111111111', 'pad=16'], '0000000000000000'),
  235. (['111111115Q', 'pad=2'], 'ff'),
  236. ],
  237. 'bytespec': [
  238. (['1G'], str(1024*1024*1024)),
  239. (['1GB'], str(1000*1000*1000)),
  240. (['1234GB'], str(1234*1000*1000*1000)),
  241. (['1234G'], str(1234*1024*1024*1024)),
  242. (['1234TB'], str(1234*1000*1000*1000*1000)),
  243. (['1234T'], str(1234*1024*1024*1024*1024)),
  244. (['1234PB'], str(1234*1000*1000*1000*1000*1000)),
  245. (['1234P'], str(1234*1024*1024*1024*1024*1024)),
  246. (['1234EB'], str(1234*1000*1000*1000*1000*1000*1000)),
  247. (['1234E'], str(1234*1024*1024*1024*1024*1024*1024)),
  248. (['1.234MB'], str(1234*1000)),
  249. (['1.234567M'], str(int(Decimal('1.234567')*1024*1024))),
  250. (['1234'], str(1234)),
  251. ],
  252. 'to_bytespec': [
  253. ([str(1024*1024*1024), 'G'], '1.00G'),
  254. ([str(1024*1024*1024), 'G', 'fmt=0.0'], '1G'),
  255. ([str(1024*1024*1024), 'G', 'fmt=08.5'], '01.00000G'),
  256. ([str(1234*1000*1000*1000), 'GB'], '1234.00GB'),
  257. ([str(1234*1000*1000*1000), 'GB', 'strip=True'], '1234.0GB'),
  258. ([str(1234*1000*1000*1000), 'GB', 'add_space=True'], '1234.00 GB'),
  259. ([str(1234*1024*1024*1024), 'G'], '1234.00G',),
  260. ([str(1000*1000*1000*1000*1000), 'PB'], '1.00PB'),
  261. ([str(1024*1024*1024*1024*1024), 'P'], '1.00P'),
  262. ([str(1024*1024*1024*1024*1024*1024), 'E'], '1.00E'),
  263. ([str(int(Decimal('1.234567')*1024*1024)), 'M', 'fmt=0.6'], '1.234567M'),
  264. (['1234', 'c', 'fmt=0.0', 'print_sym=false'], '1234'),
  265. ],
  266. 'hash160': [ # TODO: check that hextob58chk(hash160) = pubhex2addr
  267. (['deadbeef'], 'f04df4c4b30d2b7ac6e1ed2445aeb12a9cb4d2ec'),
  268. (['000000000000000000000000000000000000000000'], '2db95e704e2d9b0474acf76182f3f985b7064a8a'),
  269. ([''], 'b472a266d0bd89c13706a4132ccfb16f7c3b9fcb'),
  270. (['ffffffffffffffff'], 'f86221f5a1fca059a865c0b7d374dfa9d5f3aeb4'),
  271. ],
  272. 'hash256': [
  273. (['deadbeef'], 'e107944e77a688feae4c2d4db5951923812dd0f72026a11168104ee1b248f8a9'),
  274. (
  275. ['000000000000000000000000000000000000000000'],
  276. 'fd5181fcd097a334ab340569e5edcd09f702fef7994abab01f4b66e86b32ebbe'
  277. ),
  278. ([''], '5df6e0e2761359d30a8275058e299fcc0381534545f55cf43e41983f5d4c9456'),
  279. (['ffffffffffffffff'], '57b2d2c3455e0f76c61c5237ff04fc9fc0f3fe691e587ea9c951949e1a5e0fed'),
  280. ],
  281. 'hexdump': [
  282. ([sample_text.encode()], sample_text_hexdump),
  283. ],
  284. 'unhexdump': [
  285. ([sample_text_hexdump.encode()], sample_text.encode()),
  286. ],
  287. 'hexlify': [
  288. ([b'foobar'], '666f6f626172'),
  289. ],
  290. 'unhexlify': [
  291. (['666f6f626172'], 'foobar'),
  292. ],
  293. 'hexreverse': [
  294. (['deadbeefcafe'], 'fecaefbeadde'),
  295. ],
  296. 'id6': [
  297. ([sample_text.encode()], 'a6d72b'),
  298. ],
  299. 'id8': [
  300. ([sample_text.encode()], '687C09C2'),
  301. ],
  302. 'str2id6': [
  303. (['74ev zjeq Zw2g DspF RKpE 7H'], '70413d'), # checked
  304. ],
  305. 'randhex': [
  306. ([], {'boolfunc':is_hex_str, 'len':64}, ['-r0']),
  307. (['nbytes=16'], {'boolfunc':is_hex_str, 'len':32}, ['-r0']),
  308. (['nbytes=6'], {'boolfunc':is_hex_str, 'len':12}, ['-r0']),
  309. ],
  310. 'randb58': [
  311. ([], {'boolfunc':is_b58_str}, ['-r0']),
  312. (['nbytes=16'], {'boolfunc':is_b58_str}, ['-r0']),
  313. (['nbytes=12', 'pad=0'], is_b58_str, ['-r0']),
  314. ],
  315. },
  316. 'Wallet': {
  317. 'gen_key': [
  318. (
  319. ['98831F3A:11', 'wallet=test/ref/98831F3A.mmwords'],
  320. '5JKLcdYbhP6QQ4BXc9HtjfqJ79FFRXP2SZTKUyEuyXJo9QSFUkv'
  321. ), (
  322. ['98831F3A:C:11', 'wallet=test/ref/98831F3A.mmwords'],
  323. 'L2LwXv94XTU2HjCbJPXCFuaHjrjucGipWPWUi1hkM5EykgektyqR'
  324. ), (
  325. ['98831F3A:B:11', 'wallet=test/ref/98831F3A.mmwords'],
  326. 'L2K4Y9MWb5oUfKKZtwdgCm6FLZdUiWJDHjh9BYxpEvtfcXt4iM5g'
  327. ), (
  328. ['98831F3A:S:11', 'wallet=test/ref/98831F3A.mmwords'],
  329. 'KwmkkfC9GghnJhnKoRXRn5KwGCgXrCmDw6Uv83NzE4kJS5axCR9A'
  330. ),
  331. ],
  332. 'gen_addr': [
  333. (['98831F3A:11', 'wallet=test/ref/98831F3A.mmwords'], btc_addr5),
  334. (['98831F3A:L:11', 'wallet=test/ref/98831F3A.mmwords'], btc_addr5),
  335. (
  336. ['98831F3A:C:11', 'wallet=test/ref/98831F3A.mmwords'],
  337. '1MPsZ7BY9qikqfPxqmrovE8gLDX2rYArZk'
  338. ),
  339. (['98831F3A:B:11', 'wallet=test/ref/98831F3A.mmwords'], btc_addr6),
  340. (['98831F3A:S:11', 'wallet=test/ref/98831F3A.mmwords'], btc_addr7),
  341. ],
  342. 'get_subseed': [
  343. (['3s', 'wallet=test/ref/98831F3A.mmwords'], '4018EB17'),
  344. (['200', 'wallet=test/ref/98831F3A.mmwords'], '2B05AE73'),
  345. ],
  346. 'get_subseed_by_seed_id': [
  347. (['4018EB17', 'wallet=test/ref/98831F3A.mmwords'], '3S'),
  348. (['2B05AE73', 'wallet=test/ref/98831F3A.mmwords'], None),
  349. (['2B05AE73', 'wallet=test/ref/98831F3A.mmwords', 'last_idx=200'], '200L'),
  350. ],
  351. 'list_subseeds': [
  352. (
  353. ['1-5', 'wallet=test/ref/98831F3A.mmwords'],
  354. (md5_hash_strip, '996c047e8543d5dde6f82efc3214a6a1')
  355. ),
  356. ],
  357. 'list_shares': [
  358. (
  359. ['3', 'wallet=test/ref/98831F3A.bip39'],
  360. (md5_hash_strip, '84e8bdaebf9c816a8a3bd2ebec5a2e12')
  361. ), (
  362. ['3', 'id_str=default', 'wallet=test/ref/98831F3A.mmwords'],
  363. (md5_hash_strip, '84e8bdaebf9c816a8a3bd2ebec5a2e12')
  364. ), (
  365. ['3', 'id_str=foo', 'wallet=test/ref/98831F3A.bip39'],
  366. (md5_hash_strip, 'd2ac20823c4ea26f15234b5ca8df5d6f')
  367. ), (
  368. ['3', 'id_str=foo', 'master_share=0', 'wallet=test/ref/98831F3A.mmwords'],
  369. (md5_hash_strip, 'd2ac20823c4ea26f15234b5ca8df5d6f')
  370. ), (
  371. ['3', 'id_str=foo', 'master_share=5', 'wallet=test/ref/98831F3A.mmwords'],
  372. (md5_hash_strip, 'c4feedce40bb5959011ee4a996710832')
  373. ), (
  374. ['3', 'id_str=βαρ', 'master_share=5', 'wallet=test/ref/98831F3A.mmwords'],
  375. (md5_hash_strip, 'f7d254798fe2e34b94b5f4ff312998db')
  376. ), (
  377. ['4', 'id_str=βαρ', 'master_share=5', 'wallet=test/ref/98831F3A.bip39'],
  378. (md5_hash_strip, 'd3e479f55792181372a9f32a569c04e5')
  379. ),
  380. ],
  381. },
  382. 'Coin': {
  383. 'addr2pubhash': {
  384. 'btc_mainnet': [
  385. ([btc_addr5], pubhash1),
  386. ([btc_addr6], pubhash2),
  387. ],
  388. 'rune_mainnet': [
  389. ([rune_addr1], pubhash2),
  390. ],
  391. },
  392. 'eth_checksummed_addr': {
  393. 'eth_mainnet': [
  394. (['00a329c0648769a73afac7f9381e08fb43dbea72'], '00a329c0648769A73afAc7F9381E08FB43dBEA72'),
  395. (['deadbeef'*5], 'DeaDbeefdEAdbeefdEadbEEFdeadbeEFdEaDbeeF'),
  396. (['ffffffff'*5], 'FFfFfFffFFfffFFfFFfFFFFFffFFFffffFfFFFfF'),
  397. (['0'*39 + '1'], '0'*39 + '1'),
  398. ],
  399. },
  400. 'pubhash2addr': {
  401. 'btc_mainnet': [
  402. ([pubhash1], btc_addr5, None, 'legacy'),
  403. (['8e34586186551f6320fa3eb2d238a9c61ab8264b'], '37ZBgCBjjz9WSEzp1Zjv8sqdgmNie3Kd5s',
  404. ['--type=segwit'], 'segwit'),
  405. ([pubhash2], btc_addr6, ['--type=bech32'], 'bech32'),
  406. ],
  407. 'rune_mainnet': [
  408. ([pubhash2], rune_addr1, ['--type=X'], 'bech32x'),
  409. ],
  410. },
  411. 'addr2scriptpubkey': {
  412. 'btc_mainnet': [
  413. ([btc_addr5], '76a914118089d66b4a5853765e94923abdd5de4616c6e588ac'),
  414. ([btc_addr7], 'a9148e34586186551f6320fa3eb2d238a9c61ab8264b87'),
  415. ([btc_addr6], '00143057f66ddd26fa6ef826b0d5ca067ec3e8f3c178'),
  416. ],
  417. },
  418. 'scriptpubkey2addr': {
  419. 'btc_mainnet': [
  420. (['76a914118089d66b4a5853765e94923abdd5de4616c6e588ac'], btc_addr5),
  421. (['a9148e34586186551f6320fa3eb2d238a9c61ab8264b87'], btc_addr7),
  422. (['00143057f66ddd26fa6ef826b0d5ca067ec3e8f3c178'], btc_addr6),
  423. ],
  424. },
  425. 'hex2wif': {
  426. 'btc_mainnet': [
  427. ([privhex7], btc_wif1, None, 'legacy'),
  428. ([privhex7], btc_wif2, ['--type=compressed'], 'compressed'),
  429. ([privhex7], btc_wif2, ['--type=segwit'], 'segwit'),
  430. ([privhex7], btc_wif2, ['--type=bech32'], 'bech32'),
  431. ],
  432. },
  433. 'privhex2addr': {
  434. 'btc_mainnet': [
  435. ([privhex7], btc_addr1, None, 'legacy'),
  436. ([privhex7], btc_addr2, ['--type=compressed'], 'compressed'),
  437. ([privhex7], btc_addr3, ['--type=segwit'], 'segwit'),
  438. ([privhex7], btc_addr4, ['--type=bech32'], 'bech32'),
  439. ],
  440. 'eth_mainnet': [
  441. ([privhex1], eth_addr1),
  442. ([privhex2], eth_addr2),
  443. ([privhex3], eth_addr3),
  444. ([privhex4], eth_addr4),
  445. ([privhex5], eth_addr5),
  446. ([privhex6], eth_addr6),
  447. ],
  448. 'xmr_mainnet': [
  449. ([privhex1], xmr_addr1),
  450. ([privhex2], xmr_addr2),
  451. ([privhex3], xmr_addr3),
  452. ([privhex4], xmr_addr4),
  453. ([privhex5], xmr_addr5),
  454. ([privhex6], xmr_addr6),
  455. ],
  456. 'zec_mainnet': [
  457. ([privhex1], zec_addr1, ['--type=zcash_z'], 'zcash_z'),
  458. ([privhex2], zec_addr2, ['--type=zcash_z'], 'zcash_z'),
  459. ([privhex3], zec_addr2, ['--type=zcash_z'], 'zcash_z'),
  460. ([privhex4], zec_addr4, ['--type=zcash_z'], 'zcash_z'),
  461. ([privhex5], zec_addr5, ['--type=zcash_z'], 'zcash_z'),
  462. ([privhex6], zec_addr6, ['--type=zcash_z'], 'zcash_z'),
  463. ],
  464. },
  465. 'privhex2pubhex': {
  466. 'btc_mainnet': [
  467. ([privhex7], btc_pubhex2, None, 'legacy'),
  468. ([privhex7], btc_pubhex1, ['--type=compressed'], 'compressed'),
  469. ([privhex7], btc_pubhex1, ['--type=segwit'], 'segwit'),
  470. ([privhex7], btc_pubhex1, ['--type=bech32'], 'bech32'),
  471. ],
  472. 'eth_mainnet': [
  473. ([privhex1], eth_pubhex1),
  474. ],
  475. 'xmr_mainnet': [
  476. ([privhex1], xmr_pubhex1),
  477. ],
  478. 'zec_mainnet': [
  479. ([privhex1], zec_pubhex1, ['--type=zcash_z'], 'zcash_z'),
  480. ],
  481. },
  482. 'pubhex2addr': {
  483. 'btc_mainnet': [
  484. ([btc_pubhex2], btc_addr1, None, 'legacy'),
  485. ([btc_pubhex1], btc_addr2, ['--type=compressed'], 'compressed'),
  486. ([btc_pubhex1], btc_addr3, ['--type=segwit'], 'segwit'),
  487. ([btc_pubhex1], btc_addr4, ['--type=bech32'], 'bech32'),
  488. ],
  489. 'eth_mainnet': [
  490. ([eth_pubhex1], eth_addr1),
  491. ([eth_pubhex2], eth_addr2),
  492. ],
  493. 'xmr_mainnet': [
  494. ([xmr_pubhex1], xmr_addr1),
  495. ],
  496. 'zec_mainnet': [
  497. ([zec_pubhex1], zec_addr1, ['--type=zcash_z'], 'zcash_z'),
  498. ],
  499. },
  500. 'pubhex2redeem_script': {
  501. 'btc_mainnet': [
  502. ([btc_pubhex1], redeem_script1, ['--type=segwit'], 'segwit'),
  503. ],
  504. },
  505. 'redeem_script2addr': {
  506. 'btc_mainnet': [
  507. ([redeem_script1], btc_addr3, ['--type=segwit'], 'segwit'),
  508. ],
  509. },
  510. 'randpair': {
  511. 'btc_mainnet': [([], [is_wif_loc, is_coin_addr_loc], ['-r0'])],
  512. 'btc_testnet': [([], [is_wif_loc, is_coin_addr_loc], ['-r0'])],
  513. },
  514. 'randwif': {
  515. 'btc_mainnet': [([], is_wif_loc, ['-r0'])],
  516. 'btc_testnet': [([], is_wif_loc, ['-r0'])],
  517. },
  518. 'wif2addr': {
  519. 'btc_mainnet': [
  520. ([btc_wif1], btc_addr1, ['--type=legacy'], 'legacy'),
  521. ([btc_wif2], btc_addr2, ['--type=compressed'], 'compressed'),
  522. ([btc_wif2], btc_addr3, ['--type=segwit'], 'segwit'),
  523. ([btc_wif2], btc_addr4, ['--type=bech32'], 'bech32'),
  524. ],
  525. 'eth_mainnet': [
  526. ([privhex1], eth_addr1),
  527. (['000000000000000000000000000000014551231950b75fc4402da1732fc9bebe'], eth_addr2),
  528. ([privhex3], eth_addr3),
  529. ([privhex4], eth_addr4),
  530. (['000000000000000000000000000000014551231950b75fc4402da1732fc9bdce'], eth_addr5),
  531. ([privhex6], eth_addr6),
  532. ],
  533. 'xmr_mainnet': [
  534. ([privhex1], xmr_addr1),
  535. (['1c95988d7431ecd670cf7d73f45befc6feffffffffffffffffffffffffffff0f'], xmr_addr2),
  536. (['2c94988d7431ecd670cf7d73f45befc6feffffffffffffffffffffffffffff0f'], xmr_addr3),
  537. (['1d95988d7431ecd670cf7d73f45befc6feffffffffffffffffffffffffffff0e'], xmr_addr4),
  538. ([privhex5], xmr_addr5),
  539. (['e8164dda6d42bd1e261a3406b2038dcbddadbeefdeadbeefdeadbeefdeadbe0f'], xmr_addr6),
  540. ],
  541. 'zec_mainnet': [
  542. (
  543. ['SKxny894fJe2rmZjeuoE6GVfNkWoXfPp8337VrLLNWG56FjqVUYR'],
  544. zec_addr1, ['--type=zcash_z'], 'zcash_z'
  545. ), (
  546. ['SKxv1peuQvMT4TvqPLqKy1px3oqLm98Evi948VU8N8VKcf7C2umc'],
  547. zec_addr2, ['--type=zcash_z'], 'zcash_z'
  548. ), (
  549. ['SKxny894fJe2rmZjeuoE6GVfNkWoXfPp8337VrLLNWG56kQw4qjm'],
  550. zec_addr4, ['--type=zcash_z'], 'zcash_z'
  551. ), (
  552. ['SKxv1peuQvMT4TvqPLqKy1px3oqLm98Evi948VU8N8VKcBwrLwiu'],
  553. zec_addr5, ['--type=zcash_z'], 'zcash_z'
  554. ), (
  555. ['SKxuS56e99jpCeD9mMQ5o63zoGPakNdM9HCvt4Vt2cypvRjCdvGJ'],
  556. zec_addr6, ['--type=zcash_z'], 'zcash_z'
  557. ),
  558. ],
  559. },
  560. 'wif2hex': {
  561. 'btc_mainnet': [
  562. ([btc_wif1], privhex7, None, 'legacy'),
  563. ([btc_wif2], privhex7, ['--type=compressed'], 'compressed'),
  564. ([btc_wif2], privhex7, ['--type=segwit'], 'segwit'),
  565. ([btc_wif2], privhex7, ['--type=bech32'], 'bech32'),
  566. ],
  567. },
  568. 'wif2redeem_script': {
  569. 'btc_mainnet': [
  570. ([btc_wif2], redeem_script1, ['--type=segwit'], 'segwit'),
  571. ],
  572. },
  573. 'wif2segwit_pair': {
  574. 'btc_mainnet': [
  575. ([btc_wif2], (redeem_script1, btc_addr3), ['--type=segwit'], 'segwit'),
  576. ],
  577. },
  578. },
  579. # TODO: compressed address files are missing
  580. # 'addrfile_compressed_chk':
  581. # 'btc': ('A33C 4FDE F515 F5BC', '6C48 AA57 2056 C8C8'),
  582. # 'ltc': ('3FC0 8F03 C2D6 BD19', '4C0A 49B6 2DD1 1BE0'),
  583. 'File': {
  584. 'addrfile_chksum': {
  585. 'btc_mainnet': [
  586. (
  587. ['test/ref/98831F3A[1,31-33,500-501,1010-1011].addrs'],
  588. '6FEF 6FB9 7B13 5D91'
  589. ), (
  590. ['test/ref/98831F3A-S[1,31-33,500-501,1010-1011].addrs'],
  591. '06C1 9C87 F25C 4EE6'
  592. ), (
  593. ['test/ref/98831F3A-B[1,31-33,500-501,1010-1011].addrs'],
  594. '9D2A D4B6 5117 F02E'
  595. ),
  596. ],
  597. 'btc_testnet': [
  598. (
  599. ['test/ref/98831F3A[1,31-33,500-501,1010-1011].testnet.addrs'],
  600. '424E 4326 CFFE 5F51'
  601. ), (
  602. ['test/ref/98831F3A-S[1,31-33,500-501,1010-1011].testnet.addrs'],
  603. '072C 8B07 2730 CB7A'
  604. ), (
  605. ['test/ref/98831F3A-B[1,31-33,500-501,1010-1011].testnet.addrs'],
  606. '0527 9C39 6C1B E39A'
  607. ),
  608. ],
  609. 'ltc_mainnet': [
  610. (
  611. ['test/ref/litecoin/98831F3A-LTC[1,31-33,500-501,1010-1011].addrs'],
  612. 'AD52 C3FE 8924 AAF0'
  613. ), (
  614. ['test/ref/litecoin/98831F3A-LTC-S[1,31-33,500-501,1010-1011].addrs'],
  615. '63DF E42A 0827 21C3'
  616. ), (
  617. ['test/ref/litecoin/98831F3A-LTC-B[1,31-33,500-501,1010-1011].addrs'],
  618. 'FF1C 7939 5967 AB82'
  619. ),
  620. ],
  621. 'ltc_testnet': [
  622. (
  623. ['test/ref/litecoin/98831F3A-LTC[1,31-33,500-501,1010-1011].testnet.addrs'],
  624. '4EBE 2E85 E969 1B30'
  625. ), (
  626. ['test/ref/litecoin/98831F3A-LTC-S[1,31-33,500-501,1010-1011].testnet.addrs'],
  627. '5DD1 D186 DBE1 59F2'
  628. ), (
  629. ['test/ref/litecoin/98831F3A-LTC-B[1,31-33,500-501,1010-1011].testnet.addrs'],
  630. 'ED3D 8AA4 BED4 0B40'
  631. ),
  632. ],
  633. 'zec_mainnet': [
  634. (['test/ref/zcash/98831F3A-ZEC-C[1,31-33,500-501,1010-1011].addrs'], '903E 7225 DD86 6E01'),
  635. (
  636. ['test/ref/zcash/98831F3A-ZEC-Z[1,31-33,500-501,1010-1011].addrs'],
  637. '9C7A 72DC 3D4A B3AF', ['--type=zcash_z'], 'zcash_z'
  638. ),
  639. ],
  640. 'xmr_mainnet': [
  641. (['test/ref/monero/98831F3A-XMR-M[1,31-33,500-501,1010-1011].addrs'], '4369 0253 AC2C 0E38'),],
  642. 'dash_mainnet': [
  643. (['test/ref/dash/98831F3A-DASH-C[1,31-33,500-501,1010-1011].addrs'], 'FBC1 6B6A 0988 4403'),],
  644. 'eth_mainnet': [
  645. (['test/ref/ethereum/98831F3A-ETH[1,31-33,500-501,1010-1011].addrs'],'E554 076E 7AF6 66A3'),],
  646. 'etc_mainnet': [
  647. (
  648. ['test/ref/ethereum_classic/98831F3A-ETC[1,31-33,500-501,1010-1011].addrs'],
  649. 'E97A D796 B495 E8BC'
  650. ),
  651. ],
  652. 'rune_mainnet': [
  653. (
  654. ['test/ref/thorchain/98831F3A-RUNE-X[1,31-33,500-501,1010-1011].addrs'],
  655. '00C6 1930 557F 5E99'
  656. ),
  657. ],
  658. },
  659. 'viewkeyaddrfile_chksum': {
  660. 'xmr_mainnet': [
  661. (['test/ref/monero/98831F3A-XMR-M[1-3].vkeys'], '40C9 0E61 B743 229C'),
  662. ],
  663. },
  664. 'keyaddrfile_chksum': {
  665. 'btc_mainnet': [
  666. (
  667. ['test/ref/98831F3A[1,31-33,500-501,1010-1011].akeys.mmenc'],
  668. '9F2D D781 1812 8BAD', kafile_opts
  669. ),
  670. ],
  671. 'btc_testnet': [
  672. (
  673. ['test/ref/98831F3A[1,31-33,500-501,1010-1011].testnet.akeys.mmenc'],
  674. '88CC 5120 9A91 22C2', kafile_opts
  675. ),
  676. ],
  677. 'ltc_mainnet': [
  678. (
  679. ['test/ref/litecoin/98831F3A-LTC[1,31-33,500-501,1010-1011].akeys.mmenc'],
  680. 'B804 978A 8796 3ED4', kafile_opts
  681. ),
  682. ],
  683. 'ltc_testnet': [
  684. (
  685. ['test/ref/litecoin/98831F3A-LTC[1,31-33,500-501,1010-1011].testnet.akeys.mmenc'],
  686. '98B5 AC35 F334 0398', kafile_opts
  687. ),
  688. ],
  689. 'zec_mainnet': [
  690. (
  691. ['test/ref/zcash/98831F3A-ZEC-C[1,31-33,500-501,1010-1011].akeys.mmenc'],
  692. 'F05A 5A5C 0C8E 2617', kafile_opts
  693. ), (
  694. ['test/ref/zcash/98831F3A-ZEC-Z[1,31-33,500-501,1010-1011].akeys.mmenc'],
  695. '6B87 9B2D 0D8D 8D1E', kafile_opts + ['--type=zcash_z'], 'zcash_z'
  696. ),
  697. ],
  698. 'xmr_mainnet': [
  699. (
  700. ['test/ref/monero/98831F3A-XMR-M[1,31-33,500-501,1010-1011].akeys.mmenc'],
  701. 'E0D7 9612 3D67 404A', kafile_opts
  702. ),
  703. ],
  704. 'dash_mainnet': [
  705. (
  706. ['test/ref/dash/98831F3A-DASH-C[1,31-33,500-501,1010-1011].akeys.mmenc'],
  707. 'E83D 2C63 FEA2 4142', kafile_opts
  708. ),
  709. ],
  710. 'eth_mainnet': [
  711. (
  712. ['test/ref/ethereum/98831F3A-ETH[1,31-33,500-501,1010-1011].akeys.mmenc'],
  713. 'E400 70D9 0AE3 C7C2', kafile_opts
  714. ),
  715. ],
  716. 'etc_mainnet': [
  717. (
  718. ['test/ref/ethereum_classic/98831F3A-ETC[1,31-33,500-501,1010-1011].akeys.mmenc'],
  719. 'EF49 967D BD6C FE45', kafile_opts
  720. ),
  721. ],
  722. },
  723. 'passwdfile_chksum': {
  724. 'btc_mainnet': [
  725. (
  726. ['test/ref/98831F3A-фубар@crypto.org-b58-20[1,4,1100].pws'],
  727. 'DDD9 44B0 CA28 183F', kafile_opts
  728. ),
  729. ],
  730. },
  731. 'txview': {
  732. 'btc_mainnet': [(['test/ref/0B8D5A[15.31789,14,tl=1320969600].rawtx'], None),],
  733. 'btc_testnet': [(['test/ref/0C7115[15.86255,14,tl=1320969600].testnet.rawtx'], None),],
  734. 'bch_mainnet': [(['test/ref/460D4D-BCH[10.19764,tl=1320969600].rawtx'], None),],
  735. 'bch_testnet': [(['test/ref/359FD5-BCH[6.68868,tl=1320969600].testnet.rawtx'], None),],
  736. 'ltc_mainnet': [(['test/ref/litecoin/AF3CDF-LTC[620.76194,1453,tl=1320969600].rawtx'], None),],
  737. 'ltc_testnet': [(['test/ref/litecoin/A5A1E0-LTC[1454.64322,1453,tl=1320969600].testnet.rawtx'],
  738. None),],
  739. 'eth_mainnet': [(['test/ref/ethereum/88FEFD-ETH[23.45495,40000].rawtx'], None),],
  740. 'eth_testnet': [([
  741. 'test/ref/ethereum/76CF8C-ETH[99.99895,50000].regtest.rawtx',
  742. 'test/ref/ethereum/76CF8C-ETH[99.99895,50000].regtest.sigtx'
  743. ], None),],
  744. 'mm1_mainnet': [(['test/ref/ethereum/5881D2-MM1[1.23456,50000].rawtx'], None),],
  745. 'mm1_testnet': [(['test/ref/ethereum/6BDB25-MM1[1.23456,50000].testnet.rawtx'], None),],
  746. 'etc_mainnet': [(['test/ref/ethereum_classic/ED3848-ETC[1.2345,40000].rawtx'], None),],
  747. },
  748. },
  749. }