Skip to content

Commit

Permalink
[tests] add python linter
Browse files Browse the repository at this point in the history
  • Loading branch information
spalmer25 committed Nov 7, 2024
1 parent 4cd0f96 commit 5860929
Show file tree
Hide file tree
Showing 58 changed files with 765 additions and 480 deletions.
12 changes: 12 additions & 0 deletions tests/integration/.pylintrc
Original file line number Diff line number Diff line change
@@ -0,0 +1,12 @@
[MESSAGES CONTROL]
disable=
broad-exception-caught,
global-statement,
line-too-long,
protected-access,
redefined-outer-name,
too-few-public-methods,
too-many-arguments,
too-many-instance-attributes,
too-many-positional-arguments,
too-many-statements,
51 changes: 42 additions & 9 deletions tests/integration/nano/conftest.py
Original file line number Diff line number Diff line change
@@ -1,11 +1,29 @@
import pytest
# Copyright 2024 Trilitech <[email protected]>
# Copyright 2024 Functori <[email protected]>

# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at

# http://www.apache.org/licenses/LICENSE-2.0

# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.

"""Conftest base on `ragger` conftest."""


from pathlib import Path
from typing import Dict, Generator, List, Union

import pytest
from ragger.firmware import Firmware
from typing import Dict, Callable, Generator, List, Optional, Tuple, Union

from utils.app import TezosAppScreen, SpeculosTezosBackend, DEFAULT_SEED
from utils.backend import TezosBackend, APP_KIND
from utils.backend import AppKind

