Port 'test_configuration_cmd' from 'speculos' to 'ragger'

This commit is contained in:
Charles-Edouard de la Vergne
2024-03-25 14:47:53 +01:00
parent 140ecc75fb
commit 6e477717de
2 changed files with 48 additions and 3 deletions

View File

@@ -0,0 +1,48 @@
from pathlib import Path
from typing import List
import re
from ragger.backend import BackendInterface
from ragger.utils.misc import get_current_app_name_and_version
def test_check_version(backend: BackendInterface):
"""Check version and name"""
# Send the APDU
app_name, version = get_current_app_name_and_version(backend)
print(f" Name: {app_name}")
print(f" Version: {version}")
_verify_version(version.split("-")[0])
def _verify_version(version: str) -> None:
"""Verify the app version, based on defines in Makefile
Args:
Version (str): Version to be checked
"""
vers_dict = {}
vers_str = ""
lines = _read_makefile()
version_re = re.compile(r"^APPVERSION_(?P<part>\w)\s?=\s?(?P<val>\d*)", re.I)
for line in lines:
info = version_re.match(line)
if info:
dinfo = info.groupdict()
vers_dict[dinfo["part"]] = dinfo["val"]
try:
vers_str = f"{vers_dict['M']}.{vers_dict['N']}.{vers_dict['P']}"
except KeyError:
pass
assert version == vers_str
def _read_makefile() -> List[str]:
"""Read lines from the parent Makefile """
parent = Path(__file__).parent.parent.parent.resolve()
makefile = f"{parent}/Makefile"
with open(makefile, "r", encoding="utf-8") as f_p:
lines = f_p.readlines()
return lines

View File

@@ -1,3 +0,0 @@
def test_configuration(cmd):
assert cmd.get_configuration() == (2, 1, 11, 0)