I'm familiar with doing RPA with UiPath, so I wanted to try out other tools for automation. Robot Framework is really popular and you can use Python with it, so that was a natural selection for me. The scope of this article is just the finished product and tips for my pitfalls.
The finished robot:
#/devdata/env.json { "RPA_SECRET_MANAGER": "RPA.Robocorp.Vault.FileSecrets", "RPA_SECRET_FILE": "vault.json" }
#tasks.robot *** Settings *** Documentation Insert orders to system from a csv-file, produce receipts and a summary ZIP ... Author: www.github.com/kalletolonen ... Source for this excersise: https://robocorp.com/docs/courses/build-a-robot#rules-for-the-robot ... More from the author: https://www.kalletolonen.com Library RPA.Browser.Selenium auto_close=${FALSE} Library RPA.PDF Library RPA.HTTP Library RPA.Tables Library OperatingSystem Library DateTime Library Dialogs Library Screenshot Library RPA.Archive Library RPA.Robocorp.Vault *** Variables *** ${receipt_directory}= ${OUTPUT_DIR}${/}receipts/ ${image_directory}= ${OUTPUT_DIR}${/}images/ ${zip_directory}= ${OUTPUT_DIR}${/} *** Tasks *** Insert orders to system, produce receipts and a summary ZIP Get csv url Open the order site Fill in the order form using the data from the csv file Name and make the ZIP Delete original images Log out and close the browser *** Keywords *** Get csv url ${csv_url}= Get Secret cert2address Download the csv file ${csv_url}[value] Download the csv file [Arguments] ${csv_url} Download ${csv_url} overwrite=True Open the order site Open Available Browser https://robotsparebinindustries.com/#/robot-order Click OK Wait Until Page Contains Element class:alert-buttons Click Button OK Make order Click Button Order Page Should Contain Element id:receipt Return to order form Wait Until Element Is Visible id:order-another Click Button id:order-another Fill out 1 order [Arguments] ${orders} Click OK Wait Until Page Contains Element class:form-group Select From List By Index head ${orders}[Head] Select Radio Button body ${orders}[Body] Input Text xpath://html/body/div/div/div[1]/div/div[1]/form/div[3]/input ${orders}[Legs] Input Text address ${orders}[Address] Click Button Preview Wait Until Keyword Succeeds 2min 500ms Make order Save order details Wait Until Element Is Visible id:receipt ${order_id}= Get Text //*[@id="receipt"]/p[1] Set Local Variable ${receipt_filename} ${receipt_directory}receipt_${order_id}.pdf ${receipt_html}= Get Element Attribute //*[@id="receipt"] outerHTML Html To Pdf content=${receipt_html} output_path=${receipt_filename} Wait Until Element Is Visible id:robot-preview-image Set Local Variable ${image_filename} ${image_directory}robot_${order_id}.png Screenshot id:robot-preview-image ${image_filename} Combine receipt with robot image to a PDF ${receipt_filename} ${image_filename} Fill in the order form using the data from the csv file ${orders}= Read table from CSV path=orders.csv FOR ${order} IN @{orders} Fill out 1 order ${order} Save order details Return to order form END Combine receipt with robot image to a PDF [Arguments] ${receipt_filename} ${image_filename} Open PDF ${receipt_filename} @{pseudo_file_list}= Create List ... ${receipt_filename} ... ${image_filename}:align=center Add Files To PDF ${pseudo_file_list} ${receipt_filename} ${False} Close Pdf ${receipt_filename} Log out and close the browser Close Browser Delete original images Empty Directory ${image_directory} Empty Directory ${receipt_directory} Name and make the ZIP ${date}= Get Current Date exclude_millis=True ${name_of_zip}= Get Value From User Give the name for the zip of the orders: Log To Console ${name_of_zip}_${date} Create the ZIP ${name_of_zip}_${date} Create the ZIP [Arguments] ${name_of_zip} Create Directory ${zip_directory} Archive Folder With Zip ${receipt_directory} ${zip_directory}${name_of_zip}
My local “Vault”:
#vault.json { "cert2address": { "key": "address", "value": "https://robotsparebinindustries.com/#/robot-order" } }
You can grab the whole repo at my Github.
I had some challenges: 1. Firefox doesn’t allow you to copy the whole Xpath, so I used Chrome 2. My local Vault didn’t work with Assistant, so I hardcoded my info 3. “Try-Catch” was really easy to do with Wait Until Keyword Succeeds 4. Appending to a PDF had to be done by a list
Your comment may be published.
Name:
Email:
Message: