1
0
mirror of https://github.com/trezor/trezor-firmware.git synced 2025-01-10 07:20:56 +00:00

device_tests: use original ethereum message digest, enable ethereum_{sign,verify}message for T2

This commit is contained in:
Pavol Rusnak 2018-05-25 14:23:16 +02:00
parent f273bbb736
commit 648ef511b6
No known key found for this signature in database
GPG Key ID: 91F3B339B9A02A3D
2 changed files with 24 additions and 26 deletions

View File

@ -19,17 +19,18 @@ from .common import *
@pytest.mark.ethereum
@pytest.mark.skip_t2
class TestMsgEthereumSignmessage(TrezorTest):
PATH = [0]
ADDRESS = b'cb3864960e8db1a751212c580af27ee8867d688f'
VECTORS = [
('This is an example of a signed message.', b'b7837058907192dbc9427bf57d93a0acca3816c92927a08be573b785f2d72dab65dad9c92fbe03a358acdb455eab2107b869945d11f4e353d9cc6ea957d08a871b'),
('VeryLongMessage!' * 64, b'da2b73b0170479c2bfba3dd4839bf0d67732a44df8c873f3f3a2aca8a57d7bdc0b5d534f54c649e2d44135717001998b176d3cd1212366464db51f5838430fb31c'),
]
def test_sign(self):
self.setup_mnemonic_nopin_nopassphrase()
sig = self.client.ethereum_sign_message([0], 'This is an example of a signed message.')
assert hexlify(sig.address) == b'cb3864960e8db1a751212c580af27ee8867d688f'
assert hexlify(sig.signature) == b'95b64a7b3aa492f0cc1668a24097004562cc2b4f0e755e3c0d60dd791b9f9e285f95b618258ff97036b8419d0a0dd1af3751c625b4d248ee6deff84eba21b8ee1c'
def test_sign_long(self):
self.setup_mnemonic_nopin_nopassphrase()
sig = self.client.ethereum_sign_message([0], 'VeryLongMessage!' * 64)
assert hexlify(sig.address) == b'cb3864960e8db1a751212c580af27ee8867d688f'
assert hexlify(sig.signature) == b'70d03c8447b64489e80ae44ce4f1a543e8eb5dd9e9a19c4743ce95fbd9b8234b2d2a16db87cee857f5b474107ad2c0c0c86118f8a33d5df3d98b766be92d71331b'
for msg, sig in self.VECTORS:
res = self.client.ethereum_sign_message(self.PATH, msg)
assert hexlify(res.address) == self.ADDRESS
assert hexlify(res.signature) == sig

View File

@ -19,23 +19,20 @@ from .common import *
@pytest.mark.ethereum
@pytest.mark.skip_t2
class TestMsgEthereumVerifymessage(TrezorTest):
ADDRESS = b'cb3864960e8db1a751212c580af27ee8867d688f'
VECTORS = [
('This is an example of a signed message.', b'b7837058907192dbc9427bf57d93a0acca3816c92927a08be573b785f2d72dab65dad9c92fbe03a358acdb455eab2107b869945d11f4e353d9cc6ea957d08a871b'),
('VeryLongMessage!' * 64, b'da2b73b0170479c2bfba3dd4839bf0d67732a44df8c873f3f3a2aca8a57d7bdc0b5d534f54c649e2d44135717001998b176d3cd1212366464db51f5838430fb31c'),
]
def test_verify(self):
self.setup_mnemonic_nopin_nopassphrase()
for msg, sig in self.VECTORS:
res = self.client.ethereum_verify_message(
unhexlify('cb3864960e8db1a751212c580af27ee8867d688f'),
unhexlify('95b64a7b3aa492f0cc1668a24097004562cc2b4f0e755e3c0d60dd791b9f9e285f95b618258ff97036b8419d0a0dd1af3751c625b4d248ee6deff84eba21b8ee1c'),
'This is an example of a signed message.'
unhexlify(self.ADDRESS),
unhexlify(sig),
msg
)
assert res is True
def test_verify_long(self):
self.setup_mnemonic_nopin_nopassphrase()
ret = self.client.ethereum_verify_message(
unhexlify('cb3864960e8db1a751212c580af27ee8867d688f'),
unhexlify('70d03c8447b64489e80ae44ce4f1a543e8eb5dd9e9a19c4743ce95fbd9b8234b2d2a16db87cee857f5b474107ad2c0c0c86118f8a33d5df3d98b766be92d71331b'),
'VeryLongMessage!' * 64
)
assert ret is True