Michael Walsh | a2a553c | 2017-01-10 11:17:38 -0600 | [diff] [blame] | 1 | #!/usr/bin/env python |
| 2 | |
| 3 | r""" |
| 4 | This module is the python counterpart to run_keyword.robot. |
| 5 | """ |
| 6 | |
Michael Walsh | edb5c94 | 2019-03-28 12:40:50 -0500 | [diff] [blame] | 7 | import gen_print as gp |
Michael Walsh | a2a553c | 2017-01-10 11:17:38 -0600 | [diff] [blame] | 8 | import gen_robot_valid as grv |
Michael Walsh | 16cbb7f | 2017-02-02 15:54:16 -0600 | [diff] [blame] | 9 | import gen_robot_utils as gru |
| 10 | |
Michael Walsh | a2a553c | 2017-01-10 11:17:38 -0600 | [diff] [blame] | 11 | from robot.libraries.BuiltIn import BuiltIn |
Michael Walsh | e7a7a18 | 2017-01-19 10:37:10 -0600 | [diff] [blame] | 12 | import re |
Michael Walsh | a2a553c | 2017-01-10 11:17:38 -0600 | [diff] [blame] | 13 | |
| 14 | |
Michael Walsh | a2a553c | 2017-01-10 11:17:38 -0600 | [diff] [blame] | 15 | def setup(): |
Michael Walsh | a2a553c | 2017-01-10 11:17:38 -0600 | [diff] [blame] | 16 | r""" |
| 17 | Do general program setup tasks. |
| 18 | """ |
| 19 | |
Michael Walsh | edb5c94 | 2019-03-28 12:40:50 -0500 | [diff] [blame] | 20 | gp.qprintn() |
Michael Walsh | a2a553c | 2017-01-10 11:17:38 -0600 | [diff] [blame] | 21 | |
| 22 | validate_parms() |
| 23 | |
Michael Walsh | edb5c94 | 2019-03-28 12:40:50 -0500 | [diff] [blame] | 24 | gp.qprint_pgm_header() |
Michael Walsh | a2a553c | 2017-01-10 11:17:38 -0600 | [diff] [blame] | 25 | |
Michael Walsh | a2a553c | 2017-01-10 11:17:38 -0600 | [diff] [blame] | 26 | |
Michael Walsh | a2a553c | 2017-01-10 11:17:38 -0600 | [diff] [blame] | 27 | def validate_parms(): |
Michael Walsh | a2a553c | 2017-01-10 11:17:38 -0600 | [diff] [blame] | 28 | r""" |
| 29 | Validate all program parameters. |
| 30 | """ |
| 31 | |
Michael Walsh | e7edb22 | 2019-08-19 17:39:38 -0500 | [diff] [blame] | 32 | grv.valid_value("keyword_string") |
Michael Walsh | a2a553c | 2017-01-10 11:17:38 -0600 | [diff] [blame] | 33 | |
| 34 | return True |
| 35 | |
Michael Walsh | a2a553c | 2017-01-10 11:17:38 -0600 | [diff] [blame] | 36 | |
Michael Walsh | a2a553c | 2017-01-10 11:17:38 -0600 | [diff] [blame] | 37 | def program_teardown(): |
Michael Walsh | a2a553c | 2017-01-10 11:17:38 -0600 | [diff] [blame] | 38 | r""" |
| 39 | Clean up after this program. |
| 40 | """ |
| 41 | |
Michael Walsh | edb5c94 | 2019-03-28 12:40:50 -0500 | [diff] [blame] | 42 | gp.qprint_pgm_footer() |
Michael Walsh | a2a553c | 2017-01-10 11:17:38 -0600 | [diff] [blame] | 43 | |
Michael Walsh | e9d78c4 | 2017-03-02 14:41:15 -0600 | [diff] [blame] | 44 | |
Michael Walsh | e9d78c4 | 2017-03-02 14:41:15 -0600 | [diff] [blame] | 45 | def my_run_keywords(lib_file_path, |
| 46 | keyword_string, |
| 47 | quiet=0, |
| 48 | test_mode=0): |
Michael Walsh | e9d78c4 | 2017-03-02 14:41:15 -0600 | [diff] [blame] | 49 | r""" |
| 50 | Run the keywords in the keyword string. |
| 51 | |
| 52 | Description of arguments: |
| 53 | lib_file_path The path to a library or resource needed to run the |
| 54 | keywords. This may contain a colon-delimited list of |
| 55 | library/resource paths. |
| 56 | keyword_string The keyword string to be run by this function. If this |
| 57 | keyword string contains " ; " anywhere, it will be taken to |
| 58 | be multiple keyword strings. Each keyword may also include |
| 59 | a variable assignment. Example: |
| 60 | ${my_var}= My Keyword |
| 61 | quiet If this parameter is set to "1", this program will print |
| 62 | only essential information, i.e. it will not echo |
| 63 | parameters, echo commands, print the total run time, etc. |
| 64 | test_mode This means that this program should go through all the |
| 65 | motions but not actually do anything substantial. |
| 66 | """ |
| 67 | |
| 68 | # NOTE: During code review the following question was raised: Why support |
| 69 | # 1) variable assignments 2) multiple keywords? Couldn't a user simply |
| 70 | # call this program twice to get what they need. If necessary, the user |
| 71 | # could take the output of the first call and specify it as a literal on |
| 72 | # the second call. |
| 73 | # |
| 74 | # However, this approach would not work in all cases. The following case |
| 75 | # would be such an example: |
| 76 | # Let's say the first keyword string is as follows: |
| 77 | # Create Dictionary foo=bar |
| 78 | # You wish to take the output of that call and specify it as a literal |
| 79 | # value when running the following: |
| 80 | # Want Dictionary parm=<literal dictionary specification> |
| 81 | # The problem is that there is no way to specify a dictionary as a |
| 82 | # literal in Robot Framework. |
| 83 | # By having this program support variable assignments and multiple |
| 84 | # keywords, the user can invoke it with the following keyword string. |
| 85 | # ${my_dict}= Create Dictionary foo=bar ; Want Dictionary ${my_dict} |
| 86 | |
Michael Walsh | e9d78c4 | 2017-03-02 14:41:15 -0600 | [diff] [blame] | 87 | # The user can pass multiple lib/resource paths by separating them with a |
| 88 | # colon. |
| 89 | lib_file_path_list = lib_file_path.split(":") |
| 90 | # Get rid of empty entry if it exists. |
| 91 | if lib_file_path_list[0] == "": |
| 92 | del lib_file_path_list[0] |
| 93 | for lib_file_path in lib_file_path_list: |
| 94 | if lib_file_path.endswith(".py"): |
Michael Walsh | edb5c94 | 2019-03-28 12:40:50 -0500 | [diff] [blame] | 95 | gp.dprint_issuing("import_library(\"" + lib_file_path + "\")") |
Michael Walsh | e9d78c4 | 2017-03-02 14:41:15 -0600 | [diff] [blame] | 96 | BuiltIn().import_library(lib_file_path) |
| 97 | else: |
Michael Walsh | edb5c94 | 2019-03-28 12:40:50 -0500 | [diff] [blame] | 98 | gp.dprint_issuing("my_import_resource(\"" + lib_file_path + "\")") |
Michael Walsh | e9d78c4 | 2017-03-02 14:41:15 -0600 | [diff] [blame] | 99 | gru.my_import_resource(lib_file_path) |
| 100 | |
| 101 | # The user can pass multiple keyword strings by separating them with " ; ". |
| 102 | keyword_list = keyword_string.split(" ; ") |
| 103 | for keyword_string in keyword_list: |
| 104 | cmd_buf = keyword_string.split(" ") |
| 105 | if re.match(r"\$\{", cmd_buf[0]): |
| 106 | # This looks like an assignment (e.g. ${var}= <keyword>). |
| 107 | # We'll extract the variable name, remove element 0 from |
| 108 | # cmd_buf and set the global variable with the results |
| 109 | # after running the keyword. |
| 110 | var_name = cmd_buf[0].strip("${}=") |
| 111 | del cmd_buf[0] |
| 112 | else: |
| 113 | var_name = "" |
| 114 | |
| 115 | if not quiet: |
Michael Walsh | edb5c94 | 2019-03-28 12:40:50 -0500 | [diff] [blame] | 116 | gp.print_issuing(cmd_buf, test_mode) |
Michael Walsh | e9d78c4 | 2017-03-02 14:41:15 -0600 | [diff] [blame] | 117 | if test_mode: |
| 118 | continue |
| 119 | |
| 120 | output = BuiltIn().run_keyword(*cmd_buf) |
| 121 | |
| 122 | if var_name != "": |
| 123 | BuiltIn().set_global_variable("${" + var_name + "}", output) |
| 124 | else: |
| 125 | if output is not None: |
Michael Walsh | edb5c94 | 2019-03-28 12:40:50 -0500 | [diff] [blame] | 126 | gp.gp_print(output) |
Michael Walsh | e9d78c4 | 2017-03-02 14:41:15 -0600 | [diff] [blame] | 127 | |
Michael Walsh | e9d78c4 | 2017-03-02 14:41:15 -0600 | [diff] [blame] | 128 | |
Michael Walsh | e9d78c4 | 2017-03-02 14:41:15 -0600 | [diff] [blame] | 129 | def main_py(): |
Michael Walsh | e9d78c4 | 2017-03-02 14:41:15 -0600 | [diff] [blame] | 130 | r""" |
| 131 | Do main program processing. |
| 132 | """ |
| 133 | |
| 134 | setup() |
| 135 | |
| 136 | lib_file_path = BuiltIn().get_variable_value("${lib_file_path}") |
| 137 | keyword_string = BuiltIn().get_variable_value("${keyword_string}") |
| 138 | quiet = int(BuiltIn().get_variable_value("${quiet}")) |
| 139 | test_mode = int(BuiltIn().get_variable_value("${test_mode}")) |
| 140 | |
| 141 | my_run_keywords(lib_file_path, keyword_string, quiet, test_mode) |