From 696b7eef7b2797aae29a9869dfa7ce09b01bb68d Mon Sep 17 00:00:00 2001 From: Gilles Peskine Date: Thu, 11 Apr 2024 11:17:58 +0200 Subject: [PATCH] TestCase: add mechanism to skip a test case Allow "skipping" a test case, meaning that the test case is generated commented out. This is useful when systematically generating test cases according to certain rules, where some generated tests cannot be executed but we still want them to be visible when auditing the generation output. Signed-off-by: Gilles Peskine --- scripts/mbedtls_dev/test_case.py | 30 +++++++++++++++++++++++++++--- 1 file changed, 27 insertions(+), 3 deletions(-) diff --git a/scripts/mbedtls_dev/test_case.py b/scripts/mbedtls_dev/test_case.py index 6ed5e849de..db7b8a501c 100644 --- a/scripts/mbedtls_dev/test_case.py +++ b/scripts/mbedtls_dev/test_case.py @@ -31,6 +31,7 @@ class TestCase: self.dependencies = [] #type: List[str] self.function = None #type: Optional[str] self.arguments = [] #type: List[str] + self.skip_reason = '' def add_comment(self, *lines: str) -> None: self.comments += lines @@ -47,6 +48,23 @@ class TestCase: def set_arguments(self, arguments: List[str]) -> None: self.arguments = arguments + def skip_because(self, reason: str) -> None: + """Skip this test case. + + It will be included in the output, but commented out. + + This is intended for test cases that are obtained from a + systematic enumeration, but that have dependencies that cannot + be fulfilled. Since we don't want to have test cases that are + never executed, we arrange not to have actual test cases. But + we do include comments to make it easier to understand the output + of test case generation. + + reason must be a non-empty string explaining to humans why this + test case is skipped. + """ + self.skip_reason = reason + def check_completeness(self) -> None: if self.description is None: raise MissingDescription @@ -67,10 +85,16 @@ class TestCase: out.write('\n') for line in self.comments: out.write('# ' + line + '\n') - out.write(self.description + '\n') + prefix = '' + if self.skip_reason: + prefix = '## ' + out.write('## # skipped because: ' + self.skip_reason + '\n') + out.write(prefix + self.description + '\n') if self.dependencies: - out.write('depends_on:' + ':'.join(self.dependencies) + '\n') - out.write(self.function + ':' + ':'.join(self.arguments) + '\n') + out.write(prefix + 'depends_on:' + + ':'.join(self.dependencies) + '\n') + out.write(prefix + self.function + ':' + + ':'.join(self.arguments) + '\n') def write_data_file(filename: str, test_cases: Iterable[TestCase],