| 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) |