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.4.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.4-py3-none-any.whl (4.4 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: fluent_selectors-0.1.4.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.4.tar.gz
Algorithm Hash digest
SHA256 1a283e42c8b70dee257ad9d947ac84149beac9afc6364ea30eba602b50916b8e
MD5 360c4a05ae9d3540b44ebbe788f4ddb8
BLAKE2b-256 c389e2f1c1b0f8802ed0998f05d76bb1222cba2bd54b8f7ef5d2292f69c65a7b

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for fluent_selectors-0.1.4-py3-none-any.whl
Algorithm Hash digest
SHA256 84bf20d1b1ffc3dcd8e56902f56eede483a4047ef0512112c518165380f9a30c
MD5 d1669d973a11b3cabdd66bb436d7306f
BLAKE2b-256 e57262f75e0c70a3bf684b18c0fbc5573cca86d86a593a9d0435e5f37329d424

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