1
0
mirror of https://github.com/trezor/trezor-firmware.git synced 2024-12-11 08:58:08 +00:00
trezor-firmware/tests/device_tests/test_autolock.py

183 lines
5.2 KiB
Python
Raw Normal View History

#
# This file is part of the Trezor project.
# Copyright (C) 2012-2019 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 <https://www.gnu.org/licenses/lgpl-3.0.html>.
import time
import pytest
from trezorlib import device, messages, models
2024-11-15 15:06:55 +00:00
from trezorlib.debuglink import SessionDebugWrapper as Session
from trezorlib.exceptions import TrezorFailure
from ..common import TEST_ADDRESS_N, get_test_address
PIN4 = "1234"
pytestmark = pytest.mark.setup_client(pin=PIN4)
2024-11-15 15:06:55 +00:00
def pin_request(session: Session):
return (
messages.PinMatrixRequest
2024-11-15 15:06:55 +00:00
if session.model is models.T1B1
else messages.ButtonRequest
)
2024-11-15 15:06:55 +00:00
def set_autolock_delay(session: Session, delay):
with session, session.client as client:
client.use_pin_sequence([PIN4])
2024-11-15 15:06:55 +00:00
session.set_expected_responses(
[
2024-11-15 15:06:55 +00:00
pin_request(session),
messages.ButtonRequest,
messages.Success,
2024-11-15 15:06:55 +00:00
# messages.Features,
]
)
2024-11-15 15:06:55 +00:00
device.apply_settings(session, auto_lock_delay_ms=delay)
2024-11-15 15:06:55 +00:00
def test_apply_auto_lock_delay(session: Session):
session.lock()
set_autolock_delay(session, 10 * 1000)
time.sleep(0.1) # sleep less than auto-lock delay
2024-11-15 15:06:55 +00:00
with session:
# No PIN protection is required.
2024-11-15 15:06:55 +00:00
session.set_expected_responses([messages.Address])
get_test_address(session)
time.sleep(10.5) # sleep more than auto-lock delay
2024-11-15 15:06:55 +00:00
with session, session.client as client:
client.use_pin_sequence([PIN4])
2024-11-15 15:06:55 +00:00
session.set_expected_responses([pin_request(session), messages.Address])
get_test_address(session)
@pytest.mark.parametrize(
"seconds",
[
10, # 10 seconds, minimum
60, # 1 minute
123, # 2 minutes
3601, # 1 hour
7227, # 2 hours
536870, # 149 hours, maximum
],
)
2024-11-15 15:06:55 +00:00
def test_apply_auto_lock_delay_valid(session: Session, seconds):
session.lock()
set_autolock_delay(session, seconds * 1000)
assert session.features.auto_lock_delay_ms == seconds * 1000
2024-11-15 15:06:55 +00:00
def test_autolock_default_value(session: Session):
session.lock()
assert session.features.auto_lock_delay_ms is None
with session, session.client as client:
client.use_pin_sequence([PIN4])
2024-11-15 15:06:55 +00:00
device.apply_settings(session, label="pls unlock")
session.refresh_features()
assert session.features.auto_lock_delay_ms == 60 * 10 * 1000
@pytest.mark.parametrize(
2020-09-25 11:59:16 +00:00
"seconds",
[0, 1, 9, 536871, 2**22],
)
2024-11-15 15:06:55 +00:00
def test_apply_auto_lock_delay_out_of_range(session: Session, seconds):
session.lock()
with session, session.client as client:
client.use_pin_sequence([PIN4])
2024-11-15 15:06:55 +00:00
session.set_expected_responses(
[
2024-11-15 15:06:55 +00:00
pin_request(session),
messages.Failure(code=messages.FailureType.ProcessError),
]
)
delay = seconds * 1000
with pytest.raises(TrezorFailure):
2024-11-15 15:06:55 +00:00
device.apply_settings(session, auto_lock_delay_ms=delay)
@pytest.mark.models("core")
2024-11-15 15:06:55 +00:00
def test_autolock_cancels_ui(session: Session):
session.lock()
set_autolock_delay(session, 10 * 1000)
2024-11-15 15:06:55 +00:00
resp = session.call_raw(
messages.GetAddress(
coin_name="Testnet",
address_n=TEST_ADDRESS_N,
show_display=True,
script_type=messages.InputScriptType.SPENDADDRESS,
)
)
assert isinstance(resp, messages.ButtonRequest)
# send an ack, do not read response
2024-11-15 15:06:55 +00:00
session._write(messages.ButtonAck())
# sleep more than auto-lock delay
time.sleep(10.5)
2024-11-15 15:06:55 +00:00
resp = session._read()
assert isinstance(resp, messages.Failure)
assert resp.code == messages.FailureType.ActionCancelled
2024-11-15 15:06:55 +00:00
def test_autolock_ignores_initialize(session: Session):
session.lock()
2024-11-15 15:06:55 +00:00
set_autolock_delay(session, 10 * 1000)
assert session.features.unlocked is True
start = time.monotonic()
while time.monotonic() - start < 11:
# init_device should always work even if locked
2024-11-15 15:06:55 +00:00
raise Exception("THIS SHOULD BE REMADE")
session.init_device()
time.sleep(0.1)
# after 11 seconds we are definitely locked
2024-11-15 15:06:55 +00:00
assert session.features.unlocked is False
2024-11-15 15:06:55 +00:00
def test_autolock_ignores_getaddress(session: Session):
session.lock()
2024-11-15 15:06:55 +00:00
set_autolock_delay(session, 10 * 1000)
2024-11-15 15:06:55 +00:00
assert session.features.unlocked is True
start = time.monotonic()
# let's continue for 8 seconds to give a little leeway to the slow CI
while time.monotonic() - start < 8:
2024-11-15 15:06:55 +00:00
get_test_address(session)
time.sleep(0.1)
# sleep 3 more seconds to wait for autolock
time.sleep(3)
# after 11 seconds we are definitely locked
2024-11-15 15:06:55 +00:00
session.refresh_features()
assert session.features.unlocked is False