FIRMWARES: List[Firmware] = [
Firmware.NANOS,
Expand All @@ -16,6 +34,7 @@
DEVICES: List[str] = list(map(lambda fw: fw.device, FIRMWARES))

def pytest_addoption(parser):
"""Register argparse-style options for pytest."""
parser.addoption("-D", "--device",
type=str,
choices=DEVICES,
Expand Down Expand Up @@ -49,6 +68,7 @@ def pytest_addoption(parser):
global_log_dir: Union[Path, None] = None

def pytest_configure(config):
"""Configure pytest."""
global global_log_dir
log_dir = config.getoption("log_dir")
if log_dir is not None:
Expand All @@ -57,21 +77,24 @@ def pytest_configure(config):
logs : Dict[str, List[pytest.TestReport]] = {}

@pytest.hookimpl(tryfirst=True)
def pytest_runtest_logstart(nodeid, location):
def pytest_runtest_logstart(location):
"""Called at the start of running the runtest protocol for a single item."""
logs[location[2]] = []

@pytest.hookimpl(tryfirst=True)
def pytest_runtest_logreport(report):
"""Called at the end of running the runtest protocol for a single test."""
logs[report.head_line].append(report)

@pytest.hookimpl(tryfirst=True)
def pytest_runtest_logfinish(nodeid, location):
def pytest_runtest_logfinish(location):
"""Called at the end of running the runtest protocol for a single item."""
if global_log_dir is not None:
log_dir = global_log_dir / Path(location[0]).stem
log_dir.mkdir(parents=True, exist_ok=True)
head_line = location[2]
log_file = log_dir / f"{head_line.replace(' ', '_')}.log"
with open(log_file, 'w') as writer:
with open(log_file, 'w', encoding="utf-8") as writer:
for report in logs[head_line]:
writer.write(f"============================== {report.when.capitalize()} {report.outcome} ==============================\n")
writer.write(f"{report.longreprtext}\n")
Expand All @@ -84,37 +107,44 @@ def pytest_runtest_logfinish(nodeid, location):

@pytest.fixture(scope="session")
def firmware(pytestconfig) -> Firmware :
"""Get `firware` for pytest."""
device = pytestconfig.getoption("device")
return next(fw for fw in FIRMWARES if fw.device == device)

@pytest.fixture(scope="session")
def port(pytestconfig, request, worker_id) -> int :
def port(pytestconfig, worker_id) -> int :
"""Get `port` for pytest."""
if worker_id == "master":
return pytestconfig.getoption("port")
# worker_id = gw0, gw1, ...
return 5000 + int(worker_id[2:])

@pytest.fixture(scope="session")
def display(pytestconfig) -> bool :
"""Get `display` for pytest."""
return pytestconfig.getoption("display")

@pytest.fixture(scope="session")
def golden_run(pytestconfig) -> bool:
"""Get `golden_run` for pytest."""
return pytestconfig.getoption("golden_run")

@pytest.fixture(scope="session")
def app_path(pytestconfig) -> Path:
"""Get `app_path` for pytest."""
return Path(pytestconfig.getoption("app"))

@pytest.fixture(scope="session")
def speculos_args(pytestconfig) -> List[str]:
"""Get `app_path` for pytest."""
speculos_args = pytestconfig.getoption("speculos_args")
if speculos_args is None:
return []
return speculos_args.split()

@pytest.fixture(scope="function")
def seed(request) -> str:
"""Get `seed` for pytest."""
param = getattr(request, "param", None)
return param.get("seed", DEFAULT_SEED) if param else DEFAULT_SEED

Expand All @@ -125,6 +155,7 @@ def backend(app_path: Path,
display: bool,
seed: str,
speculos_args: List[str]) -> Generator[SpeculosTezosBackend, None, None]:
"""Get `backend` for pytest."""

if display:
speculos_args += ["--display", "qt"]
Expand All @@ -143,10 +174,12 @@ def backend(app_path: Path,
yield b

@pytest.fixture(scope="function")
def app(backend: SpeculosTezosBackend, golden_run: bool):
return TezosAppScreen(backend, APP_KIND.WALLET, golden_run)
def app(backend: SpeculosTezosBackend, golden_run: bool) -> TezosAppScreen:
"""Get `app` for pytest."""
return TezosAppScreen(backend, AppKind.WALLET, golden_run)

def requires_device(device):
"""Wrapper to run the pytest test only with the provided device."""
return pytest.mark.skipif(
f"config.getvalue('device') != '{ device }'",
reason=f"Test requires device to be { device }."
Expand Down
Empty file.
15 changes: 5 additions & 10 deletions tests/integration/nano/nanos/test_nanos_regression_batched_ops.py
Original file line number Diff line number Diff line change
Expand Up @@ -13,19 +13,13 @@
# See the License for the specific language governing permissions and
# limitations under the License.

import os
import sys
"""Check signing batch operation"""

file_path=os.path.abspath(__file__)
dir_path=os.path.dirname(file_path)
root_path=os.path.dirname(dir_path)
sys.path.append(root_path)
from pathlib import Path

from conftest import requires_device

from pathlib import Path

from utils.app import Screen, DEFAULT_ACCOUNT
from utils.app import TezosAppScreen, DEFAULT_ACCOUNT
from utils.message import Message

# Operation (0): Transaction
Expand All @@ -42,7 +36,8 @@
# Destination: KT1CYT8oACUcCSNTu2qfgB4fj5bD7szYrpti

@requires_device("nanos")
def test_nanos_regression_batched_ops(app):
def test_nanos_regression_batched_ops(app: TezosAppScreen):
"""Check signing batch operation"""
test_name = Path(__file__).stem

app.setup_expert_mode()
Expand Down
Empty file.
Original file line number Diff line number Diff line change
Expand Up @@ -13,19 +13,13 @@
# See the License for the specific language governing permissions and
# limitations under the License.

import os
import sys
"""Check signing operation that display potentially empty screens"""

file_path=os.path.abspath(__file__)
dir_path=os.path.dirname(file_path)
root_path=os.path.dirname(dir_path)
sys.path.append(root_path)
from pathlib import Path

from conftest import requires_device

from pathlib import Path

from utils.app import Screen, DEFAULT_ACCOUNT
from utils.app import TezosAppScreen, DEFAULT_ACCOUNT
from utils.message import Message

# Operation (0): Transfer ticket
Expand All @@ -43,7 +37,8 @@
# S

@requires_device("nanosp")
def test_nanosp_regression_potential_empty_screen(app):
def test_nanosp_regression_potential_empty_screen(app: TezosAppScreen):
"""Check signing operation that display potentially empty screens"""
test_name = Path(__file__).stem

app.setup_expert_mode()
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -13,28 +13,23 @@
# See the License for the specific language governing permissions and
# limitations under the License.

import os
import sys
"""Check no need to click right two times between APDUs during signing flow"""

file_path=os.path.abspath(__file__)
dir_path=os.path.dirname(file_path)
root_path=os.path.dirname(dir_path)
sys.path.append(root_path)
from pathlib import Path

from conftest import requires_device

from pathlib import Path

from utils.app import Screen, DEFAULT_ACCOUNT
from utils.app import Screen, TezosAppScreen, DEFAULT_ACCOUNT
from utils.message import Message

# Expression: {IF_NONE {{SWAP;IF {DIP {{DROP 1;PUSH unit Unit;PUSH bool True;PUSH string ";L\\S?p$-Fq)VDg\n]te\no4v0_8)\""}}} {{DROP 2;PUSH unit Unit;PUSH bool False;PUSH string "Li-%*edF6~?E[5Kmu?dyviwJ^2\"\\d$FyQ>>!>D$g(Qg";PUSH string "*Tx<E`SiG6Yf*A^kZ\\=7?H[mOlQ\n]Ehs"}}}} {IF_NONE {DUP} {{DROP 4;PUSH unit Unit;PUSH bool True;PUSH string "\"\\6_4\n$k%";PUSH string "c^1\"\\?Ey_1!EVb~9;EX;YU\n#Kj2ZT8h`U!X "}}};SIZE}

@requires_device("nanosp")
def test_nanosp_regression_press_right_works_across_apdu_recieves(app):
def test_nanosp_regression_press_right_works_across_apdu_recieves(app: TezosAppScreen):
"""Check no need to click right two times between APDUs during signing flow"""
test_name = Path(__file__).stem

app.assert_screen(Screen.Home)
app.assert_screen(Screen.HOME)

message = Message.from_bytes("050200000135072f02000000c502000000c0034c072c0200000040051f02000000390200000034052000010743036c030b07430359030a07430368010000001b3b4c5c533f70242d4671295644670a5d74650a6f3476305f3829220200000072020000006d052000020743036c030b07430359030307430368010000002b4c692d252a656446367e3f455b354b6d753f64797669774a5e32225c64244679513e3e213e4424672851670743036801000000202a54783c45605369473659662a415e6b5a5c3d373f485b6d4f6c510a5d4568730200000062072f020000000203210200000054020000004f052000040743036c030b07430359030a074303680100000009225c365f340a246b25074303680100000024635e31225c3f45795f31214556627e393b45583b59550a234b6a325a54386860552158200345")

Expand Down
Empty file.
15 changes: 5 additions & 10 deletions tests/integration/nano/nanox/test_nanox_regression_batched_ops.py
Original file line number Diff line number Diff line change
Expand Up @@ -13,19 +13,13 @@
# See the License for the specific language governing permissions and
# limitations under the License.

import os
import sys
"""Check signing batch operation"""

file_path=os.path.abspath(__file__)
dir_path=os.path.dirname(file_path)
root_path=os.path.dirname(dir_path)
sys.path.append(root_path)
from pathlib import Path

from conftest import requires_device

from pathlib import Path

from utils.app import Screen, DEFAULT_ACCOUNT
from utils.app import TezosAppScreen, DEFAULT_ACCOUNT
from utils.message import Message

# Operation (0): Transaction
Expand All @@ -42,7 +36,8 @@
# Destination: KT1CYT8oACUcCSNTu2qfgB4fj5bD7szYrpti

@requires_device("nanox")
def test_nanox_regression_batched_ops(app):
def test_nanox_regression_batched_ops(app: TezosAppScreen):
"""Check signing batch operation"""
test_name = Path(__file__).stem

app.setup_expert_mode()
Expand Down
66 changes: 34 additions & 32 deletions tests/integration/nano/test_basic.py
Original file line number Diff line number Diff line change
Expand Up @@ -13,68 +13,70 @@
# See the License for the specific language governing permissions and
# limitations under the License.

from utils.app import Screen
"""Check main menu operation"""

def test_basic(app):
# Check main menu operation
app.assert_screen(Screen.Home)
from utils.app import Screen, TezosAppScreen

def test_basic(app: TezosAppScreen):
"""Check main menu operation"""
app.assert_screen(Screen.HOME)
app.backend.right_click()
app.assert_screen(Screen.Version)
app.assert_screen(Screen.VERSION)
app.backend.both_click()
app.assert_screen(Screen.Version)
app.assert_screen(Screen.VERSION)
app.backend.right_click()
app.assert_screen(Screen.Settings)
app.assert_screen(Screen.SETTINGS)
app.backend.right_click()
app.assert_screen(Screen.Quit)
app.assert_screen(Screen.QUIT)
app.backend.left_click()
app.assert_screen(Screen.Settings)
app.assert_screen(Screen.SETTINGS)
app.backend.left_click()
app.assert_screen(Screen.Version)
app.assert_screen(Screen.VERSION)
app.backend.left_click()
app.assert_screen(Screen.Home)
app.assert_screen(Screen.HOME)
app.backend.both_click()
app.assert_screen(Screen.Home)
app.assert_screen(Screen.HOME)
app.backend.left_click()
app.assert_screen(Screen.Quit)
app.assert_screen(Screen.QUIT)
app.backend.right_click()
app.assert_screen(Screen.Home)
app.assert_screen(Screen.HOME)
app.backend.right_click()
app.assert_screen(Screen.Version)
app.assert_screen(Screen.VERSION)
app.backend.right_click()
app.assert_screen(Screen.Settings)
app.assert_screen(Screen.SETTINGS)
app.backend.right_click()
app.assert_screen(Screen.Quit)
app.assert_screen(Screen.QUIT)
app.backend.right_click()
app.assert_screen(Screen.Home)
app.assert_screen(Screen.HOME)
app.backend.right_click()
app.assert_screen(Screen.Version)
app.assert_screen(Screen.VERSION)

# Check Settings menu operation
app.backend.right_click()
app.assert_screen(Screen.Settings)
app.assert_screen(Screen.SETTINGS)
app.backend.both_click()
app.assert_screen(Screen.Settings_expert_mode_disabled)
app.assert_screen(Screen.SETTINGS_EXPERT_MODE_DISABLED)
app.backend.both_click()
app.assert_screen(Screen.Settings_expert_mode_enabled)
app.assert_screen(Screen.SETTINGS_EXPERT_MODE_ENABLED)
app.backend.right_click()
app.assert_screen(Screen.Settings_blindsign_off)
app.assert_screen(Screen.SETTINGS_BLINDSIGN_OFF)
app.backend.both_click()
app.assert_screen(Screen.Settings_blindsign_on)
app.assert_screen(Screen.SETTINGS_BLINDSIGN_ON)
app.backend.both_click()
app.assert_screen(Screen.Settings_blindsign_off)
app.assert_screen(Screen.SETTINGS_BLINDSIGN_OFF)
app.backend.right_click()
app.assert_screen(Screen.Settings_back)
app.assert_screen(Screen.SETTINGS_BACK)
app.backend.left_click()
app.assert_screen(Screen.Settings_blindsign_off)
app.assert_screen(Screen.SETTINGS_BLINDSIGN_OFF)
app.backend.left_click()
app.assert_screen(Screen.Settings_expert_mode_enabled)
app.assert_screen(Screen.SETTINGS_EXPERT_MODE_ENABLED)
app.backend.left_click()
app.assert_screen(Screen.Settings_back)
app.assert_screen(Screen.SETTINGS_BACK)
app.backend.right_click()
app.assert_screen(Screen.Settings_expert_mode_enabled)
app.assert_screen(Screen.SETTINGS_EXPERT_MODE_ENABLED)
app.backend.left_click()
app.assert_screen(Screen.Settings_back)
app.assert_screen(Screen.SETTINGS_BACK)
app.backend.both_click()
app.assert_screen(Screen.Home)
app.assert_screen(Screen.HOME)
app.backend.left_click()
app._quit()
Loading

0 comments on commit 5860929

Please sign in to comment.