Robot Framework Browser library powered by Playwright. Aiming for speed, reliability and visibility.
Project description
robotframework-browser
Robot Framework Browser library powered by Playwright. Moving browser automation to year 2021!
Aiming for :rocket: speed, :white_check_mark: reliability and :microscope: visibility.
Installation instructions
Only Python 3.7 or newer is supported.
- Install node.js e.g. from https://nodejs.org/en/download/ (only < v15 supported; if unsure, use 14.15.0 LTS)
- Update pip
pip install -U pip
to ensure latest version is used - Install robotframework-browser from the commandline:
pip install robotframework-browser
- Install the node dependencies: run
rfbrowser init
in your shell
- if
rfbrowser
is not found, trypython -m Browser.entry init
Or use the docker images. Documented at atest/docker/README.md.
Update instructions
To upgrade your already installed robotframework-browser library
- Update from commandline:
pip install -U robotframework-browser
- Install the node dependencies for the newly installed version:
rfbrowser init
Examples
Testing with Robot Framework
*** Settings ***
Library Browser
*** Test Cases ***
Example Test
New Page https://playwright.dev
Get Text h1 contains Playwright
and testing with Python.
import Browser
browser = Browser.Browser()
browser.new_page("https://playwright.dev")
assert 'Playwright' in browser.get_text("h1")
browser.close_browser()
and extending with JavaScript
async function myGoToKeyword(page, args) {
return await page.goto(args[0]);
}
exports.__esModule = true;
exports.myGoToKeyword = myGoToKeyword;
*** Settings ***
Library Browser jsextension=${CURDIR}/mymodule.js
*** Test Cases ***
Example Test
New Page
myGoToKeyword https://www.robotframework.org
Ergonomic selector syntax, supports chaining of text
, css
and xpath
selectors
# 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"
Evaluate in browser page
New Page ${LOGIN_URL}
${ref}= Get Element h1
Get Property ${ref} innerText == Login Page
Execute JavaScript (elem) => elem.innerText = "abc" ${ref}
Get Property ${ref} innerText == abc
Asynchronously waiting for HTTP requests and responses
# 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 Descriptors
${device}= Get Device iPhone X
New Context &{device}
New Page
Get Viewport Size # returns { "width": 375, "height": 812 }
Sending HTTP requests and parsing their responses
&{response}= HTTP /api/post POST {"name": "John"}
Should Be Equal ${response.status} ${200}
Development
See CONTRIBUTING.md for development instructions.
Core team
In order of appearance.
- Mikko Korpela
- Tatu Aalto
- Janne Härkönen (Alumnus)
- Kerkko Pelttari
- René Rohner
Contributors
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.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Hashes for robotframework-browser-4.3.0.tar.gz
Algorithm | Hash digest | |
---|---|---|
SHA256 | 08ca65dd71064dc92b7c9454513f508452f1cf1fd5da64b871ed34d5112476de |
|
MD5 | b0d6073ba7001fb66726219cd5b7d800 |
|
BLAKE2b-256 | a687b3deb078db9734ddb18e996ffa201af6a32c36cbfa2c2aec05206d88f56c |
Hashes for robotframework_browser-4.3.0-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | adcb96033a267fce57a3789102d5ef5bdd9d096513ec51c061250a09282089c1 |
|
MD5 | b1407ee5605586b7b4cf09bf5f2608d8 |
|
BLAKE2b-256 | 2c2d27a07683e2c7e0220f0e086db9a5c1b3bedcaa5553da6441c593fc6da6bf |