# This file is part of the Trezor project. # # Copyright (C) 2022 SatoshiLabs and contributors # # This library is free software: you can redistribute it and/or modify # it under the terms of the GNU Lesser General Public License version 3 # as published by the Free Software Foundation. # # 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. # # You should have received a copy of the License along with this library. # If not, see . import time import pytest from trezorlib import btc, device, models from trezorlib.debuglink import TrezorClientDebugLink as Client from trezorlib.tools import parse_path PIN = "1234" def _assert_busy(client: Client, should_be_busy: bool, screen: str = "Homescreen"): assert client.features.busy is should_be_busy if client.model in (models.T2T1, models.T2B1, models.T3T1): if should_be_busy: assert "CoinJoinProgress" in client.debug.read_layout().all_components() else: assert client.debug.read_layout().main_component() == screen @pytest.mark.setup_client(pin=PIN) def test_busy_state(client: Client): _assert_busy(client, False, "Lockscreen") assert client.features.unlocked is False # Show busy dialog for 1 minute. device.set_busy(client, expiry_ms=60 * 1000) _assert_busy(client, True) assert client.features.unlocked is False with client: client.use_pin_sequence([PIN]) btc.get_address( client, "Bitcoin", parse_path("m/44h/0h/0h/0/0"), show_display=True ) client.refresh_features() _assert_busy(client, True) assert client.features.unlocked is True # Hide the busy dialog. device.set_busy(client, None) _assert_busy(client, False) assert client.features.unlocked is True @pytest.mark.flaky(max_runs=5) def test_busy_expiry(client: Client): WAIT_TIME_MS = 1500 TOLERANCE = 1000 _assert_busy(client, False) # Start a timer start = time.monotonic() # Show the busy dialog. device.set_busy(client, expiry_ms=WAIT_TIME_MS) _assert_busy(client, True) # Wait until the layout changes client.debug.wait_layout() end = time.monotonic() # Check that the busy dialog was shown for at least WAIT_TIME_MS. duration = (end - start) * 1000 assert WAIT_TIME_MS <= duration <= WAIT_TIME_MS + TOLERANCE # Check that the device is no longer busy. # Also needs to come back to Homescreen (for UI tests). client.refresh_features() _assert_busy(client, False)