| #!/usr/bin/env python | 
 |  | 
 | r""" | 
 | This module contains utility and wrapper functions useful to robot python | 
 | programs. | 
 | """ | 
 |  | 
 | import re | 
 | from robot.libraries.BuiltIn import BuiltIn | 
 |  | 
 |  | 
 | def my_import_resource(path): | 
 |     r""" | 
 |     Import the resource file specified in path. | 
 |  | 
 |     Description of arguments: | 
 |     path   The path to your resource file. | 
 |  | 
 |     This function is a wrapper for BuiltIn().import_resource() and provides | 
 |     the following benefits: | 
 |     - When you invoke a robot program from a command line, you may specify | 
 |       program parameters as follows: | 
 |  | 
 |       -v --variable name:values | 
 |  | 
 |       For example: | 
 |  | 
 |       robot -v parm_x:1 file_x.robot | 
 |  | 
 |       When you do "Resource utils_x.robot" in a .robot program, it processes | 
 |       "utils_x.robot" BEFORE your command line parms are processed, as one | 
 |       might expect.  On the other hand, if one of your python library files | 
 |       were to run BuiltIn().import_resource("utils_x.robot"), it will process | 
 |       "utils_x.robot" AFTER your program parms are processed.  Let's suppose | 
 |       that utils_x.robot contains the following: | 
 |  | 
 |       *** Variables *** | 
 |       ${parm_x}  ${0} | 
 |  | 
 |       If your program is invoked like this: | 
 |  | 
 |       robot -v parm_x:3 file_x.robot | 
 |  | 
 |       And if your program has a python library file that invokes | 
 |       BuiltIn().import_resource("utils_x.robot"), then parm_x will get set to | 
 |       ${0}.  In other words, instead of utils_x.robot serving to set a default | 
 |       value for parm_x, it actually causes the user's specification of | 
 |       "-v parm_x:3" to be overwritten. | 
 |  | 
 |       This function will remedy that problem by keeping your -v parms intact. | 
 |  | 
 |     - The problems with -v parms mentioned above are also found with variables | 
 |       from your file_x.robot "** Variables **" section.  Namely, they may get | 
 |       overwritten when import_resource() is used.  This function will likewise | 
 |       remedy that problem. | 
 |  | 
 |     """ | 
 |  | 
 |     # Retrieve the values of all current variables into a dictionary. | 
 |     pre_var_dict = BuiltIn().get_variables() | 
 |     # Do the import. | 
 |     BuiltIn().import_resource(path) | 
 |     # Once again, retrieve the values of all current variables into a | 
 |     # dictionary. | 
 |     post_var_dict = BuiltIn().get_variables() | 
 |  | 
 |     # If any variable values were changed due to the prior import, set them | 
 |     # back to their original values. | 
 |     for key, value in post_var_dict.items(): | 
 |         if key in pre_var_dict: | 
 |             if value != pre_var_dict[key]: | 
 |                 global_var_name = re.sub("[@&]", "$", key) | 
 |                 BuiltIn().set_global_variable(global_var_name, | 
 |                                               pre_var_dict[key]) |