Skip to content

Commit

Permalink
[test] rename TezosAppScreen to TezosNavigator
Browse files Browse the repository at this point in the history
 - move functions and value not related to navigator out of `navigator.py`
  • Loading branch information
spalmer25 committed Dec 12, 2024
1 parent b3631ba commit eedfef1
Show file tree
Hide file tree
Showing 27 changed files with 523 additions and 424 deletions.
13 changes: 8 additions & 5 deletions tests/integration/nano/conftest.py
Original file line number Diff line number Diff line change
Expand Up @@ -21,9 +21,11 @@

import pytest
from ragger.firmware import Firmware
from ragger.navigator import NanoNavigator

from utils.account import Account, DEFAULT_ACCOUNT, DEFAULT_SEED
from utils.app import TezosAppScreen, SpeculosTezosBackend
from utils.backend import TezosBackend, SpeculosTezosBackend
from utils.navigator import TezosNavigator

FIRMWARES: List[Firmware] = [
Firmware.NANOS,
Expand Down Expand Up @@ -163,7 +165,7 @@ def backend(app_path: Path,
port: int,
display: bool,
seed: str,
speculos_args: List[str]) -> Generator[SpeculosTezosBackend, None, None]:
speculos_args: List[str]) -> Generator[TezosBackend, None, None]:
"""Get `backend` for pytest."""

