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.3.tar.gz (3.6 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.3-py3-none-any.whl (4.3 kB view details)

Uploaded Python 3

File details

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

File metadata

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

File hashes

Hashes for fluent_selectors-0.1.3.tar.gz
Algorithm Hash digest
SHA256 654e94acbd6252ac27c7f4aeaf9b1b24f3d2f277b46328f0d091002ed975f50a
MD5 38d9d785805ee25ef398178429098bab
BLAKE2b-256 91e3a286151b0b8f1b044c7f848e84e5c2eaf139b011a46ed781558a4fd23eae

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for fluent_selectors-0.1.3-py3-none-any.whl
Algorithm Hash digest
SHA256 bdb1aa996248e8de5ebaaabc640b438f0329ffc5a5645134444e9b2de30d3d1a
MD5 4209a95806f201a2e885c5c9c022c77b
BLAKE2b-256 45aecb6633fff3a0e525a06c32007566f5e39613f2da619a52476033ca1af058

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