All notable changes to this project will be documented in this file.
The format is based on Keep a Changelog, and this project adheres to Semantic Versioning.
- navigator:
Navigator.navigate_until_text_and_compare
andNavigator.navigate_until_text
now accept asnap_start_idx
argument, likeNavigator.navigate_and_compare
.
- conftest: Added a all_eink device option to target Stax and Flex
- conftest: Added a autouse fixture to skip unsupported devices
- firmware/stax: Choice List positions were no longer correct compared to latest NBGL evolutions
- Rust app: get target directory from cargo metadata (workspace compatible)
- firmware/flex: Wrong keyboard position
- firmware/flex: Added the suggestion buttons positions (used with keyboard)
- firmware/stax: Updated the suggestion buttons positions (used with keyboard)
- firmware/flex: Wrong keyboard position
- Use SWIPE_CENTER_TO_LEFT in Stax navigation scenario
- navigator: Now use Stax API_LEVEL_21 as layout for navigation
- REVERT conftest: Fixed '--device all': limit the tests to devices declared in the App manifest
- conftest: Fixed '--device all': limit the tests to devices declared in the App manifest
- conftest: Fixed '--device all' conftest option
- navigator: Moved review.tap coordinates on Stax from center to center left to avoid clicking on QR code button
- conftest: Overridable fixture to inject custom arguments into the Speculos client
- firmware/navigation: Adding swipe capabilities for Flex
- navigation: scenarios now use
Firmware
enum rather than strings
- backend: Adapting to new Speculos API
finger_touch
function.
- navigator: fixed issue when using the custom_screen_text parameter
- Flex firmware & navigation
- firmware: 'stax' module is renamed 'touch', as it is no longer specific to the Stax device
- navigator: 'StaxNavigator' class is renamed 'TouchNavigator', as it is no longer specific to the Stax device
- firmware: deprecated properties
Firmware.has_bal
andhas_nbgl
- Speculos backend: if not specified, availability of API and APDU ports are checked to avoid collision
- navigator: New pytest fixture to navigate by scenario to simplify classic navigation operations
- Speculos backend: Properly fixed internal snapshot state desync compare screen with text
- Speculos backend: fixed internal snapshot state desync compare screen with text
- backend: add missing tick_timeout argument from physical backends
- firmware: stax: move
UseCaseSettings.previous
fromBUTTON_LOWER_MIDDLE
toBUTTON_LOWER_LEFT
- conftest: Integrating Rust application binary paths
- conftest:
APP_DIR
andLOAD_MAIN_APP_AS_LIBRARY
are replaced by the optional parameterMAIN_APP_DIR
. - firmware: stax: positions: Update settings exit for new SDK v15.2.0
- navigator:
BaseNavInsID
allows to create customNavInsID
while usingNavigator
methods without additional type conversion. - backend: Add optional argument to allow timeout in apdu exchange functions with default value of 5 minutes
- Fix search tree for main app binary in library mode
- Update search tree for main app binary in library mode
- Removing the
frozen
attribute forExceptionRAPDU
dataclass, as Python3.11contextlib
needs the exception class it throws to be RW.
- Update Ragger dependency versions (Speculos, LedgerComm, ledgerCTL), so that it can leverage recent features.
- Batch generator with the
SpeculosBackend:batch
methods which allows to spawn several Speculos client of the same app, with (if needed) different seed, RNG and/or attestation or user keys.
- SpeculosBackend: Removing
host
andport
arguments, as they were modifying the client behavior, but not the server, so this feature probably never worked. The port can be changed through Speculos arguments:args=["--api-port", "9876"]
.
- interface: Adding RAISE_CUSTOM raise policy to allow custom definition of white-listed status.
- conftest: Add support for plugin testing
- backend/speculos - navigator: Allow navigation screen content comparison with regex.
- Requirements: Fail due to missing pytesseract only if really needed.
- CI: Remove CI job dependency to allow deployment if wanted
- Dependency: Update needed Speculos version
- firmware:use_case: Increase confirm time to 2.4 sec following SDK change
- base conftest : hotfix option "all_nano"
- base conftest : add an "all_nano" option for the device parameter
- physical backend gui : do not try to kill GUI process if it is not alive (causes error).
- firmware: Adding a proxy
Firmware.device
property to ensure retro-compatibility with olderFirmware
usages. Previous change was breaking a lot of code.
- firmware: Removing the firmware version mechanism: as the device / version is embedded into each application ELF, Speculos alone can figure out how to emulate a device. Besides this, the version mechanism was only useful for the Stax graphical multi-version retrocompatibility, which is a niche usage not worth the complexity of the whole mechanism. Firmware is now an enum listing the currently supported devices (NanoS, NanoS+, NanoX and Stax).
- navigator: Restore
NavInsID.USE_CASE_REVIEW_CONFIRM
custom wait for screen change for cases where the app callio_seproxyhal_io_heartbeat()
before next screen is displayed.
- speculos: Only pause ticker during navigation steps
- speculos: Default touch duration changed from 0.5sec to 0.1sec
- speculos: Control the ticker allowing to avoid any race issue when comparing screen and accessing OCR result
- speculos: Bump minimal speculos version to 0.2.5
- import: Fix from 1.8.1 was not wide enough. Exception was filtered on 'QtCore', but they could also throw as 'QtWidgets'.
- import: Feature developed in this branch forced all Ragger installation to have PyQt5 and its dependencies installed. This is no longer the case.
- backend: Physical backends (
LedgerComm
,LedgerWallet
) can now pop a GUI in order to guide a user performing tests on a physical device.
- package: Version is not longer hardcoded in sources, but inferred from tag then bundled into the
package thanks to
setuptools_scm
- configuration: Add a mechanism to specify the app dir where Speculos should search for the directory that holds the application compilation artifacts.
- backend: StubBackend
- backend: Add a mechanism to survive USB stack reboot (
handle_usb_reset()
) - backend: ledgerwallet/ledgercomm: Add a mechanism to check appname and open app at backend instantiation
- backend: Drop double logging of RAPDU on LedgerCommBackend and LedgerWalletBackend
- conftest: Set navigator fixture scope to backend one
- backend: Add
wait_for_home_screen()
,wait_for_text_on_screen()
andwait_for_text_not_on_screen()
. - navigator: Add
WAIT_FOR_SCREEN_CHANGE
,WAIT_FOR_HOME_SCREEN
,WAIT_FOR_TEXT_ON_SCREEN
andWAIT_FOR_TEXT_NOT_ON_SCREEN
instructions.
- backend: speculos: Based
wait_for_screen_change()
on screenshot comparison where it was previously based on OCR content. - backend: speculos: Remove internal screen content reference update from
get_current_screen_content()
. - navigator: Add a call to
wait_for_screen_change()
innavigate()
similarly to what is done innavigate_and_compare()
. - navigator: Remove
USE_CASE_STATUS_WAIT
instruction, it should be replaced byUSE_CASE_STATUS_WAIT
.
- navigator: Sanitize the behavior of
USE_CASE_REVIEW_CONFIRM
navigation instruction.
- navigator: Add USE_CASE_STATUS_DISMISS, this allows to dismiss the status instead of waiting for its end with USE_CASE_STATUS_WAIT.
- conftest: add configuration and pytest options that allow a custom seed to be used for speculos.
- Dependency: Use speculos>=0.1.224 to avoid issues when running in slow setup.
- backend: speculos.py: Strip empty text events from Speculos. This avoid false detection of screen change in navigation.
- conftest: new module that provides a base_conftest for unifying conftest features
- tests: the existing tests now use the new conftest module
- CI: the CI now uses the reusable workflows for boilerplate compilation
- tests: all tests are passing for Stax
- misspelling fixes and new CI
- template: conftest.py: Target nanosp release 1.0.4 which is now supported by speculos
- backend: speculos.py: Do not pass
--sdk
argument anymore, this enforce using either last speculos supported SDK or app elf file with metadata. - template: conftest.py/usage.md: Enable full Stax support
- Dependency: Use ledgerwallet>=0.2.3 to fix protobuff version issues
- Dependency: Use speculos>=0.1.202 to enable support for Last Stax firmware
- firmware/stax: Classes using
MetaScreen
can now declare their own__init__
without it being overridden
- backend/speculos : improved reliability of wait_for_screen_change
- firmware/stax : the "Suggestions" positions are shifted by Y+75px in order to fit with BOLOS suggestion buttons, which are under the typing text area, not above.
- navigator: Don't clean already existing snapshots when running
navigate_and_compare()
throughnavigate_until_text_and_compare()
.
- template: conftest.py: Use session scope for firmware and backend fixtures
- template: conftest.py: Targeted device must be specified with new
--device
required option. - unified naming of the Ledger Stax product: from
fat
orfatstacks
to stax
- requirements: Removed the dependency on protobuf package
- conftest:
--log_apdu_file <filename>
option - firmware:
Firmware:have_bagl
andFirmware:have_nbgl
properties indicates which graphical interface the firmware implements. - navigator: Add USE_CASE_ADDRESS_CONFIRMATION_TAP
- navigator:
add_callback()
method to register callbacks after Navigator initialization
- navigator:
NavIns
arguments ofnavigate()
and higher-level methods can now also beNavInsID
, which will automatically be converted toNavIns
(with no argument for the callback)
- Fatstacks
UseCaseHomeExt
- navigator: Improve navigation by waiting screen changes instead of hardcoded sleeps
- navigator:
navigate_and_compare()
: add optional snap_start_idx parameter - navigator:
navigate_until_text()
: take a list of validation instructions and check last screen
- Initial version