if display:
Expand All @@ -183,9 +185,10 @@ def backend(app_path: Path,
yield b

@pytest.fixture(scope="function")
def app(backend: SpeculosTezosBackend, golden_run: bool) -> TezosAppScreen:
"""Get `app` for pytest."""
return TezosAppScreen(backend, golden_run)
def tezos_navigator(backend: TezosBackend, golden_run: bool) -> TezosNavigator:
"""Get `navigator` for pytest."""
navigator = NanoNavigator(backend, backend.firmware, golden_run)
return TezosNavigator(backend, navigator)

@pytest.fixture(scope="function")
def snapshot_dir(request) -> Path :
Expand Down
32 changes: 16 additions & 16 deletions tests/integration/nano/test_menu.py
Original file line number Diff line number Diff line change
Expand Up @@ -24,59 +24,59 @@
from ragger.navigator import NavIns, NavInsID

from utils.backend import TezosBackend
from utils.app import TezosAppScreen
from utils.navigator import TezosNavigator


def test_home_menu(app: TezosAppScreen, snapshot_dir: Path):
def test_home_menu(tezos_navigator: TezosNavigator, snapshot_dir: Path):
"""Check home menu flow"""
instructions: List[Union[NavIns, NavInsID]] = [
# Home
NavInsID.RIGHT_CLICK, # Version
NavInsID.RIGHT_CLICK, # Settings
NavInsID.RIGHT_CLICK, # Quit
]
app.navigate(
tezos_navigator.navigate(
instructions=instructions,
snap_path=snapshot_dir,
)


def test_settings_menu(app: TezosAppScreen, snapshot_dir: Path):
def test_settings_menu(tezos_navigator: TezosNavigator, snapshot_dir: Path):
"""Check settings menu flow"""
app.navigate_to_settings()
tezos_navigator.navigate_to_settings()
instructions: List[Union[NavIns, NavInsID]] = [
# Expert Mode
NavInsID.RIGHT_CLICK, # Blind Sign
NavInsID.RIGHT_CLICK, # Back
NavInsID.BOTH_CLICK, # Home
]
app.navigate(
tezos_navigator.navigate(
instructions=instructions,
snap_path=snapshot_dir
)


def test_toggle_expert_mode(app: TezosAppScreen, snapshot_dir: Path):
def test_toggle_expert_mode(tezos_navigator: TezosNavigator, snapshot_dir: Path):
"""Check settings' expert_mode toggle"""
snap_idx = app.toggle_expert_mode(snap_path=snapshot_dir)
snap_idx = tezos_navigator.toggle_expert_mode(snap_path=snapshot_dir)
# Toggle back
app.toggle_expert_mode(snap_start_idx=snap_idx, snap_path=snapshot_dir)
tezos_navigator.toggle_expert_mode(snap_start_idx=snap_idx, snap_path=snapshot_dir)


def test_toggle_blindsign(app: TezosAppScreen, snapshot_dir: Path):
def test_toggle_blindsign(tezos_navigator: TezosNavigator, snapshot_dir: Path):
"""Check settings' blindsign toggle"""
snap_idx = app.toggle_blindsign(snap_path=snapshot_dir)
snap_idx = tezos_navigator.toggle_blindsign(snap_path=snapshot_dir)
# Toggle back
app.toggle_blindsign(snap_start_idx=snap_idx, snap_path=snapshot_dir)
tezos_navigator.toggle_blindsign(snap_start_idx=snap_idx, snap_path=snapshot_dir)


def test_quit(app: TezosAppScreen):
def test_quit(backend: TezosBackend):
"""Check quit app"""
# Home
app.backend.left_click()
app.backend.wait_for_screen_change() # Quit
backend.left_click()
backend.wait_for_screen_change() # Quit
try:
app.backend.both_click()
backend.both_click()
assert False, "Must have lost connection with speculos"
except requests.exceptions.ConnectionError:
pass
16 changes: 8 additions & 8 deletions tests/integration/nano/test_public_key.py
Original file line number Diff line number Diff line change
Expand Up @@ -21,8 +21,8 @@
import pytest

from utils.account import Account, PublicKey, SigType
from utils.app import TezosAppScreen
from utils.backend import StatusCode
from utils.backend import TezosBackend, StatusCode
from utils.navigator import TezosNavigator

accounts = [
Account("m/44'/1729'/0'/0'",
Expand All @@ -40,12 +40,12 @@
]

@pytest.mark.parametrize("account", accounts, ids=lambda account: f"{account.sig_type}")
def test_get_pk(app: TezosAppScreen, account: Account):
def test_get_pk(backend: TezosBackend, account: Account):
"""Test that public keys get from the app are correct."""

expected_public_key = account.key.public_key()

data = app.backend.get_public_key(account, with_prompt=False)
data = backend.get_public_key(account, with_prompt=False)

public_key = PublicKey.from_bytes(data, account.sig_type)

Expand All @@ -54,21 +54,21 @@ def test_get_pk(app: TezosAppScreen, account: Account):


@pytest.mark.parametrize("account", accounts, ids=lambda account: f"{account.sig_type}")
def test_provide_pk(app: TezosAppScreen, account: Account, snapshot_dir: Path):
def test_provide_pk(tezos_navigator: TezosNavigator, account: Account, snapshot_dir: Path):
"""Test that public keys get from the app are correct and correctly displayed."""

expected_public_key = account.key.public_key()

data = app.provide_public_key(account, snap_path=snapshot_dir)
data = tezos_navigator.provide_public_key(account, snap_path=snapshot_dir)

public_key = PublicKey.from_bytes(data, account.sig_type)

assert public_key == expected_public_key.encode(), \
f"Expected public key {expected_public_key} but got {public_key}"


def test_reject_pk(app: TezosAppScreen, account: Account, snapshot_dir: Path):
def test_reject_pk(tezos_navigator: TezosNavigator, account: Account, snapshot_dir: Path):
"""Check reject pk behaviour"""

with StatusCode.REJECT.expected():
app.reject_public_key(account, snap_path=snapshot_dir)
tezos_navigator.reject_public_key(account, snap_path=snapshot_dir)
15 changes: 9 additions & 6 deletions tests/integration/nano/test_sign/operations/test_sign_ballot.py
Original file line number Diff line number Diff line change
Expand Up @@ -19,10 +19,11 @@
from pathlib import Path

from utils.account import Account
from utils.app import TezosAppScreen
from utils.message import Ballot
from utils.navigator import TezosNavigator

def test_sign_ballot(app: TezosAppScreen, account: Account, snapshot_dir: Path):

def test_sign_ballot(tezos_navigator: TezosNavigator, account: Account, snapshot_dir: Path):
"""Check signing ballot"""

message = Ballot(
Expand All @@ -32,10 +33,12 @@ def test_sign_ballot(app: TezosAppScreen, account: Account, snapshot_dir: Path):
period = 32
)

data = app.sign(account,
message,
with_hash=True,
snap_path=snapshot_dir)
data = tezos_navigator.sign(
account,
message,
with_hash=True,
snap_path=snapshot_dir
)

account.check_signature(
message=message,
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -21,19 +21,20 @@
from conftest import requires_device

from utils.account import Account
from utils.app import TezosAppScreen
from utils.message import (
OperationGroup,
Origination,
Transaction,
TransferTicket
)
from utils.navigator import TezosNavigator


@requires_device("nanos")
def test_nanos_regression_batched_ops(app: TezosAppScreen, account: Account, snapshot_dir: Path):
def test_nanos_regression_batched_ops(tezos_navigator: TezosNavigator, account: Account, snapshot_dir: Path):
"""Check signing batch operation"""

app.toggle_expert_mode()
tezos_navigator.toggle_expert_mode()

message = OperationGroup([
Transaction(
Expand All @@ -58,21 +59,23 @@ def test_nanos_regression_batched_ops(app: TezosAppScreen, account: Account, sna
)
])

data = app.sign(account,
message,
with_hash=True,
snap_path=snapshot_dir)
data = tezos_navigator.sign(
account,
message,
with_hash=True,
snap_path=snapshot_dir
)

account.check_signature(
message=message,
with_hash=True,
data=data)

@requires_device("nanox")
def test_nanox_regression_batched_ops(app: TezosAppScreen, account: Account, snapshot_dir: Path):
def test_nanox_regression_batched_ops(tezos_navigator: TezosNavigator, account: Account, snapshot_dir: Path):
"""Check signing batch operation"""

app.toggle_expert_mode()
tezos_navigator.toggle_expert_mode()

message = OperationGroup([
Transaction(
Expand All @@ -97,20 +100,22 @@ def test_nanox_regression_batched_ops(app: TezosAppScreen, account: Account, sna
)
])

data = app.sign(account,
message,
with_hash=True,
snap_path=snapshot_dir)
data = tezos_navigator.sign(
account,
message,
with_hash=True,
snap_path=snapshot_dir
)

account.check_signature(
message=message,
with_hash=True,
data=data)

def test_sign_complex_operation(app: TezosAppScreen, account: Account, snapshot_dir: Path):
def test_sign_complex_operation(tezos_navigator: TezosNavigator, account: Account, snapshot_dir: Path):
"""Check signing complex operation"""

app.toggle_expert_mode()
tezos_navigator.toggle_expert_mode()

message = OperationGroup([
Origination(
Expand All @@ -137,10 +142,12 @@ def test_sign_complex_operation(app: TezosAppScreen, account: Account, snapshot_
)
])

data = app.sign(account,
message,
with_hash=True,
snap_path=snapshot_dir)
data = tezos_navigator.sign(
account,
message,
with_hash=True,
snap_path=snapshot_dir
)

account.check_signature(
message=message,
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -19,10 +19,11 @@
from pathlib import Path

from utils.account import Account
from utils.app import TezosAppScreen
from utils.message import Delegation
from utils.navigator import TezosNavigator

def test_sign_delegation(app: TezosAppScreen, account: Account, snapshot_dir: Path):

def test_sign_delegation(tezos_navigator: TezosNavigator, account: Account, snapshot_dir: Path):
"""Check signing delegation"""

message = Delegation(
Expand All @@ -34,10 +35,12 @@ def test_sign_delegation(app: TezosAppScreen, account: Account, snapshot_dir: Pa
delegate = 'tz1TmFPVZsGQ8MnrBJtnECJgkFUwLa6EWYDm'
)

data = app.sign(account,
message,
with_hash=True,
snap_path=snapshot_dir)
data = tezos_navigator.sign(
account,
message,
with_hash=True,
snap_path=snapshot_dir
)

account.check_signature(
message=message,
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -19,18 +19,21 @@
from pathlib import Path

from utils.account import Account
from utils.app import TezosAppScreen
from utils.message import FailingNoop
from utils.navigator import TezosNavigator

def test_sign_failing_noop(app: TezosAppScreen, account: Account, snapshot_dir: Path):

def test_sign_failing_noop(tezos_navigator: TezosNavigator, account: Account, snapshot_dir: Path):
"""Check signing failing noop"""

message = FailingNoop("9f09f2952d34528c733f94615cfc39bc555619fc550dd4a67ba2208ce8e867aa3d13a6ef99dfbe32c6974aa9a2150d21eca29c3349e59c13b9081f1c11b440ac4d3455dedbe4ee0de15a8af620d4c86247d9d132de1bb6da23d5ff9d8dffda22ba9a84")

data = app.sign(account,
message,
with_hash=True,
snap_path=snapshot_dir)
data = tezos_navigator.sign(
account,
message,
with_hash=True,
snap_path=snapshot_dir
)

account.check_signature(
message=message,
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -19,10 +19,11 @@
from pathlib import Path

from utils.account import Account
from utils.app import TezosAppScreen
from utils.message import IncreasePaidStorage
from utils.navigator import TezosNavigator

def test_sign_increase_paid_storage(app: TezosAppScreen, account: Account, snapshot_dir: Path):

def test_sign_increase_paid_storage(tezos_navigator: TezosNavigator, account: Account, snapshot_dir: Path):
"""Check signing increase paid storage"""

message = IncreasePaidStorage(
Expand All @@ -35,10 +36,12 @@ def test_sign_increase_paid_storage(app: TezosAppScreen, account: Account, snaps
destination = "KT18amZmM5W7qDWVt2pH6uj7sCEd3kbzLrHT"
)

data = app.sign(account,
message,
with_hash=True,
snap_path=snapshot_dir)
data = tezos_navigator.sign(
account,
message,
with_hash=True,
snap_path=snapshot_dir
)

account.check_signature(
message=message,
Expand Down
Loading

0 comments on commit eedfef1

Please sign in to comment.