Merge pull request #10700 from gilles-peskine-arm/python-project-knowledge-directory-mbedtls-dev

Create Python project knowledge directory
This commit is contained in:
Ronald Cron
2026-05-12 13:38:23 +00:00
committed by GitHub
5 changed files with 36 additions and 26 deletions
+1 -1
View File
@@ -1,4 +1,4 @@
[mypy] [mypy]
mypy_path = framework/scripts:scripts mypy_path = framework/scripts:scripts:tf-psa-crypto/scripts/project_knowledge
namespace_packages = True namespace_packages = True
warn_unused_configs = True warn_unused_configs = True
+1 -1
View File
@@ -1,5 +1,5 @@
[MASTER] [MASTER]
init-hook='import sys; sys.path.append("scripts"); sys.path.append("framework/scripts")' init-hook='import sys; sys.path += ["scripts", "framework/scripts", "tf-psa-crypto/scripts/project_knowledge"]'
min-similarity-lines=10 min-similarity-lines=10
[BASIC] [BASIC]
+3
View File
@@ -15,3 +15,6 @@ import sys
sys.path.append(os.path.join(os.path.dirname(__file__), sys.path.append(os.path.join(os.path.dirname(__file__),
os.path.pardir, os.path.pardir,
'framework', 'scripts')) 'framework', 'scripts'))
sys.path.append(os.path.join(os.path.dirname(__file__),
os.path.pardir,
'tf-psa-crypto', 'scripts', 'project_knowledge'))
+28 -24
View File
@@ -14,23 +14,21 @@ import importlib.machinery
import importlib.util import importlib.util
import os import os
import re import re
import sys
import types
import typing import typing
import scripts_path # pylint: disable=unused-import import scripts_path # pylint: disable=unused-import
from mbedtls_framework import outcome_analysis from mbedtls_framework import outcome_analysis
from mbedtls_framework import typing_util
# Until all TF-PSA-Crypto branches we care about have
class CryptoAnalyzeOutcomesType(typing_util.Protocol): # scripts/project_knowledge/tf_psa_crypto_test_case_info.py,
"""Our expectations on tf-psa-crypto/tests/scripts/tf_psa_crypto_test_case_info.py. # fall back to its previous location where we load it manually
# (see the _load_crypto_module method below).
See CoverageTask._load_crypto_module(). try:
""" import tf_psa_crypto_test_case_info #type: ignore #pylint: disable=unused-import
#pylint: disable=too-few-public-methods except ImportError:
pass
# Test cases that are about internal aspects of TF-PSA-Crypto,
# which Mbed TLS is therefore not required to cover.
INTERNAL_TEST_CASES: outcome_analysis.TestCaseSetDescription
class CoverageTask(outcome_analysis.CoverageTask): class CoverageTask(outcome_analysis.CoverageTask):
@@ -224,33 +222,39 @@ class CoverageTask(outcome_analysis.CoverageTask):
], ],
} }
def _load_crypto_module(self) -> None: @staticmethod
def _load_crypto_module() -> typing.Optional[types.ModuleType]:
"""Try to load the information about test cases from the tf-psa-crypto submodule..""" """Try to load the information about test cases from the tf-psa-crypto submodule.."""
# All this complexity is because we don't want to add the directory # All this complexity is because we didn't want to add
# to the import path. # `tf-psa-crypto/tests/scripts/` to the import path.
if self.crypto_module is not None: # The new location `tf-psa-crypto/scripts/project_knowledge` is
return # on the import path. So once we can assume that all crypto
# branches have the new location, this whole function can go away.
# https://github.com/Mbed-TLS/mbedtls/issues/10699.
if 'tf_psa_crypto_test_case_info' in sys.modules:
return sys.modules['tf_psa_crypto_test_case_info']
crypto_script_path = 'tf-psa-crypto/tests/scripts/tf_psa_crypto_test_case_info.py' crypto_script_path = 'tf-psa-crypto/tests/scripts/tf_psa_crypto_test_case_info.py'
if not os.path.exists(crypto_script_path): if not os.path.exists(crypto_script_path):
# During a transition period, while the crypto script is not # During a transition period, while the crypto script is not
# yet present in all branches we care about, allow it not to # yet present in all branches we care about, allow it not to
# exist. # exist.
return return None
crypto_spec = importlib.util.spec_from_file_location( crypto_spec = importlib.util.spec_from_file_location(
'tf_psa_crypto_test_case_info', 'tf_psa_crypto_test_case_info',
crypto_script_path) crypto_script_path)
# Assertions and type annotation to help mypy. # Assertions and type annotation to help mypy.
assert crypto_spec is not None assert crypto_spec is not None
assert crypto_spec.loader is not None assert crypto_spec.loader is not None
self.crypto_module: typing.Optional[CryptoAnalyzeOutcomesType] = \ crypto_module = importlib.util.module_from_spec(crypto_spec)
importlib.util.module_from_spec(crypto_spec) crypto_spec.loader.exec_module(crypto_module)
crypto_spec.loader.exec_module(self.crypto_module) sys.modules['tf_psa_crypto_test_case_info'] = crypto_module
return crypto_module
def _load_crypto_instructions(self) -> None: def _load_crypto_instructions(self) -> None:
"""Try to load instructions from the tf-psa-crypto submodule's outcome analysis.""" """Try to load instructions from the tf-psa-crypto submodule's outcome analysis."""
self._load_crypto_module() crypto_module = self._load_crypto_module()
if self.crypto_module is not None: if crypto_module is not None:
crypto_internal_test_cases = self.crypto_module.INTERNAL_TEST_CASES crypto_internal_test_cases = crypto_module.INTERNAL_TEST_CASES
else: else:
# Legacy set of tests covered by TF-PSA-Crypto only, # Legacy set of tests covered by TF-PSA-Crypto only,
# from before Mbed TLS's outcome analysis read that information # from before Mbed TLS's outcome analysis read that information
+3
View File
@@ -18,3 +18,6 @@ sys.path.append(os.path.join(os.path.dirname(__file__),
sys.path.append(os.path.join(os.path.dirname(__file__), sys.path.append(os.path.join(os.path.dirname(__file__),
os.path.pardir, os.path.pardir, os.path.pardir, os.path.pardir,
'framework', 'scripts')) 'framework', 'scripts'))
sys.path.append(os.path.join(os.path.dirname(__file__),
os.path.pardir, os.path.pardir,
'tf-psa-crypto', 'scripts', 'project_knowledge'))