You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
monero-python/tests/test_seed.py

409 lines
17 KiB

import unittest
from monero.address import Address
from monero.seed import Seed
from monero.wordlists import list_wordlists
class SeedTestCase(unittest.TestCase):
def test_mnemonic_seed(self):
# Known good 25 word seed phrases should construct a class and register valid hex
seed = Seed(
"wedge going quick racetrack auburn physics lectures light waist axes whipped habitat square awkward together injury niece nugget guarded hive obnoxious waxing faked folding square"
)
self.assertEqual(
seed.hex, "8ffa9f586b86d294d93731765d192765311bddc76a4fa60311f8af36bbf6fb06"
)
# Known good 24 word seed phrases should construct a class, store phrase, and register valid hex
seed = Seed(
"wedge going quick racetrack auburn physics lectures light waist axes whipped habitat square awkward together injury niece nugget guarded hive obnoxious waxing faked folding"
)
self.assertEqual(
seed.hex, "8ffa9f586b86d294d93731765d192765311bddc76a4fa60311f8af36bbf6fb06"
)
# Known good 25 word hexadecimal strings should construct a class, store phrase, and register valid hex
seed = Seed("8ffa9f586b86d294d93731765d192765311bddc76a4fa60311f8af36bbf6fb06")
self.assertEqual(
seed.phrase,
"wedge going quick racetrack auburn physics lectures light waist axes whipped habitat square awkward together injury niece nugget guarded hive obnoxious waxing faked folding square",
)
self.assertTrue(len(seed.hex) % 8 == 0)
# Known good 13 word seed phrases should construct a class and register valid hex
seed = Seed(
"ought knowledge upright innocent eldest nerves gopher fowls below exquisite aces basin fowls"
)
self.assertEqual(seed.hex, "932d70711acc2d536ca11fcb79e05516")
# Known good 12 word seed phrases should construct a class, store phrase, and register valid hex
seed = Seed(
"ought knowledge upright innocent eldest nerves gopher fowls below exquisite aces basin"
)
self.assertEqual(seed.hex, "932d70711acc2d536ca11fcb79e05516")
# Known good 13 word hexadecimal strings should construct a class, store phrase, and register valid hex
seed = Seed("932d70711acc2d536ca11fcb79e05516")
self.assertEqual(
seed.phrase,
"ought knowledge upright innocent eldest nerves gopher fowls below exquisite aces basin fowls",
)
self.assertTrue(len(seed.hex) % 8 == 0)
# Generated seed phrases should be 25 words, register valid hex
seed = Seed()
seed_split = seed.phrase.split(" ")
self.assertTrue(len(seed_split) == 25)
self.assertTrue(len(seed.hex) % 8 == 0)
# Invalid phrases should not be allowed
with self.assertRaises(ValueError) as ts:
Seed("oh damn you thought fool")
self.assertEqual(ts.expected, ValueError)
with self.assertRaises(ValueError) as ts:
Seed("Thi5isMyS3cr3tPa55w0rd")
self.assertEqual(ts.expected, ValueError)
with self.assertRaises(ValueError) as ts:
Seed(" ")
self.assertEqual(ts.expected, ValueError)
with self.assertRaises(ValueError) as ts:
Seed("\\x008")
self.assertEqual(ts.expected, ValueError)
def test_keys(self):
seed = Seed(
"adjust mugged vaults atlas nasty mews damp toenail suddenly toxic possible "
"framed succeed fuzzy return demonstrate nucleus album noises peculiar virtual "
"rowboat inorganic jester fuzzy"
)
self.assertFalse(seed.is_mymonero())
self.assertEqual(
seed.secret_spend_key(),
"482700617ba810f94035d7f4d7ccc1a29878e165b4867872b705204c85406906",
)
self.assertEqual(
seed.secret_view_key(),
"09ed72c713d3e9e19bef2f5204cf85f6cb25de7842aa0722abeb12697f171903",
)
self.assertEqual(
seed.public_spend_key(),
"4ee576f52b9c6a824a3d5c2832d117177d2bb9992507c2c78788bb8dbaf4b640",
)
self.assertEqual(
seed.public_view_key(),
"e1ef99d66312ec0b16b17c66c591ab59594e21621588b63b62fa69fe615a768e",
)
self.assertEqual(
seed.public_address(),
"44cWztNFdAqNnycvZbUoj44vsbAEmKnx9aNgkjHdjtMsBrSeKiY8J4s2raH7EMawA2Fwo9utaRTV7Aw8EcTMNMxhH4YtKdH",
)
self.assertIsInstance(seed.public_address(), Address)
self.assertEqual(
seed.public_address(net="stage"),
"54pZ5jHDGmwNnycvZbUoj44vsbAEmKnx9aNgkjHdjtMsBrSeKiY8J4s2raH7EMawA2Fwo9utaRTV7Aw8EcTMNMxhH6cuARW",
)
self.assertIsInstance(seed.public_address(net="stage"), Address)
seed = Seed(
"dwelt idols lopped blender haggled rabbits piloted value swagger taunts toolbox upgrade swagger"
)
self.assertTrue(seed.is_mymonero())
# check if the same seed without checksum matches the hex
self.assertEqual(seed.hex, Seed(" ".join(seed.phrase.split(" ")[:12])).hex)
# the following fails, #21 addresses that
self.assertEqual(
seed.secret_spend_key(),
"a67505f92004dd6242b64acd16e34ecf788a2d28b6072091e054238d84591403",
)
self.assertEqual(
seed.secret_view_key(),
"83f652cb370948c8cbcf06839df043aa8c0d0ed36e38b3c827c4c00370af1a0f",
)
self.assertEqual(
seed.public_address(),
"47dwi1w9it69yZyTBBRD52ctQqw3B2FZx79bCEgVUKGHH2m7MjmaXrjeQfchMMkarG6AF9a36JvBWCyRaqEcUixpKLQRxdj",
)
self.assertIsInstance(seed.public_address(), Address)
def test_languages(self):
for wordlist in list_wordlists():
# Generate random seed
seed = Seed(wordlist=wordlist)
# Convert it from phrase
seed_from_phrase = Seed(seed.phrase, wordlist=wordlist)
self.assertEqual(seed.hex, seed_from_phrase.hex)
self.assertEqual(seed.phrase, seed_from_phrase.phrase)
# Convert it from hex
seed_from_hex = Seed(seed.hex, wordlist=wordlist)
self.assertEqual(seed.hex, seed_from_hex.hex)
self.assertEqual(seed.phrase, seed_from_hex.phrase)
def test_chinese_simplified(self):
seed = Seed(
"遭 牲 本 点 司 司 仲 吉 虎 只 绝 生 指 纯 伟 破 夫 惊 群 楚 祥 旋 暗 骨 伟", "Chinese (simplified)"
)
self.assertEqual(
seed.secret_spend_key(),
"2ec46011b23b0c00468946f1d9a64995bf0a89f9ee0bbf4f64058a3acd81a70e",
)
self.assertEqual(
seed.secret_view_key(),
"aa141796baa24539583306300b44a72495bb7823a0cc6ad856de6d372288d10f",
)
self.assertEqual(
seed.public_spend_key(),
"76cc3b927e70fee85a43a6141d019b53c77f46bbcd6c4dc6d814dfc271af361c",
)
self.assertEqual(
seed.public_view_key(),
"91ef3783492e173ca366a818ae7ee37f062daea909fd9ed9ca40d41e7d572dd4",
)
self.assertEqual(
seed.public_address(),
"468Dewci4TPfs7TATZ2nf4F1mKAEMp6RraG37wiSU4uT5nAbBwGz5LaB9GWHG23o6ANFJ1Q9cBYk5dRqWNNkmFN4Qx3RqBD",
)
def test_dutch(self):
seed = Seed(
"ralf tolvrij copier roon ossuarium wedstrijd splijt debbie bomtapijt occlusie oester noren hiaat scenario geshockt veeteler rotten symboliek jarig bock yoghurt plegen weert zeeblauw wedstrijd",
"Dutch",
)
self.assertEqual(
seed.secret_spend_key(),
"600d3c5022e1844dd2df02f178a074fc2e566793e99d9e1465926adcbfa9b508",
)
self.assertEqual(
seed.secret_view_key(),
"bb8984647124dafcb8682f1c257b5232bb12b96d682bfc320b4f8ce935e2d303",
)
self.assertEqual(
seed.public_spend_key(),
"df4be25f7ccaf632f1525b06fd9b0d7e9f64b21ebfb609353d643a24de16221b",
)
self.assertEqual(
seed.public_view_key(),
"2fcd275e4337152ea77ac68ec02f166a243f4917ebd53b2a381ab27b84d24065",
)
self.assertEqual(
seed.public_address(),
"4A5uCL4cXoB9XD3WjTrEwvNBQ6JRPTHaY9uVaxfWmcLy5YkE81tW7B28oc42XGzAeRJkhyHjKAxSE84aZnihjVBVCQf15mw",
)
def test_esperanto(self):
seed = Seed(
"knedi aspekti boli asbesto pterido aparta muro sandalo hufumo porcelana degeli utopia ebono lifto dutaga hundo vejno ebono higieno nikotino orkestro arlekeno insekto jaguaro hundo",
"Esperanto",
)
self.assertEqual(
seed.secret_spend_key(),
"a8e8a30d3638cc4d09d1fa9f4de12ac0096c69a77896774793627c0cc6a28703",
)
self.assertEqual(
seed.secret_view_key(),
"8b4dcbcbafaf3d195af5bd54aa386d767a8de3b45236c9842cb876212427f103",
)
self.assertEqual(
seed.public_spend_key(),
"32c8a782c05db039018caa150bef1f66621831b3cb591401381e1dfc3c3d423e",
)
self.assertEqual(
seed.public_view_key(),
"047963206a0267649657936d268824e35e59e3426c63b9f3b04788b14af1d85f",
)
self.assertEqual(
seed.public_address(),
"43YjCQcHm8TAY2kKbSMHz6J8FDZQwjPxw1Cq1vQ7SsQVBNeYEUMwGTQHppi5ffwg3df2m56DYexj2hm5uaQDtqpTBnUVzmD",
)
def test_french(self):
seed = Seed(
"sauce exprimer chasse asile larve tacler digestion muguet rondeur sept clore narrer fluor arme torse dans glace tant salon sanguin globe quiche ficher flaque clore",
"French",
)
self.assertEqual(
seed.secret_spend_key(),
"597703dd73d0da6b3996b83c3e1e2f602be4f0de453e15846171aa9076901603",
)
self.assertEqual(
seed.secret_view_key(),
"f6e448dbbeaa7682a541b3b5b7e2e8ebb614fac032f1c3dff659ca26ab430f09",
)
self.assertEqual(
seed.public_spend_key(),
"10b42e100196ef2a68eeec191a46d8dc5c83d73c0861c185e5244202cd432087",
)
self.assertEqual(
seed.public_view_key(),
"34c4c479d53b10d3e9c0a3d11432fd13611b12dc5b721c8ff3802329b7bac328",
)
self.assertEqual(
seed.public_address(),
"42FpfU7DfLi86RtY3ajKUKdrnKvXTx41WPPx6wsyp9XVPcfnrLDXxhucSphpzt3mDv4F1DMiCrfHmR5WPZq1erzn5bs4eA7",
)
def test_german(self):
seed = Seed(
"Erdgas Gesuch beeilen Chiffon Abendrot Alter Helium Salz Almweide Ampel Dichter Rotglut Dialekt Akkord Rampe Gesöff Ziege Boykott keuchen Krach Anbau Labor Esel Ferien Ampel",
"German",
)
self.assertEqual(
seed.secret_spend_key(),
"193152abe15c5e0a0ff56e3020229398769cd7c6ca5a4e30e439d6702c4f320a",
)
self.assertEqual(
seed.secret_view_key(),
"cdb967c501195827d78a791e1173d4b8826a5ae73b0885984898c84b6c9dd80c",
)
self.assertEqual(
seed.public_spend_key(),
"32eac115ca4b072c18198966c7ac9cb63b9f701a691eb52bfa18345d0fbcd90f",
)
self.assertEqual(
seed.public_view_key(),
"06a2119dfa7c48bdc03ad251026fc509bd01f3a4f7521802ca31b93cf06539ac",
)
self.assertEqual(
seed.public_address(),
"43Z2BHsCkU68NmZrxzfZuuXUtUHCXWttt8MdcnNyDMkC3WmfoFb9byqYjpeBaC4Xtx2dUUv8YPv1d1U4krZCLzyWLUFif2E",
)
def test_italian(self):
seed = Seed(
"tramonto spuntare ruota afrodite binocolo riferire moneta assalire tuta firmare malattia flagello paradiso tacere sindrome spuntare sogliola volare follia versare insulto diagnosi lapide meteo malattia",
"Italian",
)
self.assertEqual(
seed.secret_spend_key(),
"29c8d9e91c1cb59e059bddd901e011db85f8d4f00f967226ffb5e185bd10e70d",
)
self.assertEqual(
seed.secret_view_key(),
"1f224a0330ee358428fe91fa48b6986941030c34f2d1efecc4eb26ea9f838b02",
)
self.assertEqual(
seed.public_spend_key(),
"149bdad48fd1ca40e1eb3e323b676132e2cae1eedbd715ac131b97c2c749c6b4",
)
self.assertEqual(
seed.public_view_key(),
"efc1a3382c33ac58ecfdd3a71497b0d0aeef061d0af94e5c49278d653167d643",
)
self.assertEqual(
seed.public_address(),
"42QQUPDR9PoBrSc9rB5VvG9Wf7KmtjXhEVnLhGKif9rDXGK3n1e6rsVFsh62YDqDf5buVQXuL6oLHGSHg4ANgQUu8beDd9R",
)
def test_japanese(self):
seed = Seed(
"いもり すあな いきる しちょう うったえる ちひょう けなみ たいちょう うぶごえ しかい しなぎれ いっせい つかれる しなん ばあさん たいまつばな しひょう おいかける あんがい ていへん せんもん きこく せんく そそぐ つかれる",
"Japanese",
)
self.assertFalse(seed.is_mymonero())
self.assertEqual(
seed.secret_spend_key(),
"a047598095d2ada065af73758f7082900b9b0d721b5f99a541a78bd461ffc607",
)
self.assertEqual(
seed.secret_view_key(),
"080c6135edf93233176d41c8535caef0f13d596dc5093b5a5afa4279339dbc00",
)
self.assertEqual(
seed.public_spend_key(),
"85d849793fce4d0238d991d3aab7ac790cee73e5732d378c216f11bd3b873e43",
)
self.assertEqual(
seed.public_view_key(),
"19dc462a6074a26fa7788b45e542a71ffdbd48502e41ae8790c46fd6de556de3",
)
self.assertEqual(
seed.public_address(),
"46hHs9s3boi1NZJHGSwMgfMFLpCBaKwdQQSSf7fqVjWdCDxudsDmqqbKgBkpYDX6JA6MMZG8o5yrMPg9ztrXHdEkSfUA131",
)
def test_portuguese(self):
seed = Seed(
"rebuscar mefistofelico luto isca vulva ontologico autuar epiteto jarro invulneravel inquisitorial vietnamita voile potro mamute giroscopio scherzo cheroqui gueto loquaz fissurar fazer violoncelo viquingue vulva",
"Portuguese",
)
self.assertFalse(seed.is_mymonero())
self.assertEqual(
seed.secret_spend_key(),
"60916cfcb10fa0b2b0648e36ecd7037f5c1972d36b2e6d56c2f4feca613a4200",
)
self.assertEqual(
seed.secret_view_key(),
"b23941e3f4da76e0fab171d94a36fe70031fb501f1f80e0cb3b4b4638b5f7106",
)
self.assertEqual(
seed.public_spend_key(),
"340c89026a03637e8b0abda566ac99b98a7c85b30a81281be19af869c3631dfb",
)
self.assertEqual(
seed.public_view_key(),
"23bb38c5e34867c49a65f0e7192138483361d419febbd429f256088e5e62a55e",
)
self.assertEqual(
seed.public_address(),
"43bWUqKAoYWNAdMtuaSF2pY2yptw7zfCB5fV2fXLkYTvj1NNYUKM4aaZtJCVYJunHuD5SNE2CPTCo81wDhZc8bReBidbX1w",
)
def test_russian(self):
seed = Seed(
"дощатый ателье мыло паек азот ружье домашний уныние уплата торговля шкаф кекс газета тревога улица армия лазерный иголка друг хищник пашня дневник кричать лыжный иголка",
"Russian",
)
self.assertEqual(
seed.secret_spend_key(),
"6dc31f6ebcf834ab375a69006cb19c66fcccfa0732dfb3ea1b0662b455226b0d",
)
self.assertEqual(
seed.secret_view_key(),
"5467825ef0148a11582115f80b01c9af90fe31216a9cf6fb2d6b3c78698ce80a",
)
self.assertEqual(
seed.public_spend_key(),
"200657c6d14ab19cd3fccd8634e8f23e81290a559b8eb5e58dda3696553ddffc",
)
self.assertEqual(
seed.public_view_key(),
"f7563d9efb1c03a299b9c91a604caf7fd0c5a6998fdeedf18b58a63930958a24",
)
self.assertEqual(
seed.public_address(),
"42qVnaWnHSGTERsT6diSvdBTNbHfQZauSfPxpc5EuHc2jK699E28uwpUCRrHr9aaZ4NNyJ9ABdxX6hQHPHv2YcW55A26UbQ",
)
def test_spanish(self):
seed = Seed(
"riesgo lápiz martes fuerza dinero pupila pago mensaje guion libro órgano juntar imperio puñal historia pasión nación posible paso límite don afirmar receta reposo fuerza",
"Spanish",
)
self.assertFalse(seed.is_mymonero())
self.assertEqual(
seed.secret_spend_key(),
"5973d91299466a9a51ddfcd20d1710c776aa1399279b292b264ab6b7ab608105",
)
self.assertEqual(
seed.secret_view_key(),
"5f7a66cf32120515870f89e3a156ec2024154334a3b43af1da05244ec4cf250d",
)
self.assertEqual(
seed.public_spend_key(),
"42161417635c6bd31a8dce8c2bd3b5f4879369fb732073d9f6fa82b18329c7f7",
)
self.assertEqual(
seed.public_view_key(),
"6acc984fecb5894b5661d446954ffcfe302cd1d2cf0e5177c2553aafb1dc3d2a",
)
self.assertEqual(
seed.public_address(),
"448MxehQwbgcJyJ3fKnTYYhuF7g7cs7AJdTXoybMu8UEiPFtFpEVNTaDbsK5vatPHVjWwjvJfyWKiM2pBKXJrg4U5qeGXjZ",
)
if __name__ == "__main__":
unittest.main()