mirror of
https://github.com/Mbed-TLS/mbedtls.git
synced 2026-06-05 21:15:16 +00:00
Merge pull request #10700 from gilles-peskine-arm/python-project-knowledge-directory-mbedtls-dev
Create Python project knowledge directory
This commit is contained in:
@@ -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,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]
|
||||||
|
|||||||
@@ -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'))
|
||||||
|
|||||||
@@ -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
|
||||||
|
|||||||
@@ -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'))
|
||||||
|
|||||||
Reference in New Issue
Block a user