from analysis.generaterobotdata import GenerateRobotData from json import dump from sys import argv from os.path import dirname, exists from os import makedirs, walk def create_json_of_robotfile(robot_file_to_be_processed: str, computestatistics: bool=False): folder_test_suites = dirname(dirname(__file__)) folder_result_path = f'{folder_test_suites}/doc/results' result_file = f'{folder_result_path}/{robot_file_to_be_processed}.json' robot_path_to_be_processed, robot_file = find_robot_file(basedir=folder_test_suites, filename=robot_file_to_be_processed) # Check that the folder '/results' exists and if not, create it if not exists(folder_result_path): makedirs(folder_result_path) if computestatistics: try: data = GenerateRobotData(robot_file=robot_file, execdir=folder_test_suites) data.parse_robot() info = data.get_info() except Exception as e: print("WHILE GENERATING ROBOT DATA:", e) info = dict() info["error_while_parsing"] = True info["robotfile"] = robot_file_to_be_processed if(robot_path_to_be_processed.startswith("/")): robot_path_to_be_processed = robot_path_to_be_processed[1:] info["robotpath"] = robot_path_to_be_processed else: data = GenerateRobotData(robot_file=robot_file, execdir=folder_test_suites) data.parse_robot() info = data.get_info() with open(result_file, 'w') as fp: dump(obj=info, indent=2, fp=fp) return info def find_robot_file(basedir: str, filename: str): filename = f'{filename}.robot' for root, dirs, files in walk(basedir): if filename in files: return root.replace(f'{basedir}/TP/NGSI-LD', ''), f'{root}/{filename}' return None, None if __name__ == "__main__": # Call with the folder below /TP/NGSI-LD which contains the robot file with name args[0] args = argv[1:] robot_file_tbp = args[0] resulting_json = create_json_of_robotfile(robot_file_tbp) print("Correctly exiting")