Robot Framework Browser library powered by Playwright. Moving browser automation to year 2020 (or 2021)!
Aiming for 🚀 speed, ✅ reliability and 🔬 visibility.
Only Python 3.8 or later is supported.
- Install node.js e.g. from https://nodejs.org/en/download/
- Install robotframework-browser from the commandline:
pip install robotframework-browser
- Install the node dependencies: run
rfbrowser init
in your shell
Or use the docker images.
Testing with Robot Framework
*** Settings ***
Library Browser
*** Test Cases ***
Example Test
New Page https://playwright.dev
Get Text h1 == 🎭 Playwright
and testing with Python.
import Browser
browser = Browser.Browser()
browser.new_page("https://playwright.dev")
assert browser.get_text("h1") == '🎭 Playwright'
browser.close_all_browsers()
# Select element containing text "Login" with text selector strategy
# and select it's parent `input` element with xpath
Click "Login" >> xpath=../input
# Select element with CSS strategy and select button in it with text strategy
Click div.dialog >> "Ok"
New Page ${LOGIN_URL}
${ref}= Get Element h1
Get Attribute ${ref} innerText == Login Page
Execute JavaScript (elem) => elem.innerText = "abc" ${ref}
Get Attribute ${ref} innerText == abc
# The button with id `delayed_request` fires a delayed request. We use a promise to capture it.
{promise}= Promise To Wait For Response matcher= timeout=3s
Click \#delayed_request
${body}= Wait For ${promise}
${device}= Get Device iPhone X
New Context &{device}
New Page
Get Viewport Size # returns { "width": 375, "height": 812 }
&{response}= HTTP /api/post POST {"name": "John"}
Should Be Equal ${response.status} ${200}
See CONTRIBUTING.md for development instructions.
In order of appearance.
- Mikko Korpela
- Tatu Aalto
- Janne Härkönen
- Kerkko Pelttari
- René Rohner
This project is community driven and becomes a reality only through the work of all the people who contribute. Supported by Robocorp through Robot Framework Foundation.