Lines Matching +full:pytest +full:- +full:twister +full:- +full:harness

1 # SPDX-License-Identifier: Apache-2.0
19 from pytest import ExitCode
28 logger = logging.getLogger('twister')
34 class Harness: class
71 def trace(self) -> bool:
75 def status(self) -> TwisterStatus:
79 def status(self, value : TwisterStatus) -> None:
113 def translate_record(self, record: dict) -> dict:
121 logger.warning(f"HARNESS:{self.__class__.__name__}: recording JSON failed:"
123 # Don't set the Harness state to failed for recordings.
127 def parse_record(self, line) -> re.Match:
169 class Robot(Harness):
183 ''' Test cases that make use of this harness care about results given
218 self.instance.execution_time = time.time() - start_time
238 class Console(Harness):
244 Console Harness id has only TestSuite id without TestCase name suffix.
246 a single test case is configured to use this harness type for simplified
247 output parsing instead of the Ztest harness as Ztest suite should do.
260 f"HARNESS:{self.__class__.__name__}:no regex patterns configured."
276 f"HARNESS:{self.__class__.__name__}:incorrect type={self.type}"
284 logger.debug(f"HARNESS:{self.__class__.__name__}:EXPECTED:"
291 logger.debug(f"HARNESS:{self.__class__.__name__}:EXPECTED("
302 logger.debug(f"HARNESS:{self.__class__.__name__}:EXPECTED("
329 logger.error(f"HARNESS:{self.__class__.__name__}: failed with"
337 logger.error(f"HARNESS:{self.__class__.__name__}: failed with"
351 """General exception for pytest."""
354 class Pytest(Harness): class
382 pytest_root = config.get('pytest_root', ['pytest']) if config else ['pytest']
386 'pytest',
387 '--twister-harness',
388 '-s', '-v',
389 f'--build-dir={self.running_dir}',
390 f'--junit-xml={self.report_file}',
391 '--log-file-level=DEBUG',
392 '--log-file-format=%(asctime)s.%(msecs)03d:%(levelname)s:%(name)s: %(message)s',
393 f'--log-file={self.pytest_log_file_path}',
394 f'--platform={self.instance.platform.name}'
400 command.append(f'--dut-scope={pytest_dut_scope}')
402 # Always pass output from the pytest test and the test image up to Twister log.
404 '--log-cli-level=DEBUG',
405 '--log-cli-format=%(levelname)s: %(message)s'
408 # Use the test timeout as the base timeout for pytest
410 command.append(f'--base-timeout={base_timeout}')
417 command.append(f'--device-type={handler.type_str}')
419 command.append('--device-type=custom')
427 command.append(f'--twister-fixture={fixture}')
430 command.append(f'--extra-test-args={shlex.join(handler.options.extra_test_args)}')
440 command = ['--device-type=hardware']
449 command.append(f'--device-serial-pty={hardware.serial_pty}')
452 f'--device-serial={hardware.serial}',
453 f'--device-serial-baud={hardware.baud}'
457 command.append(f'--flash-timeout={hardware.flash_timeout}')
461 command.append(f'--runner={runner}')
465 command.append(f'--runner-params={param}')
468 command.append(f'--west-flash-extra-args={options.west_flash}')
471 command.append(f'--device-id={board_id}')
474 command.append(f'--device-product={hardware.product}')
477 command.append(f'--pre-script={hardware.pre_script}')
480 command.append(f'--post-flash-script={hardware.post_flash_script}')
483 command.append(f'--post-script={hardware.post_script}')
486 command.append(f'--flash-before={hardware.flash_before}')
489 command.append(f'--twister-fixture={fixture}')
509 self.instance.reason = 'Pytest timeout'
518 self.instance.reason = f'Pytest error - return code {proc.returncode}'
527 pytest by update PYTHONPATH and append -p argument to pytest command.
531 cmd.extend(['-p', 'twister_harness.plugin'])
536 'pytest-twister-harness',
549 logger.debug(f'Running pytest command: {cmd_to_print}')
560 logger.debug(f'PYTEST: {line}')
579 self.instance.reason = self.instance.reason or 'Pytest failed'
590 f"{elem_ts.get('failures')}/{elem_ts.get('tests')} pytest scenario(s) failed"
594 self.instance.reason = 'Error during pytest execution'
621 class Gtest(Harness):
622 ANSI_ESCAPE = re.compile(r'\x1B(?:[@-Z\\-_]|\[[0-?]*[ -/]*[@-~])')
623 _NAME_PATTERN = "[a-zA-Z_][a-zA-Z0-9_]*"
631 + "\\[----------\\] Global test environment tear-down)"
662 # Check that the instance doesn't exist yet (prevents re-running)
733 class Test(Harness):
734 __test__ = False # for pytest to skip this class when collects tests
740 test_case_start_pattern = re.compile(r"START - (test_)?([a-zA-Z0-9_-]+)")
742 r".*(PASS|FAIL|SKIP) - (test_)?(\S*) in (\d*[.,]?\d*) seconds"
745 r"SUITE (?P<suite_status>\S*) - .* \[(?P<suite_name>\S*)\]:"
749 r" - (PASS|FAIL|SKIP) - \[([^\.]*).(test_)?(\S*)\] duration = (\d*[.,]?\d*) seconds"
810 self.started_suites[suite_name]['count'] -= 1
813 self.started_suites[suite_name]['count'] -= 1
835 self.started_cases[tc_name]['count'] -= 1
916 class Bsim(Harness):
921 running multidevice bsim tests after twister has built them.
929 logger.warning('Cannot copy bsim exe - cannot find original executable.')
934 logger.warning('Cannot copy bsim exe - BSIM_OUT_PATH not provided.')
963 logger.debug(f"harness {harness_name} not implemented: {e}")