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.

  • 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.
  • parent() -> Selector | None: Get the parent selector.
  • parents() -> list[Selector]: Get 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

You can perform checks on selectors using the following properties. These checks are based on 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.
  • 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.

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.6.tar.gz (3.7 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.6-py3-none-any.whl (4.4 kB view details)

Uploaded Python 3

File details

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

File metadata

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

File hashes

Hashes for fluent_selectors-0.1.6.tar.gz
Algorithm Hash digest
SHA256 15c6f307db8dd7c74965dc23c29b7cfa59bcd84fbeb49d3a08631dc349cfa258
MD5 cc5e22f66a570fe502787fb3fdcc28cd
BLAKE2b-256 bb6d997206f99c143e776ea3aab53ea4140cff29e6f002b3a0ec22d0edf506aa

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for fluent_selectors-0.1.6-py3-none-any.whl
Algorithm Hash digest
SHA256 ef13e066f1ce12a2a59f22acd71d978e9e294ef8c7d25ac2a9a9165fafe6b5c1
MD5 6f37ef5db2f49f7f67bc09af56f322fb
BLAKE2b-256 f95052d248f9c281ed0a048d2e55d89a907ebf370038b756148933d9c449e909

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