test/framework/runner/scripts/test_executor.py
jpike b1c33161c9 Updating the test executor to use resource finder for test path
Need to correctly find the abs path of the test

Change-Id: Id7a0af3dac8ae9c4fa3e19bbcda7ae24112dbf3c
2024-12-03 10:46:39 -05:00

122 lines
4.3 KiB
Python

from optparse import OptionParser
import pytest
from config.configuration_file_locations_manager import ConfigurationFileLocationsManager
from config.configuration_manager import ConfigurationManager
from framework.database.objects.testcase import TestCase
from framework.database.operations.run_content_operation import RunContentOperation
from framework.database.operations.run_operation import RunOperation
from framework.database.operations.test_plan_operation import TestPlanOperation
from framework.logging.automation_logger import get_logger
from framework.pytest_plugins.result_collector import ResultCollector
from framework.resources.resource_finder import get_stx_resource_path
from framework.runner.objects.test_capability_matcher import TestCapabilityMatcher
from framework.runner.objects.test_executor_summary import TestExecutorSummary
from testcases.conftest import log_configuration
def execute_test(test: TestCase, test_executor_summary: TestExecutorSummary, test_case_result_id: int = None):
"""
Executes a test
Args:
test_executor_summary ():
test (): the test to run
test_case_result_id (): if one is given, update that result instead of creating a new one
Returns:
"""
result_collector = ResultCollector(test_executor_summary, test, test_case_result_id)
pytest_args = ConfigurationManager.get_config_pytest_args()
pytest_args.append(get_stx_resource_path(f'testcases/{test.get_pytest_node_id()}'))
pytest.main(pytest_args, plugins=[result_collector])
def log_summary(test_executor_summary: TestExecutorSummary):
"""
Logs the test summary
Args:
test_executor_summary (): the summary object containing the results
Returns:
"""
get_logger().log_info("")
get_logger().log_info("")
get_logger().log_info("Results Summary:")
for summary_line in test_executor_summary.get_tests_summary():
get_logger().log_info(summary_line)
get_logger().log_info("")
get_logger().log_info(f"Logs Path: {ConfigurationManager.get_logger_config().get_log_location()}")
def main():
"""
Given the lab configuration, it will run all tests in the given folder that matches the lab capabilities
Returns:
"""
parser = OptionParser()
parser.add_option(
'--tests_location',
action='store',
type='str',
dest='tests_location',
help='the location of the tests',
)
parser.add_option(
'--test_plan_id',
action='store',
type='str',
dest='test_plan_id',
help='the test plan id of the tests to run',
)
parser.add_option('--test_case_result_id', action='store', type='int', dest='test_case_result_id', help='the id for the testcase result')
configuration_locations_manager = ConfigurationFileLocationsManager()
configuration_locations_manager.set_configs_from_options_parser(parser)
ConfigurationManager.load_configs(configuration_locations_manager)
log_configuration()
options, args = parser.parse_args()
test_case_result_id = None
if options.test_case_result_id:
test_case_result_id = options.test_case_result_id
test_capability_matcher = TestCapabilityMatcher(ConfigurationManager.get_lab_config())
if ConfigurationManager.get_database_config().use_database() and not test_case_result_id:
if not options.test_plan_id:
raise "You must specify a --test_plan_id that points to the test plan to run from"
test_plan = TestPlanOperation().get_test_plan(options.test_plan_id)
run_id = RunOperation().create_run(test_plan.get_test_plan_name(), test_plan.get_run_type_id(), "24.09") # need to decide on where this comes from
RunContentOperation().create_run_content(options.test_plan_id, run_id)
tests = test_capability_matcher.get_list_of_tests_from_db(run_id)
else:
if not options.tests_location:
raise "You must specify a --tests_location that points to the folder for the tests"
tests = test_capability_matcher.get_list_of_tests(options.tests_location)
test_executor_summary = TestExecutorSummary()
for test in tests:
execute_test(test, test_executor_summary, test_case_result_id)
log_summary(test_executor_summary)
if __name__ == '__main__':
"""
Main Launcher
"""
main()