Skip to main content

A Python library for creating a readable, fluent API for Selenium browser automation

Project description

Fluent Selectors

A Python library for creating a readable, fluent API for Selenium browser automation.

Installation

Install the package using pip:

pip install fluent-selectors

Usage

Here's a simple example of how to use fluent-selectors:

from selenium import webdriver
from selenium.webdriver.common.by import By
from fluent_selectors import Selector

# Initialize the WebDriver
driver = webdriver.Chrome()
driver.get("http://www.python.org")

# Create a Selector instance
s = Selector(driver)

# Select an element and interact with it
search_bar = s.select((By.NAME, "q"))
search_bar.set_text("pycon")

go_button = s.select((By.ID, "submit"))
go_button.click()

# Perform checks
s.select((By.CLASS_NAME, "list-recent-events")).is_displayed.is_true()

driver.quit()

API

Selector(driver: WebDriver, *locators: Locator)

The main class for selecting and interacting with elements.

Traversal and Selection

  • select(locator: Locator) -> Selector: Select a descendant of the current element.
  • child(index: int) -> Selector: Select a child by its index.
  • children() -> list[Selector]: Get a list of all children selectors.
  • parent: Selector | None: The parent selector.
  • parents: list[Selector]: A list of all parent selectors.

Element Actions

  • click(): Clicks the element.
  • type_text(text: str): Types text into the element.
  • clear(): Clears the text from the element.
  • set_text(text: str): Clears the element and then types text into it.
  • upload_file(path: Path): Uploads a file to a file input element.
  • scroll_into_view(): Scrolls the element into view.

Element Properties

  • element: WebElement | None: The Selenium WebElement.
  • elements: list[WebElement]: A list of Selenium WebElements.
  • text: str | None: The text of the element.
  • tag_name: str | None: The tag name of the element.
  • accessible_name: str | None: The accessible name of the element.
  • aria_role: str | None: The ARIA role of the element.
  • id: str | None: The ID of the element.
  • location: Location | None: The location of the element.
  • size: Size | None: The size of the element.
  • attribute(name: str) -> str | None: The value of an attribute.

Checks

These methods return Check objects from the fluent-checks library.

  • is_present: Checks if the element is present in the DOM.
  • is_displayed: Checks if the element is visible.
  • is_enabled: Checks if the element is enabled.
  • is_selected: Checks if the element is selected.
  • is_stale: Checks if the element is stale.
  • has_text(text: str): Checks if the element's text contains the given text.
  • has_exact_text(text: str): Checks if the element's text exactly matches the given text.
  • has_attribute(name: str): Checks if the element has the given attribute.
  • has_attribute_value(name: str, value: str): Checks if the attribute has the given value.

Example of a check:

s.select((By.ID, "my-element")).is_displayed.is_true()
s.select((By.ID, "my-element")).has_text("Hello").is_true()

License

This project is licensed under the GNU General Public License v3.0 - see the LICENSE file for details.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

fluent_selectors-0.1.8.tar.gz (3.8 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

fluent_selectors-0.1.8-py3-none-any.whl (4.5 kB view details)

Uploaded Python 3

File details

Details for the file fluent_selectors-0.1.8.tar.gz.

File metadata

  • Download URL: fluent_selectors-0.1.8.tar.gz
  • Upload date:
  • Size: 3.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.8.13

File hashes

Hashes for fluent_selectors-0.1.8.tar.gz
Algorithm Hash digest
SHA256 fc84765d5c89fe1cd6f0acd723ef1fc4d30e5c833e3a3eb2301453ef13a9b706
MD5 05e8125f70ce9eb262abe2b9d9035d85
BLAKE2b-256 9146a5ece0d414e7b34723da4556159732f74bb0c659dddb96856d8b29cff650

See more details on using hashes here.

File details

Details for the file fluent_selectors-0.1.8-py3-none-any.whl.

File metadata

File hashes

Hashes for fluent_selectors-0.1.8-py3-none-any.whl
Algorithm Hash digest
SHA256 6fbbd948091753a82c9a54d241c17c362c72cdb71fab51b0d23554917f1aafe9
MD5 29996d501065d76493376eed00de2e31
BLAKE2b-256 43a2332df0a3ae7a5e243f3defe4df21963a4fcebb51c320c920924ad24e3643

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page