Skip to main content

Promethee-Selenium: A POM-based automated UI test library

Project description

Promethee-Selenium

[English version below | Version française plus bas]


🇬🇧 English Description

A robust, Page Object Model (POM) based library for automated UI testing using Selenium and Pytest.

This library is designed to help you write maintainable and scalable end-to-end tests with minimal boilerplate.

Features

  • Page Object Model (POM): Structured architecture separating page logic from test logic.
  • Scaffolding CLI: Quickly initialize a new project with best-practice directory structure using promethee-selenium init.
  • Built-in Utilities: Ready-to-use helpers for Waiting, Clicking, Filling inputs (via selenium-ui-test-tool).
  • Environment Management: Easy handling of test data and credentials.
  • Documentation: Includes HTML documentation to help you get started.

Installation

Install the package via pip:

pip install promethee-selenium

Getting Started

  1. Create a new folder for your test project:

    mkdir my_test_project
    cd my_test_project
    
  2. Initialize the project structure:

    promethee-selenium init
    

    To view the documentation in your browser:

    promethee-selenium docs
    

    Or use the shortcut:

    promethee-selenium-docs
    

    This will create:

    • scenarios/: For your Page Objects.
    • tests/: For your test scripts.
    • data/: For credentials and test data.
    • utils/: For local utilities.
    • conftest.py: Pytest configuration.
  3. Run the sample test:

    pytest tests/
    

Writing a Page Object

Inherit from the Base class provided by the library:

from promethee-selenium.base import Base
from selenium.webdriver.common.by import By
# Uses selenium-ui-test-tool functions internally

class LoginPage(Base):
    def fill_form(self, username, password):
        self.fill_input(By.ID, "username", username)
        self.fill_input(By.ID, "password", password)
        self.click_element(By.ID, "submit-btn")

For more details, check the generated docs/index.html after installation.


🇫🇷 Description Française

Une librairie robuste basée sur le modèle Page Object Model (POM) pour l'automatisation de tests UI avec Selenium et Pytest.

Cette librairie est conçue pour vous aider à écrire des tests de bout en bout maintenables et évolutifs avec un minimum de code répétitif.

Fonctionnalités

  • Page Object Model (POM) : Architecture structurée séparant la logique de la page de la logique de test.
  • CLI d'initialisation : Initialisez rapidement un nouveau projet avec une structure recommandée via promethee-selenium init.
  • Utilitaires intégrés : Fonctions prêtes à l'emploi pour attendre, cliquer, remplir des champs (via selenium-ui-test-tool).
  • Gestion d'environnement : Gestion facile des données de test et des identifiants.
  • Documentation : Inclut une documentation HTML pour vous aider à démarrer.

Installation

Installez le paquet via pip :

pip install Promethee-Selenium

Démarrage Rapide

  1. Créez un nouveau dossier pour votre projet de test :

    mkdir mon_projet_test
    cd mon_projet_test
    
  2. Initialisez la structure du projet :

    promethee-selenium init
    

    Pour afficher la documentation dans votre navigateur :

    promethee-selenium docs
    

    Ou utilisez le raccourci :

    promethee-selenium-docs
    

    Cela va créer :

    • scenarios/ : Pour vos Page Objects.
    • tests/ : Pour vos scripts de test.
    • data/ : Pour les identifiants et données de test.
    • utils/ : Pour les utilitaires locaux.
    • conftest.py : Configuration Pytest.
  3. Lancez le test d'exemple :

    pytest tests/
    

Écrire un Page Object

Héritez de la classe Base fournie par la librairie :

from promethee.base import Base
from selenium.webdriver.common.by import By
# Utilise les fonctions selenium-ui-test-tool en interne

class LoginPage(Base):
    def fill_form(self, username, password):
        self.fill_input(By.ID, "username", username)
        self.fill_input(By.ID, "password", password)
        self.click_element(By.ID, "submit-btn")

Pour plus de détails, consultez le fichier docs/index.html généré après l'installation.

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

promethee_selenium-1.0.4.tar.gz (15.9 kB view details)

Uploaded Source

Built Distribution

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

promethee_selenium-1.0.4-py3-none-any.whl (17.5 kB view details)

Uploaded Python 3

File details

Details for the file promethee_selenium-1.0.4.tar.gz.

File metadata

  • Download URL: promethee_selenium-1.0.4.tar.gz
  • Upload date:
  • Size: 15.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.6

File hashes

Hashes for promethee_selenium-1.0.4.tar.gz
Algorithm Hash digest
SHA256 1e53d0fafb899dcf62a5119e9f77175073834d0337c11c30766e221a4982b8d9
MD5 a3399fcbaafb69185a05a76b8d36a574
BLAKE2b-256 28fde59fbb710685a8d9eb510a69b0026f98dc4f39fc811fd8f1333dc376ac25

See more details on using hashes here.

File details

Details for the file promethee_selenium-1.0.4-py3-none-any.whl.

File metadata

File hashes

Hashes for promethee_selenium-1.0.4-py3-none-any.whl
Algorithm Hash digest
SHA256 851956813dca4f13537b770f84fa7e34860ff12b46afe04431de845f9683c227
MD5 dd196f640ebc16cd6f8b8fff4e733338
BLAKE2b-256 05b65d0f6b2379216058a3bd533b900ea7537cbf2af1a9405b8853250334a20e

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