#!/usr/bin/env python3 # Copyright (c) 2024 Intel Corporation # # SPDX-License-Identifier: Apache-2.0 """ Blackbox tests for twister's command line functions related to disable features. """ import importlib import pytest import mock import os import sys import re from conftest import ZEPHYR_BASE, TEST_DATA, testsuite_filename_mock from twisterlib.testplan import TestPlan @mock.patch.object(TestPlan, 'TESTSUITE_FILENAME', testsuite_filename_mock) class TestDisable: TESTDATA_1 = [ ( os.path.join(TEST_DATA, 'tests', 'dummy', 'agnostic'), ['qemu_x86'], '--disable-suite-name-check', [r"Expected suite names:\[['\w+'\[,\s]*\]", r"Detected suite names:\[['\w+'\[,\s]*\]"], True ), ( os.path.join(TEST_DATA, 'tests', 'dummy', 'agnostic'), ['qemu_x86'], '-v', [r"Expected suite names:\[['(\w+)'[, ]*]+", r"Detected suite names:\[['(\w+)'[, ]*]+"], False ), ] TESTDATA_2 = [ ( os.path.join(TEST_DATA, 'tests', 'always_warning'), ['qemu_x86'], '--disable-warnings-as-errors', '0' ), ( os.path.join(TEST_DATA, 'tests', 'always_warning'), ['qemu_x86'], '-v', '1' ), ] @classmethod def setup_class(cls): apath = os.path.join(ZEPHYR_BASE, 'scripts', 'twister') cls.loader = importlib.machinery.SourceFileLoader('__main__', apath) cls.spec = importlib.util.spec_from_loader(cls.loader.name, cls.loader) cls.twister_module = importlib.util.module_from_spec(cls.spec) @classmethod def teardown_class(cls): pass @pytest.mark.parametrize( 'test_path, test_platforms, flag, expected, expected_none', TESTDATA_1, ids=[ 'disable-suite-name-check', 'suite-name-check' ], ) def test_disable_suite_name_check(self, capfd, out_path, test_path, test_platforms, flag, expected, expected_none): args = ['-i', '--outdir', out_path, '-T', test_path] + \ [flag] + \ ['-vv'] + \ [val for pair in zip( ['-p'] * len(test_platforms), test_platforms ) for val in pair] with mock.patch.object(sys, 'argv', [sys.argv[0]] + args), \ pytest.raises(SystemExit) as sys_exit: self.loader.exec_module(self.twister_module) out, err = capfd.readouterr() sys.stdout.write(out) sys.stderr.write(err) assert str(sys_exit.value) == '0' if expected_none: assert re.search(expected[0], err) is None, f"Not expected string in log: {expected[0]}" assert re.search(expected[1], err) is None, f"Not expected: {expected[1]}" else: assert re.search(expected[0], err) is not None, f"Expected string in log: {expected[0]}" assert re.search(expected[1], err) is not None, f"Expected string in log: {expected[1]}" @pytest.mark.parametrize( 'test_path, test_platforms, flag, expected_exit_code', TESTDATA_2, ids=[ 'disable-warnings-as-errors', 'warnings-as-errors' ], ) def test_disable_warnings_as_errors(self, capfd, out_path, test_path, test_platforms, flag, expected_exit_code): args = ['-i', '--outdir', out_path, '-T', test_path] + \ [flag] + \ ['-vv'] + \ ['--build-only'] + \ [val for pair in zip( ['-p'] * len(test_platforms), test_platforms ) for val in pair] with mock.patch.object(sys, 'argv', [sys.argv[0]] + args), \ pytest.raises(SystemExit) as sys_exit: self.loader.exec_module(self.twister_module) out, err = capfd.readouterr() sys.stdout.write(out) sys.stderr.write(err) assert str(sys_exit.value) == expected_exit_code, \ f"Twister return not expected ({expected_exit_code}) exit code: ({sys_exit.value})"