Skip to main content

A utility library for Selenium WebDriver to enable human-like interactions, robust exception handling, and web automation tasks like popup handling and URL normalization.

Project description

Selmate

Selmate is a Python utility library designed to enhance Selenium WebDriver automation by providing human-like interactions, robust exception handling, and utilities for common web automation tasks. It simplifies interactions with web elements, handles popups, normalizes URLs, and simulates natural user behavior like mouse movements and scrolling.

Features

  • Safe Element Interactions: Wrappers for Selenium operations (clicks, scrolls, etc.) with built-in exception handling for stale elements, timeouts, and more.
  • Human-Like Behavior: Simulates realistic mouse movements, scrolling, and latency to mimic human interactions.
  • Popup Handling: Automatically detects and handles popup banners, including those within iframes, with options to accept or close them.
  • URL Normalization: Utilities to normalize URLs relative to a base URL, with configurable handling of query strings, fragments, and parameters.
  • JavaScript Integration: Execute JavaScript for advanced interactions like smooth scrolling, element removal, and visibility checks.
  • Text Similarity: Identify confirmation buttons or close buttons using fuzzy text matching.

Installation

Install Selmate via pip:

pip install selmate

Usage

Here are some examples of using Selmate's core functionalities:

Example 1: Safe Element Click

from selenium import webdriver
from selmate.composites import complex_click
from selmate.selenium_primitives import find_element_safely
from selenium.webdriver.common.by import By

driver = webdriver.Chrome()
driver.get("https://example.com")

# Safely find and click a button
button = find_element_safely(By.ID, "submit-button", driver)
if button and complex_click(button, driver):
    print("Button clicked successfully")

driver.quit()

Example 2: Handling Popup Banners

from selenium import webdriver
from selmate.composites import bypass_popup_banners

driver = webdriver.Chrome()
driver.get("https://example.com")

# Automatically handle popup banners
bypass_popup_banners(driver, observation_capacity=50, success_capacity=3, try_close=True)
print("Popups handled")

driver.quit()

Example 3: Human-Like Mouse Movement

from selenium import webdriver
from selmate.composites import wander_between_2_elements
from selmate.selenium_primitives import find_element_safely
from selenium.webdriver.common.by import By

driver = webdriver.Chrome()
driver.get("https://example.com")

# Find two elements and simulate mouse movement between them
element1 = find_element_safely(By.ID, "element1", driver)
element2 = find_element_safely(By.ID, "element2", driver)
if element1 and element2:
    wander_between_2_elements(element1, element2, driver)

driver.quit()

License

Selmate is licensed under the MIT License. See the LICENSE file for details.

Contact

For questions or support, open an issue or contact the maintainer at waxbid@gmail.com.

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

selmate-1.0.5.tar.gz (16.6 kB view details)

Uploaded Source

Built Distribution

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

selmate-1.0.5-py3-none-any.whl (18.2 kB view details)

Uploaded Python 3

File details

Details for the file selmate-1.0.5.tar.gz.

File metadata

  • Download URL: selmate-1.0.5.tar.gz
  • Upload date:
  • Size: 16.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/2.1.3 CPython/3.10.11 Windows/10

File hashes

Hashes for selmate-1.0.5.tar.gz
Algorithm Hash digest
SHA256 573d12abbd514bb8826bf30338c054bb5d41578ba306f88deb3475aa966e11ce
MD5 3b7f13b9e8b11e746305bc9b5a8eda9c
BLAKE2b-256 ac7d6d957943304ea8e35651891f8e27460de64e12e05fe881eef3e99560d8d7

See more details on using hashes here.

File details

Details for the file selmate-1.0.5-py3-none-any.whl.

File metadata

  • Download URL: selmate-1.0.5-py3-none-any.whl
  • Upload date:
  • Size: 18.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/2.1.3 CPython/3.10.11 Windows/10

File hashes

Hashes for selmate-1.0.5-py3-none-any.whl
Algorithm Hash digest
SHA256 6f41aa949bb905769d61424aa92f87912695aad54b01942d73401bfe3915a8e3
MD5 8ac474aa96dde0cbcc2f297f59a495bf
BLAKE2b-256 ecdb3fe8856b9bac92e77238ea82f355ce2422d9db239e9b61fabe2965cca8e0

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