2018-06-21 14:28:34 +00:00
|
|
|
# This file is part of the Trezor project.
|
2017-01-03 18:40:05 +00:00
|
|
|
#
|
2018-06-21 14:28:34 +00:00
|
|
|
# Copyright (C) 2012-2018 SatoshiLabs and contributors
|
2017-01-03 18:40:05 +00:00
|
|
|
#
|
|
|
|
# This library is free software: you can redistribute it and/or modify
|
2018-06-21 14:28:34 +00:00
|
|
|
# it under the terms of the GNU Lesser General Public License version 3
|
|
|
|
# as published by the Free Software Foundation.
|
2017-01-03 18:40:05 +00:00
|
|
|
#
|
|
|
|
# This library is distributed in the hope that it will be useful,
|
|
|
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
# GNU Lesser General Public License for more details.
|
|
|
|
#
|
2018-06-21 14:28:34 +00:00
|
|
|
# You should have received a copy of the License along with this library.
|
|
|
|
# If not, see <https://www.gnu.org/licenses/lgpl-3.0.html>.
|
2017-01-03 18:40:05 +00:00
|
|
|
|
2018-04-18 12:00:11 +00:00
|
|
|
import pytest
|
|
|
|
|
|
|
|
from .common import TrezorTest
|
|
|
|
from ..support import ckd_public as bip32
|
2017-12-12 15:40:11 +00:00
|
|
|
from trezorlib import messages as proto
|
2013-01-17 12:37:48 +00:00
|
|
|
|
2018-06-14 12:57:20 +00:00
|
|
|
from trezorlib.tools import parse_path, H_
|
2018-08-10 12:04:58 +00:00
|
|
|
from trezorlib import btc
|
2018-04-18 13:53:40 +00:00
|
|
|
|
2017-06-23 19:31:42 +00:00
|
|
|
|
2017-12-23 20:20:49 +00:00
|
|
|
class TestMsgGetaddress(TrezorTest):
|
2013-01-17 12:37:48 +00:00
|
|
|
|
2014-02-17 00:54:54 +00:00
|
|
|
def test_btc(self):
|
|
|
|
self.setup_mnemonic_nopin_nopassphrase()
|
2018-08-10 12:04:58 +00:00
|
|
|
assert btc.get_address(self.client, 'Bitcoin', []) == '1EfKbQupktEMXf4gujJ9kCFo83k1iMqwqK'
|
|
|
|
assert btc.get_address(self.client, 'Bitcoin', [1]) == '1CK7SJdcb8z9HuvVft3D91HLpLC6KSsGb'
|
|
|
|
assert btc.get_address(self.client, 'Bitcoin', [0, H_(1)]) == '1JVq66pzRBvqaBRFeU9SPVvg3er4ZDgoMs'
|
|
|
|
assert btc.get_address(self.client, 'Bitcoin', [H_(9), 0]) == '1F4YdQdL9ZQwvcNTuy5mjyQxXkyCfMcP2P'
|
|
|
|
assert btc.get_address(self.client, 'Bitcoin', [0, 9999999]) == '1GS8X3yc7ntzwGw9vXwj9wqmBWZkTFewBV'
|
2013-01-17 12:37:48 +00:00
|
|
|
|
2013-09-13 03:27:21 +00:00
|
|
|
def test_ltc(self):
|
2014-02-17 00:54:54 +00:00
|
|
|
self.setup_mnemonic_nopin_nopassphrase()
|
2018-08-10 12:04:58 +00:00
|
|
|
assert btc.get_address(self.client, 'Litecoin', []) == 'LYtGrdDeqYUQnTkr5sHT2DKZLG7Hqg7HTK'
|
|
|
|
assert btc.get_address(self.client, 'Litecoin', [1]) == 'LKRGNecThFP3Q6c5fosLVA53Z2hUDb1qnE'
|
|
|
|
assert btc.get_address(self.client, 'Litecoin', [0, H_(1)]) == 'LcinMK8pVrAtpz7Qpc8jfWzSFsDLgLYfG6'
|
|
|
|
assert btc.get_address(self.client, 'Litecoin', [H_(9), 0]) == 'LZHVtcwAEDf1BR4d67551zUijyLUpDF9EX'
|
|
|
|
assert btc.get_address(self.client, 'Litecoin', [0, 9999999]) == 'Laf5nGHSCT94C5dK6fw2RxuXPiw2ZuRR9S'
|
2013-01-17 12:37:48 +00:00
|
|
|
|
2013-09-13 03:27:21 +00:00
|
|
|
def test_tbtc(self):
|
2014-02-17 00:54:54 +00:00
|
|
|
self.setup_mnemonic_nopin_nopassphrase()
|
2018-08-10 12:04:58 +00:00
|
|
|
assert btc.get_address(self.client, 'Testnet', [111, 42]) == 'moN6aN6NP1KWgnPSqzrrRPvx2x1UtZJssa'
|
2014-01-14 13:29:18 +00:00
|
|
|
|
2017-08-12 19:10:12 +00:00
|
|
|
def test_bch(self):
|
|
|
|
self.setup_mnemonic_allallall()
|
2018-08-10 12:04:58 +00:00
|
|
|
assert btc.get_address(self.client, 'Bcash', parse_path("44'/145'/0'/0/0")) == 'bitcoincash:qr08q88p9etk89wgv05nwlrkm4l0urz4cyl36hh9sv'
|
|
|
|
assert btc.get_address(self.client, 'Bcash', parse_path("44'/145'/0'/0/1")) == 'bitcoincash:qr23ajjfd9wd73l87j642puf8cad20lfmqdgwvpat4'
|
|
|
|
assert btc.get_address(self.client, 'Bcash', parse_path("44'/145'/0'/1/0")) == 'bitcoincash:qzc5q87w069lzg7g3gzx0c8dz83mn7l02scej5aluw'
|
2017-08-12 19:10:12 +00:00
|
|
|
|
|
|
|
def test_bch_multisig(self):
|
|
|
|
self.setup_mnemonic_allallall()
|
2017-08-13 16:01:43 +00:00
|
|
|
xpubs = []
|
2018-08-10 12:04:58 +00:00
|
|
|
for n in map(lambda index: btc.get_public_node(self.client, parse_path("44'/145'/" + str(index) + "'")), range(1, 4)):
|
2017-08-12 19:10:12 +00:00
|
|
|
xpubs.append(n.xpub)
|
|
|
|
|
2017-08-13 16:01:43 +00:00
|
|
|
def getmultisig(chain, nr, signatures=[b'', b'', b''], xpubs=xpubs):
|
2017-12-12 15:40:11 +00:00
|
|
|
return proto.MultisigRedeemScriptType(
|
|
|
|
pubkeys=list(map(lambda xpub: proto.HDNodePathType(node=bip32.deserialize(xpub), address_n=[chain, nr]), xpubs)),
|
2017-08-12 19:10:12 +00:00
|
|
|
signatures=signatures,
|
|
|
|
m=2,
|
|
|
|
)
|
2017-08-13 16:01:43 +00:00
|
|
|
for nr in range(1, 4):
|
2018-08-10 12:04:58 +00:00
|
|
|
assert btc.get_address(self.client, 'Bcash', parse_path("44'/145'/" + str(nr) + "'/0/0"), show_display=(nr == 1), multisig=getmultisig(0, 0)) == 'bitcoincash:pqguz4nqq64jhr5v3kvpq4dsjrkda75hwy86gq0qzw'
|
|
|
|
assert btc.get_address(self.client, 'Bcash', parse_path("44'/145'/" + str(nr) + "'/1/0"), show_display=(nr == 1), multisig=getmultisig(1, 0)) == 'bitcoincash:pp6kcpkhua7789g2vyj0qfkcux3yvje7euhyhltn0a'
|
2017-08-12 19:10:12 +00:00
|
|
|
|
2014-01-14 13:29:18 +00:00
|
|
|
def test_public_ckd(self):
|
2014-02-17 00:54:54 +00:00
|
|
|
self.setup_mnemonic_nopin_nopassphrase()
|
2014-01-14 13:29:18 +00:00
|
|
|
|
2018-08-10 12:04:58 +00:00
|
|
|
node = btc.get_public_node(self.client, []).node
|
|
|
|
node_sub1 = btc.get_public_node(self.client, [1]).node
|
2014-01-14 13:29:18 +00:00
|
|
|
node_sub2 = bip32.public_ckd(node, [1])
|
|
|
|
|
2017-12-23 20:20:49 +00:00
|
|
|
assert node_sub1.chain_code == node_sub2.chain_code
|
|
|
|
assert node_sub1.public_key == node_sub2.public_key
|
2014-01-14 13:29:18 +00:00
|
|
|
|
2018-08-10 12:04:58 +00:00
|
|
|
address1 = btc.get_address(self.client, 'Bitcoin', [1])
|
2014-01-14 13:29:18 +00:00
|
|
|
address2 = bip32.get_address(node_sub2, 0)
|
|
|
|
|
2017-12-23 20:20:49 +00:00
|
|
|
assert address2 == '1CK7SJdcb8z9HuvVft3D91HLpLC6KSsGb'
|
|
|
|
assert address1 == address2
|