import unittest from lib import keystore from lib import mnemonic from lib import old_mnemonic from lib.util import bh2u from . import SequentialTestCase class Test_NewMnemonic(SequentialTestCase): def test_to_seed(self): seed = mnemonic.Mnemonic.mnemonic_to_seed(mnemonic='foobar', passphrase='none') self.assertEqual(bh2u(seed), '741b72fd15effece6bfe5a26a52184f66811bd2be363190e07a42cca442b1a5b' 'b22b3ad0eb338197287e6d314866c7fba863ac65d3f156087a5052ebc7157fce') def test_random_seeds(self): iters = 10 m = mnemonic.Mnemonic(lang='en') for _ in range(iters): seed = m.make_seed() i = m.mnemonic_decode(seed) self.assertEqual(m.mnemonic_encode(i), seed) class Test_OldMnemonic(SequentialTestCase): def test(self): seed = '8edad31a95e7d59f8837667510d75a4d' result = old_mnemonic.mn_encode(seed) words = 'hardly point goal hallway patience key stone difference ready caught listen fact' self.assertEqual(result, words.split()) self.assertEqual(old_mnemonic.mn_decode(result), seed) class Test_BIP39Checksum(SequentialTestCase): def test(self): mnemonic = u'gravity machine north sort system female filter attitude volume fold club stay feature office ecology stable narrow fog' is_checksum_valid, is_wordlist_valid = keystore.bip39_is_checksum_valid(mnemonic) self.assertTrue(is_wordlist_valid) self.assertTrue(is_checksum_valid)