xref: /openbmc/openbmc-test-automation/lib/jobs_processing.py (revision 578f646ed11bc5154b708ca04e019e90b728c253)
1#!/usr/bin/env python3
2
3r"""
4This module contains keyword functions to support multiprocessing
5execution of keywords where generic robot keywords don't support.
6
7"""
8
9from robot.libraries.BuiltIn import BuiltIn
10from multiprocessing import Process, Manager
11import os
12import datetime
13import gen_print as gp
14
15
16def execute_keyword(keyword_name, return_dict):
17    r"""
18    Execute a robot keyword.
19    In addition to running the caller's keyword, this function will:
20    - Add an entry to the return_dict
21
22    Description of argument(s):
23    keyword_name    Keyword name to be executed.
24    return_dict     A dictionary consisting of pid/process status for the
25                    keys/values. This function will append a new entry to
26                    this dictionary.
27    """
28
29    pid = os.getpid()
30    status = BuiltIn().run_keyword_and_return_status(keyword_name)
31
32    # Build PID:<status> dictionary.
33    return_dict[str(pid)] = str(status)
34
35
36def execute_process(num_process, keyword_name):
37    r"""
38    Execute a robot keyword via multiprocessing process.
39
40    Description of argument(s):
41    num_process         Number of times keyword to be executed.
42    keyword_name     Keyword name to be executed.
43    """
44
45    manager = Manager()
46    return_dict = manager.dict()
47    process_list = []
48
49    # Append user-defined times process needed to execute.
50    for ix in range(int(num_process)):
51        task = Process(target=execute_keyword,
52                       args=(keyword_name, return_dict))
53        process_list.append(task)
54        task.start()
55
56    # Wait for process to complete.
57    for task in process_list:
58        task.join()
59
60    # Return function return codes.
61    return return_dict
62
63
64def execute_keyword_args(keyword_name, args, return_dict):
65    r"""
66    Execute a robot keyword with arguments.
67    In addition to running the caller's keyword, this function will:
68    - Add an entry to the return_dict
69    Description of argument(s):
70    keyword_name    Keyword name to be executed.
71    args            Arguments to keyword.
72    return_dict     A dictionary consisting of pid/process status for the
73                    keys/values. This function will append a new entry to
74                    this dictionary.
75    """
76
77    execution_time = datetime.datetime.now()
78
79    status = BuiltIn().run_keyword_and_return_status(keyword_name, *args)
80
81    # Build execution time:<status> dictionary.
82    return_dict[str(execution_time)] = str(status)
83
84
85def execute_process_multi_keyword(number_args, *keyword_names):
86    r"""
87    Execute multiple robot keywords with arguments via multiprocessing process.
88
89    Description of argument(s):
90    number_args       Number of argument in keywords.
91    keyword_names     Keyword name to be executed.
92    """
93
94    manager = Manager()
95    return_dict = manager.dict()
96    process_list = []
97    # Append each keyword with its arguments in a process to execute.
98    for keywords_data in keyword_names:
99        keyword_args = tuple(keywords_data.split(" ")[-number_args:])
100        keyword_name = " ".join(keywords_data.split(" ")[:-number_args])
101        task = Process(target=execute_keyword_args,
102                       args=(keyword_name, keyword_args, return_dict))
103        process_list.append(task)
104        task.start()
105
106    # Wait for process to complete.
107    for task in process_list:
108        task.join()
109    return return_dict
110
111
112def get_current_date_time():
113    r"""
114    Gets current time.
115    """
116
117    current_time = datetime.datetime.now().strftime("%H:%M:%S.%f")
118    return current_time
119