mirror of
https://github.com/trezor/trezor-firmware.git
synced 2025-01-11 16:00:57 +00:00
fix(tests): auto-swipe by using only ButtonRequest.pages
This commit is contained in:
parent
1e1963f1ee
commit
f8bb90366a
@ -56,7 +56,7 @@ if __debug__:
|
|||||||
|
|
||||||
def notify_layout_change(layout: Layout) -> None:
|
def notify_layout_change(layout: Layout) -> None:
|
||||||
storage.current_content[:] = layout.read_content()
|
storage.current_content[:] = layout.read_content()
|
||||||
if storage.watch_layout_changes:
|
if storage.watch_layout_changes or layout_change_chan.takers:
|
||||||
layout_change_chan.publish(storage.current_content)
|
layout_change_chan.publish(storage.current_content)
|
||||||
|
|
||||||
async def dispatch_debuglink_decision(msg: DebugLinkDecision) -> None:
|
async def dispatch_debuglink_decision(msg: DebugLinkDecision) -> None:
|
||||||
|
@ -158,8 +158,8 @@ class DebugLink:
|
|||||||
def press_no(self):
|
def press_no(self):
|
||||||
self.input(button=False)
|
self.input(button=False)
|
||||||
|
|
||||||
def swipe_up(self):
|
def swipe_up(self, wait=False):
|
||||||
self.input(swipe=messages.DebugSwipeDirection.UP)
|
self.input(swipe=messages.DebugSwipeDirection.UP, wait=wait)
|
||||||
|
|
||||||
def swipe_down(self):
|
def swipe_down(self):
|
||||||
self.input(swipe=messages.DebugSwipeDirection.DOWN)
|
self.input(swipe=messages.DebugSwipeDirection.DOWN)
|
||||||
@ -234,13 +234,10 @@ class DebugUI:
|
|||||||
if self.input_flow is None:
|
if self.input_flow is None:
|
||||||
if br.code == messages.ButtonRequestType.PinEntry:
|
if br.code == messages.ButtonRequestType.PinEntry:
|
||||||
self.debuglink.input(self.get_pin())
|
self.debuglink.input(self.get_pin())
|
||||||
elif (
|
|
||||||
br.pages is not None
|
|
||||||
and br.page_number is not None
|
|
||||||
and br.pages > br.page_number
|
|
||||||
):
|
|
||||||
self.debuglink.swipe_up()
|
|
||||||
else:
|
else:
|
||||||
|
if br.pages is not None:
|
||||||
|
for _ in range(br.pages - 1):
|
||||||
|
self.debuglink.swipe_up(wait=True)
|
||||||
self.debuglink.press_yes()
|
self.debuglink.press_yes()
|
||||||
elif self.input_flow is self.INPUT_FLOW_DONE:
|
elif self.input_flow is self.INPUT_FLOW_DONE:
|
||||||
raise AssertionError("input flow ended prematurely")
|
raise AssertionError("input flow ended prematurely")
|
||||||
|
@ -20,7 +20,7 @@ from pathlib import Path
|
|||||||
import pytest
|
import pytest
|
||||||
|
|
||||||
from trezorlib import btc, tools
|
from trezorlib import btc, tools
|
||||||
from trezorlib.messages import ButtonRequest, ButtonRequestType as B
|
from trezorlib.messages import ButtonRequestType as B
|
||||||
|
|
||||||
# fmt: off
|
# fmt: off
|
||||||
# 1 2 3 4 5 6 7 8 9 10 11 12
|
# 1 2 3 4 5 6 7 8 9 10 11 12
|
||||||
@ -188,15 +188,14 @@ def read_and_confirm_mnemonic(debug, choose_wrong=False):
|
|||||||
mnemonic = yield from read_and_confirm_mnemonic(client.debug)
|
mnemonic = yield from read_and_confirm_mnemonic(client.debug)
|
||||||
"""
|
"""
|
||||||
mnemonic = []
|
mnemonic = []
|
||||||
while True:
|
br = yield
|
||||||
br = yield
|
for _ in range(br.pages - 1):
|
||||||
mnemonic.extend(debug.read_reset_word().split())
|
mnemonic.extend(debug.read_reset_word().split())
|
||||||
if br.page_number < br.pages:
|
debug.swipe_up(wait=True)
|
||||||
debug.swipe_up()
|
|
||||||
else:
|
# last page is confirmation
|
||||||
# last page is confirmation
|
mnemonic.extend(debug.read_reset_word().split())
|
||||||
debug.press_yes()
|
debug.press_yes()
|
||||||
break
|
|
||||||
|
|
||||||
# check share
|
# check share
|
||||||
for _ in range(3):
|
for _ in range(3):
|
||||||
@ -210,15 +209,6 @@ def read_and_confirm_mnemonic(debug, choose_wrong=False):
|
|||||||
return " ".join(mnemonic)
|
return " ".join(mnemonic)
|
||||||
|
|
||||||
|
|
||||||
def paging_responses(pages, code=None):
|
|
||||||
"""Generate a sequence of ButtonRequests for paging through a specified number
|
|
||||||
of screens.
|
|
||||||
"""
|
|
||||||
return [
|
|
||||||
ButtonRequest(code=code, page_number=i + 1, pages=pages) for i in range(pages)
|
|
||||||
]
|
|
||||||
|
|
||||||
|
|
||||||
def get_test_address(client):
|
def get_test_address(client):
|
||||||
"""Fetch a testnet address on a fixed path. Useful to make a pin/passphrase
|
"""Fetch a testnet address on a fixed path. Useful to make a pin/passphrase
|
||||||
protected call, or to identify the root secret (seed+passphrase)"""
|
protected call, or to identify the root secret (seed+passphrase)"""
|
||||||
|
@ -102,13 +102,8 @@ def test_cardano_sign_tx_with_multiple_chunks(client, parameters, result):
|
|||||||
|
|
||||||
expected_responses = [
|
expected_responses = [
|
||||||
messages.PassphraseRequest(),
|
messages.PassphraseRequest(),
|
||||||
# XXX as many ButtonRequests as paginations. We are relying on the fact that
|
messages.ButtonRequest(),
|
||||||
# there is only one fixture whose pagination is known.
|
messages.ButtonRequest(),
|
||||||
# If that changes, we'll need to figure out something else.
|
|
||||||
messages.ButtonRequest(page_number=1),
|
|
||||||
messages.ButtonRequest(page_number=2),
|
|
||||||
messages.ButtonRequest(page_number=1),
|
|
||||||
messages.ButtonRequest(page_number=2),
|
|
||||||
]
|
]
|
||||||
expected_responses += [
|
expected_responses += [
|
||||||
messages.CardanoSignedTxChunk(signed_tx_chunk=bytes.fromhex(signed_tx_chunk))
|
messages.CardanoSignedTxChunk(signed_tx_chunk=bytes.fromhex(signed_tx_chunk))
|
||||||
|
@ -27,7 +27,6 @@ from ..common import (
|
|||||||
MNEMONIC_SLIP39_ADVANCED_20,
|
MNEMONIC_SLIP39_ADVANCED_20,
|
||||||
MNEMONIC_SLIP39_BASIC_20_3of6,
|
MNEMONIC_SLIP39_BASIC_20_3of6,
|
||||||
click_through,
|
click_through,
|
||||||
paging_responses,
|
|
||||||
read_and_confirm_mnemonic,
|
read_and_confirm_mnemonic,
|
||||||
)
|
)
|
||||||
|
|
||||||
@ -37,8 +36,6 @@ from ..common import (
|
|||||||
def test_backup_bip39(client):
|
def test_backup_bip39(client):
|
||||||
assert client.features.needs_backup is True
|
assert client.features.needs_backup is True
|
||||||
mnemonic = None
|
mnemonic = None
|
||||||
words = 12
|
|
||||||
mnemonic_pages = ((words + 3) // 4) + 1
|
|
||||||
|
|
||||||
def input_flow():
|
def input_flow():
|
||||||
nonlocal mnemonic
|
nonlocal mnemonic
|
||||||
@ -56,9 +53,7 @@ def test_backup_bip39(client):
|
|||||||
client.set_expected_responses(
|
client.set_expected_responses(
|
||||||
[
|
[
|
||||||
messages.ButtonRequest(code=B.ResetDevice),
|
messages.ButtonRequest(code=B.ResetDevice),
|
||||||
]
|
messages.ButtonRequest(code=B.ResetDevice),
|
||||||
+ paging_responses(mnemonic_pages, code=B.ResetDevice)
|
|
||||||
+ [
|
|
||||||
messages.ButtonRequest(code=B.Success),
|
messages.ButtonRequest(code=B.Success),
|
||||||
messages.ButtonRequest(code=B.Success),
|
messages.ButtonRequest(code=B.Success),
|
||||||
messages.Success,
|
messages.Success,
|
||||||
@ -81,8 +76,6 @@ def test_backup_bip39(client):
|
|||||||
def test_backup_slip39_basic(client):
|
def test_backup_slip39_basic(client):
|
||||||
assert client.features.needs_backup is True
|
assert client.features.needs_backup is True
|
||||||
mnemonics = []
|
mnemonics = []
|
||||||
words = 20
|
|
||||||
mnemonic_pages = ((words + 3) // 4) + 1
|
|
||||||
|
|
||||||
def input_flow():
|
def input_flow():
|
||||||
# 1. Checklist
|
# 1. Checklist
|
||||||
@ -110,7 +103,7 @@ def test_backup_slip39_basic(client):
|
|||||||
client.set_expected_responses(
|
client.set_expected_responses(
|
||||||
[messages.ButtonRequest(code=B.ResetDevice)] * 6 # intro screens
|
[messages.ButtonRequest(code=B.ResetDevice)] * 6 # intro screens
|
||||||
+ [
|
+ [
|
||||||
*paging_responses(mnemonic_pages, code=B.ResetDevice),
|
messages.ButtonRequest(code=B.ResetDevice),
|
||||||
messages.ButtonRequest(code=B.Success),
|
messages.ButtonRequest(code=B.Success),
|
||||||
]
|
]
|
||||||
* 5 # individual shares
|
* 5 # individual shares
|
||||||
@ -139,8 +132,6 @@ def test_backup_slip39_basic(client):
|
|||||||
def test_backup_slip39_advanced(client):
|
def test_backup_slip39_advanced(client):
|
||||||
assert client.features.needs_backup is True
|
assert client.features.needs_backup is True
|
||||||
mnemonics = []
|
mnemonics = []
|
||||||
words = 20
|
|
||||||
mnemonic_pages = ((words + 3) // 4) + 1
|
|
||||||
|
|
||||||
def input_flow():
|
def input_flow():
|
||||||
# 1. Checklist
|
# 1. Checklist
|
||||||
@ -177,7 +168,7 @@ def test_backup_slip39_advanced(client):
|
|||||||
]
|
]
|
||||||
* 5 # group thresholds
|
* 5 # group thresholds
|
||||||
+ [
|
+ [
|
||||||
*paging_responses(mnemonic_pages, code=B.ResetDevice),
|
messages.ButtonRequest(code=B.ResetDevice),
|
||||||
messages.ButtonRequest(code=B.Success),
|
messages.ButtonRequest(code=B.Success),
|
||||||
]
|
]
|
||||||
* 25 # individual shares
|
* 25 # individual shares
|
||||||
|
@ -190,7 +190,7 @@ def test_show_multisig_xpubs(
|
|||||||
lines1 = client.debug.wait_layout().lines
|
lines1 = client.debug.wait_layout().lines
|
||||||
assert lines1[0] == "XPUB #1 " + ("(yours)" if i == 0 else "(cosigner)")
|
assert lines1[0] == "XPUB #1 " + ("(yours)" if i == 0 else "(cosigner)")
|
||||||
client.debug.swipe_up()
|
client.debug.swipe_up()
|
||||||
yield
|
|
||||||
lines2 = client.debug.wait_layout().lines
|
lines2 = client.debug.wait_layout().lines
|
||||||
assert lines2[0] == "XPUB #1 " + ("(yours)" if i == 0 else "(cosigner)")
|
assert lines2[0] == "XPUB #1 " + ("(yours)" if i == 0 else "(cosigner)")
|
||||||
assert "".join(lines1[1:] + lines2[1:]) == xpubs[0]
|
assert "".join(lines1[1:] + lines2[1:]) == xpubs[0]
|
||||||
@ -200,7 +200,7 @@ def test_show_multisig_xpubs(
|
|||||||
lines1 = client.debug.wait_layout().lines
|
lines1 = client.debug.wait_layout().lines
|
||||||
assert lines1[0] == "XPUB #2 " + ("(yours)" if i == 1 else "(cosigner)")
|
assert lines1[0] == "XPUB #2 " + ("(yours)" if i == 1 else "(cosigner)")
|
||||||
client.debug.swipe_up()
|
client.debug.swipe_up()
|
||||||
yield
|
|
||||||
lines2 = client.debug.wait_layout().lines
|
lines2 = client.debug.wait_layout().lines
|
||||||
assert lines2[0] == "XPUB #2 " + ("(yours)" if i == 1 else "(cosigner)")
|
assert lines2[0] == "XPUB #2 " + ("(yours)" if i == 1 else "(cosigner)")
|
||||||
assert "".join(lines1[1:] + lines2[1:]) == xpubs[1]
|
assert "".join(lines1[1:] + lines2[1:]) == xpubs[1]
|
||||||
@ -210,7 +210,7 @@ def test_show_multisig_xpubs(
|
|||||||
lines1 = client.debug.wait_layout().lines
|
lines1 = client.debug.wait_layout().lines
|
||||||
assert lines1[0] == "XPUB #3 " + ("(yours)" if i == 2 else "(cosigner)")
|
assert lines1[0] == "XPUB #3 " + ("(yours)" if i == 2 else "(cosigner)")
|
||||||
client.debug.swipe_up()
|
client.debug.swipe_up()
|
||||||
yield
|
|
||||||
lines2 = client.debug.wait_layout().lines
|
lines2 = client.debug.wait_layout().lines
|
||||||
assert lines2[0] == "XPUB #3 " + ("(yours)" if i == 2 else "(cosigner)")
|
assert lines2[0] == "XPUB #3 " + ("(yours)" if i == 2 else "(cosigner)")
|
||||||
assert "".join(lines1[1:] + lines2[1:]) == xpubs[2]
|
assert "".join(lines1[1:] + lines2[1:]) == xpubs[2]
|
||||||
|
@ -27,7 +27,6 @@ from ..common import (
|
|||||||
MNEMONIC12,
|
MNEMONIC12,
|
||||||
click_through,
|
click_through,
|
||||||
generate_entropy,
|
generate_entropy,
|
||||||
paging_responses,
|
|
||||||
read_and_confirm_mnemonic,
|
read_and_confirm_mnemonic,
|
||||||
)
|
)
|
||||||
|
|
||||||
@ -35,8 +34,6 @@ EXTERNAL_ENTROPY = b"zlutoucky kun upel divoke ody" * 2
|
|||||||
|
|
||||||
|
|
||||||
def reset_device(client, strength):
|
def reset_device(client, strength):
|
||||||
words = strength // 32 * 3
|
|
||||||
mnemonic_pages = ((words + 3) // 4) + 1
|
|
||||||
mnemonic = None
|
mnemonic = None
|
||||||
|
|
||||||
def input_flow():
|
def input_flow():
|
||||||
@ -67,9 +64,7 @@ def reset_device(client, strength):
|
|||||||
proto.EntropyRequest(),
|
proto.EntropyRequest(),
|
||||||
proto.ButtonRequest(code=B.ResetDevice),
|
proto.ButtonRequest(code=B.ResetDevice),
|
||||||
proto.ButtonRequest(code=B.ResetDevice),
|
proto.ButtonRequest(code=B.ResetDevice),
|
||||||
]
|
proto.ButtonRequest(code=B.ResetDevice),
|
||||||
+ paging_responses(mnemonic_pages, code=B.ResetDevice)
|
|
||||||
+ [
|
|
||||||
proto.ButtonRequest(code=B.Success),
|
proto.ButtonRequest(code=B.Success),
|
||||||
proto.ButtonRequest(code=B.Success),
|
proto.ButtonRequest(code=B.Success),
|
||||||
proto.Success,
|
proto.Success,
|
||||||
@ -124,8 +119,6 @@ class TestMsgResetDeviceT2:
|
|||||||
def test_reset_device_pin(self, client):
|
def test_reset_device_pin(self, client):
|
||||||
mnemonic = None
|
mnemonic = None
|
||||||
strength = 256 # 24 words
|
strength = 256 # 24 words
|
||||||
words = strength // 32 * 3
|
|
||||||
mnemonic_pages = (words // 4) + 1
|
|
||||||
|
|
||||||
def input_flow():
|
def input_flow():
|
||||||
nonlocal mnemonic
|
nonlocal mnemonic
|
||||||
@ -182,9 +175,7 @@ class TestMsgResetDeviceT2:
|
|||||||
proto.EntropyRequest(),
|
proto.EntropyRequest(),
|
||||||
proto.ButtonRequest(code=B.ResetDevice),
|
proto.ButtonRequest(code=B.ResetDevice),
|
||||||
proto.ButtonRequest(code=B.ResetDevice),
|
proto.ButtonRequest(code=B.ResetDevice),
|
||||||
]
|
proto.ButtonRequest(code=B.ResetDevice),
|
||||||
+ paging_responses(mnemonic_pages, code=B.ResetDevice)
|
|
||||||
+ [
|
|
||||||
proto.ButtonRequest(code=B.Success),
|
proto.ButtonRequest(code=B.Success),
|
||||||
proto.ButtonRequest(code=B.Success),
|
proto.ButtonRequest(code=B.Success),
|
||||||
proto.Success,
|
proto.Success,
|
||||||
@ -223,8 +214,6 @@ class TestMsgResetDeviceT2:
|
|||||||
def test_reset_failed_check(self, client):
|
def test_reset_failed_check(self, client):
|
||||||
mnemonic = None
|
mnemonic = None
|
||||||
strength = 256 # 24 words
|
strength = 256 # 24 words
|
||||||
words = strength // 32 * 3
|
|
||||||
mnemonic_pages = (words // 4) + 1
|
|
||||||
|
|
||||||
def input_flow():
|
def input_flow():
|
||||||
nonlocal mnemonic
|
nonlocal mnemonic
|
||||||
@ -264,11 +253,9 @@ class TestMsgResetDeviceT2:
|
|||||||
proto.EntropyRequest(),
|
proto.EntropyRequest(),
|
||||||
proto.ButtonRequest(code=B.ResetDevice),
|
proto.ButtonRequest(code=B.ResetDevice),
|
||||||
proto.ButtonRequest(code=B.ResetDevice),
|
proto.ButtonRequest(code=B.ResetDevice),
|
||||||
]
|
proto.ButtonRequest(code=B.ResetDevice),
|
||||||
+ paging_responses(mnemonic_pages, code=B.ResetDevice)
|
proto.ButtonRequest(code=B.ResetDevice),
|
||||||
+ [proto.ButtonRequest(code=B.ResetDevice)]
|
proto.ButtonRequest(code=B.ResetDevice),
|
||||||
+ paging_responses(mnemonic_pages, code=B.ResetDevice)
|
|
||||||
+ [
|
|
||||||
proto.ButtonRequest(code=B.Success),
|
proto.ButtonRequest(code=B.Success),
|
||||||
proto.ButtonRequest(code=B.Success),
|
proto.ButtonRequest(code=B.Success),
|
||||||
proto.Success,
|
proto.Success,
|
||||||
|
@ -23,12 +23,7 @@ from trezorlib import device, messages as proto
|
|||||||
from trezorlib.exceptions import TrezorFailure
|
from trezorlib.exceptions import TrezorFailure
|
||||||
from trezorlib.messages import BackupType, ButtonRequestType as B
|
from trezorlib.messages import BackupType, ButtonRequestType as B
|
||||||
|
|
||||||
from ..common import (
|
from ..common import click_through, generate_entropy, read_and_confirm_mnemonic
|
||||||
click_through,
|
|
||||||
generate_entropy,
|
|
||||||
paging_responses,
|
|
||||||
read_and_confirm_mnemonic,
|
|
||||||
)
|
|
||||||
|
|
||||||
EXTERNAL_ENTROPY = b"zlutoucky kun upel divoke ody" * 2
|
EXTERNAL_ENTROPY = b"zlutoucky kun upel divoke ody" * 2
|
||||||
|
|
||||||
@ -39,8 +34,6 @@ class TestMsgResetDeviceT2:
|
|||||||
@pytest.mark.setup_client(uninitialized=True)
|
@pytest.mark.setup_client(uninitialized=True)
|
||||||
def test_reset_device_slip39_advanced(self, client):
|
def test_reset_device_slip39_advanced(self, client):
|
||||||
strength = 128
|
strength = 128
|
||||||
word_count = 20
|
|
||||||
mnemonic_page_count = (word_count // 4) + 1
|
|
||||||
member_threshold = 3
|
member_threshold = 3
|
||||||
all_mnemonics = []
|
all_mnemonics = []
|
||||||
|
|
||||||
@ -101,7 +94,7 @@ class TestMsgResetDeviceT2:
|
|||||||
]
|
]
|
||||||
+ [
|
+ [
|
||||||
# individual mnemonic
|
# individual mnemonic
|
||||||
*paging_responses(mnemonic_page_count, code=B.ResetDevice),
|
proto.ButtonRequest(code=B.ResetDevice),
|
||||||
proto.ButtonRequest(code=B.Success),
|
proto.ButtonRequest(code=B.Success),
|
||||||
]
|
]
|
||||||
* (5 * 5) # groups * shares
|
* (5 * 5) # groups * shares
|
||||||
|
@ -28,16 +28,11 @@ from ..common import (
|
|||||||
EXTERNAL_ENTROPY,
|
EXTERNAL_ENTROPY,
|
||||||
click_through,
|
click_through,
|
||||||
generate_entropy,
|
generate_entropy,
|
||||||
paging_responses,
|
|
||||||
read_and_confirm_mnemonic,
|
read_and_confirm_mnemonic,
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
||||||
def reset_device(client, strength):
|
def reset_device(client, strength):
|
||||||
# per SLIP-39: strength in bits, rounded up to nearest multiple of 10, plus 70 bits
|
|
||||||
# of metadata, split into 10-bit words
|
|
||||||
word_count = ((strength + 9) // 10) + 7
|
|
||||||
mnemonic_pages = ((word_count + 3) // 4) + 1
|
|
||||||
member_threshold = 3
|
member_threshold = 3
|
||||||
all_mnemonics = []
|
all_mnemonics = []
|
||||||
|
|
||||||
@ -84,7 +79,7 @@ def reset_device(client, strength):
|
|||||||
]
|
]
|
||||||
+ [
|
+ [
|
||||||
# individual mnemonic
|
# individual mnemonic
|
||||||
*paging_responses(mnemonic_pages, code=B.ResetDevice),
|
proto.ButtonRequest(code=B.ResetDevice),
|
||||||
proto.ButtonRequest(code=B.Success),
|
proto.ButtonRequest(code=B.Success),
|
||||||
]
|
]
|
||||||
* 5 # number of shares
|
* 5 # number of shares
|
||||||
|
@ -242,12 +242,8 @@ def test_signmessage_pagination(client, message):
|
|||||||
|
|
||||||
# start assuming there was a word break; this avoids prepending space at start
|
# start assuming there was a word break; this avoids prepending space at start
|
||||||
word_break = True
|
word_break = True
|
||||||
page = 0
|
br = yield
|
||||||
while True:
|
for i in range(br.pages):
|
||||||
br = yield
|
|
||||||
assert br.page_number == page + 1
|
|
||||||
page = br.page_number
|
|
||||||
|
|
||||||
layout = client.debug.wait_layout()
|
layout = client.debug.wait_layout()
|
||||||
for line in layout.lines[1:]:
|
for line in layout.lines[1:]:
|
||||||
if line == "-":
|
if line == "-":
|
||||||
@ -261,11 +257,10 @@ def test_signmessage_pagination(client, message):
|
|||||||
# attach with space
|
# attach with space
|
||||||
message_read += " " + line
|
message_read += " " + line
|
||||||
|
|
||||||
if page < br.pages:
|
if i < br.pages - 1:
|
||||||
client.debug.swipe_up()
|
client.debug.swipe_up()
|
||||||
else:
|
|
||||||
client.debug.press_yes()
|
client.debug.press_yes()
|
||||||
break
|
|
||||||
|
|
||||||
with client:
|
with client:
|
||||||
client.set_input_flow(input_flow)
|
client.set_input_flow(input_flow)
|
||||||
|
@ -505,6 +505,7 @@ def test_p2wpkh_in_p2sh_fee_bump_from_external(client):
|
|||||||
orig_index=0,
|
orig_index=0,
|
||||||
)
|
)
|
||||||
|
|
||||||
|
t1 = client.features.model == "1"
|
||||||
with client:
|
with client:
|
||||||
client.set_expected_responses(
|
client.set_expected_responses(
|
||||||
[
|
[
|
||||||
@ -517,7 +518,7 @@ def test_p2wpkh_in_p2sh_fee_bump_from_external(client):
|
|||||||
request_output(0),
|
request_output(0),
|
||||||
request_orig_output(0, TXHASH_334cd7),
|
request_orig_output(0, TXHASH_334cd7),
|
||||||
messages.ButtonRequest(code=B.ConfirmOutput),
|
messages.ButtonRequest(code=B.ConfirmOutput),
|
||||||
messages.ButtonRequest(code=B.ConfirmOutput),
|
(t1, messages.ButtonRequest(code=B.ConfirmOutput)),
|
||||||
request_orig_output(1, TXHASH_334cd7),
|
request_orig_output(1, TXHASH_334cd7),
|
||||||
messages.ButtonRequest(code=B.SignTx),
|
messages.ButtonRequest(code=B.SignTx),
|
||||||
request_input(0),
|
request_input(0),
|
||||||
|
@ -23,18 +23,11 @@ from shamir_mnemonic import shamir
|
|||||||
from trezorlib import device, messages
|
from trezorlib import device, messages
|
||||||
from trezorlib.messages import BackupType, ButtonRequestType as B
|
from trezorlib.messages import BackupType, ButtonRequestType as B
|
||||||
|
|
||||||
from ..common import (
|
from ..common import EXTERNAL_ENTROPY, click_through, read_and_confirm_mnemonic
|
||||||
EXTERNAL_ENTROPY,
|
|
||||||
click_through,
|
|
||||||
paging_responses,
|
|
||||||
read_and_confirm_mnemonic,
|
|
||||||
)
|
|
||||||
|
|
||||||
|
|
||||||
def backup_flow_bip39(client):
|
def backup_flow_bip39(client):
|
||||||
mnemonic = None
|
mnemonic = None
|
||||||
words = 12
|
|
||||||
mnemonic_pages = ((words + 3) // 4) + 1
|
|
||||||
|
|
||||||
def input_flow():
|
def input_flow():
|
||||||
nonlocal mnemonic
|
nonlocal mnemonic
|
||||||
@ -59,9 +52,7 @@ def backup_flow_bip39(client):
|
|||||||
client.set_expected_responses(
|
client.set_expected_responses(
|
||||||
[
|
[
|
||||||
messages.ButtonRequest(code=B.ResetDevice),
|
messages.ButtonRequest(code=B.ResetDevice),
|
||||||
]
|
messages.ButtonRequest(code=B.ResetDevice),
|
||||||
+ paging_responses(mnemonic_pages, code=B.ResetDevice)
|
|
||||||
+ [
|
|
||||||
messages.ButtonRequest(code=B.Success),
|
messages.ButtonRequest(code=B.Success),
|
||||||
messages.ButtonRequest(code=B.Success),
|
messages.ButtonRequest(code=B.Success),
|
||||||
messages.Success,
|
messages.Success,
|
||||||
@ -76,8 +67,6 @@ def backup_flow_bip39(client):
|
|||||||
|
|
||||||
def backup_flow_slip39_basic(client):
|
def backup_flow_slip39_basic(client):
|
||||||
mnemonics = []
|
mnemonics = []
|
||||||
words = 20
|
|
||||||
mnemonic_pages = ((words + 3) // 4) + 1
|
|
||||||
|
|
||||||
def input_flow():
|
def input_flow():
|
||||||
# 1. Checklist
|
# 1. Checklist
|
||||||
@ -105,7 +94,7 @@ def backup_flow_slip39_basic(client):
|
|||||||
client.set_expected_responses(
|
client.set_expected_responses(
|
||||||
[messages.ButtonRequest(code=B.ResetDevice)] * 6 # intro screens
|
[messages.ButtonRequest(code=B.ResetDevice)] * 6 # intro screens
|
||||||
+ [
|
+ [
|
||||||
*paging_responses(mnemonic_pages, code=B.ResetDevice),
|
messages.ButtonRequest(code=B.ResetDevice),
|
||||||
messages.ButtonRequest(code=B.Success),
|
messages.ButtonRequest(code=B.Success),
|
||||||
]
|
]
|
||||||
* 5 # individual shares
|
* 5 # individual shares
|
||||||
@ -124,8 +113,6 @@ def backup_flow_slip39_basic(client):
|
|||||||
|
|
||||||
def backup_flow_slip39_advanced(client):
|
def backup_flow_slip39_advanced(client):
|
||||||
mnemonics = []
|
mnemonics = []
|
||||||
words = 20
|
|
||||||
mnemonic_pages = ((words + 3) // 4) + 1
|
|
||||||
|
|
||||||
def input_flow():
|
def input_flow():
|
||||||
# 1. Confirm Reset
|
# 1. Confirm Reset
|
||||||
@ -166,7 +153,7 @@ def backup_flow_slip39_advanced(client):
|
|||||||
]
|
]
|
||||||
* 5 # group thresholds
|
* 5 # group thresholds
|
||||||
+ [
|
+ [
|
||||||
*paging_responses(mnemonic_pages, code=B.ResetDevice),
|
messages.ButtonRequest(code=B.ResetDevice),
|
||||||
messages.ButtonRequest(code=B.Success),
|
messages.ButtonRequest(code=B.Success),
|
||||||
]
|
]
|
||||||
* 25 # individual shares
|
* 25 # individual shares
|
||||||
|
@ -23,12 +23,7 @@ from trezorlib import btc, device, messages
|
|||||||
from trezorlib.messages import BackupType, ButtonRequestType as B
|
from trezorlib.messages import BackupType, ButtonRequestType as B
|
||||||
from trezorlib.tools import parse_path
|
from trezorlib.tools import parse_path
|
||||||
|
|
||||||
from ..common import (
|
from ..common import EXTERNAL_ENTROPY, click_through, read_and_confirm_mnemonic
|
||||||
EXTERNAL_ENTROPY,
|
|
||||||
click_through,
|
|
||||||
paging_responses,
|
|
||||||
read_and_confirm_mnemonic,
|
|
||||||
)
|
|
||||||
|
|
||||||
|
|
||||||
@pytest.mark.skip_t1
|
@pytest.mark.skip_t1
|
||||||
@ -44,8 +39,6 @@ def test_reset_recovery(client):
|
|||||||
|
|
||||||
|
|
||||||
def reset(client, strength=128, skip_backup=False):
|
def reset(client, strength=128, skip_backup=False):
|
||||||
words = strength // 32 * 3
|
|
||||||
mnemonic_pages = ((words + 3) // 4) + 1
|
|
||||||
mnemonic = None
|
mnemonic = None
|
||||||
|
|
||||||
def input_flow():
|
def input_flow():
|
||||||
@ -77,9 +70,7 @@ def reset(client, strength=128, skip_backup=False):
|
|||||||
messages.EntropyRequest(),
|
messages.EntropyRequest(),
|
||||||
messages.ButtonRequest(code=B.ResetDevice),
|
messages.ButtonRequest(code=B.ResetDevice),
|
||||||
messages.ButtonRequest(code=B.ResetDevice),
|
messages.ButtonRequest(code=B.ResetDevice),
|
||||||
]
|
messages.ButtonRequest(code=B.ResetDevice),
|
||||||
+ paging_responses(mnemonic_pages, code=B.ResetDevice)
|
|
||||||
+ [
|
|
||||||
messages.ButtonRequest(code=B.Success),
|
messages.ButtonRequest(code=B.Success),
|
||||||
messages.ButtonRequest(code=B.Success),
|
messages.ButtonRequest(code=B.Success),
|
||||||
messages.Success,
|
messages.Success,
|
||||||
|
@ -25,7 +25,6 @@ from trezorlib.tools import parse_path
|
|||||||
from ..common import (
|
from ..common import (
|
||||||
EXTERNAL_ENTROPY,
|
EXTERNAL_ENTROPY,
|
||||||
click_through,
|
click_through,
|
||||||
paging_responses,
|
|
||||||
read_and_confirm_mnemonic,
|
read_and_confirm_mnemonic,
|
||||||
recovery_enter_shares,
|
recovery_enter_shares,
|
||||||
)
|
)
|
||||||
@ -60,10 +59,6 @@ def test_reset_recovery(client):
|
|||||||
|
|
||||||
def reset(client, strength=128):
|
def reset(client, strength=128):
|
||||||
all_mnemonics = []
|
all_mnemonics = []
|
||||||
# per SLIP-39: strength in bits, rounded up to nearest multiple of 10, plus 70 bits
|
|
||||||
# of metadata, split into 10-bit words
|
|
||||||
word_count = ((strength + 9) // 10) + 7
|
|
||||||
mnemonic_pages = ((word_count + 3) // 4) + 1
|
|
||||||
|
|
||||||
def input_flow():
|
def input_flow():
|
||||||
# 1. Confirm Reset
|
# 1. Confirm Reset
|
||||||
@ -122,7 +117,7 @@ def reset(client, strength=128):
|
|||||||
]
|
]
|
||||||
+ [
|
+ [
|
||||||
# individual mnemonic
|
# individual mnemonic
|
||||||
*paging_responses(mnemonic_pages, code=B.ResetDevice),
|
messages.ButtonRequest(code=B.ResetDevice),
|
||||||
messages.ButtonRequest(code=B.Success),
|
messages.ButtonRequest(code=B.Success),
|
||||||
]
|
]
|
||||||
* (5 * 5) # groups * shares
|
* (5 * 5) # groups * shares
|
||||||
|
@ -23,12 +23,7 @@ from trezorlib import btc, device, messages
|
|||||||
from trezorlib.messages import BackupType, ButtonRequestType as B
|
from trezorlib.messages import BackupType, ButtonRequestType as B
|
||||||
from trezorlib.tools import parse_path
|
from trezorlib.tools import parse_path
|
||||||
|
|
||||||
from ..common import (
|
from ..common import click_through, read_and_confirm_mnemonic, recovery_enter_shares
|
||||||
click_through,
|
|
||||||
paging_responses,
|
|
||||||
read_and_confirm_mnemonic,
|
|
||||||
recovery_enter_shares,
|
|
||||||
)
|
|
||||||
|
|
||||||
EXTERNAL_ENTROPY = b"zlutoucky kun upel divoke ody" * 2
|
EXTERNAL_ENTROPY = b"zlutoucky kun upel divoke ody" * 2
|
||||||
MOCK_OS_URANDOM = mock.Mock(return_value=EXTERNAL_ENTROPY)
|
MOCK_OS_URANDOM = mock.Mock(return_value=EXTERNAL_ENTROPY)
|
||||||
@ -51,10 +46,6 @@ def test_reset_recovery(client):
|
|||||||
|
|
||||||
def reset(client, strength=128):
|
def reset(client, strength=128):
|
||||||
all_mnemonics = []
|
all_mnemonics = []
|
||||||
# per SLIP-39: strength in bits, rounded up to nearest multiple of 10, plus 70 bits
|
|
||||||
# of metadata, split into 10-bit words
|
|
||||||
word_count = ((strength + 9) // 10) + 7
|
|
||||||
mnemonic_pages = ((word_count + 3) // 4) + 1
|
|
||||||
|
|
||||||
def input_flow():
|
def input_flow():
|
||||||
# 1. Confirm Reset
|
# 1. Confirm Reset
|
||||||
@ -98,7 +89,7 @@ def reset(client, strength=128):
|
|||||||
]
|
]
|
||||||
+ [
|
+ [
|
||||||
# individual mnemonic
|
# individual mnemonic
|
||||||
*paging_responses(mnemonic_pages, code=B.ResetDevice),
|
messages.ButtonRequest(code=B.ResetDevice),
|
||||||
messages.ButtonRequest(code=B.Success),
|
messages.ButtonRequest(code=B.Success),
|
||||||
]
|
]
|
||||||
* 5 # number of shares
|
* 5 # number of shares
|
||||||
|
Loading…
Reference in New Issue
Block a user