Persona DSL - Framework for implementing Screenplay pattern in Python tests
Project description
persona-dsl: Фреймворк для автотестов на Python
persona-dsl — это современная библиотека для написания E2E и API автотестов, реализующая паттерн Screenplay.
Она предоставляет выразительный язык для описания сценариев, управляет браузером (через Playwright) и автоматически генерирует детальные отчеты Allure.
📦 Установка
pip install persona-dsl
python -m playwright install --with-deps
🚀 Быстрый старт
1. Описание страницы (Page Object)
В persona-dsl используется Универсальная Архитектура Элементов.
Основной класс Page сам является элементом-контейнером. Вложенные элементы добавляются через add_element.
# pages/login_page.py
from persona_dsl.pages import Page
from persona_dsl.pages.elements import Input, Button
class LoginPage(Page):
def __init__(self):
super().__init__()
# Имя атрибута (self.username) будет использовано как имя элемента в отчетах
self.username = self.add_element(Input(xpath="//input[@id='user']", name="Логин"))
self.password = self.add_element(Input(xpath="//input[@id='pass']", name="Пароль"))
self.submit = self.add_element(Button(xpath="//button[@type='submit']", name="Вход"))
2. Написание теста
Тесты пишутся в стиле "Persona делает действия":
# tests/test_login.py
import pytest
from persona_dsl.ops.web import NavigateTo, Fill, Click
from persona_dsl.facts.web import CurrentPath
from persona_dsl.expectations.web import IsEqualTo
from pages.login_page import LoginPage
def test_login_flow(persona):
login_page = LoginPage()
# 1. Действия (Actions)
persona.make(
NavigateTo("/login"),
Fill(login_page.username, "admin"),
Fill(login_page.password, "secret"),
Click(login_page.submit)
)
# 2. Проверка (Verification)
# Получаем Факт (CurrentPath) и проверяем Ожидание (IsEqualTo)
current_path = persona.get(CurrentPath())
persona.check(current_path, IsEqualTo("/dashboard"))
🏗 Архитектура
1. Ключевые компоненты (Persona Core)
| Компонент | Назначение | Пример |
|---|---|---|
| Persona | Исполнитель. Хранит состояние и навыки. | persona.make(...) |
| Skill | "Навык". Дает доступ к инструментам. | UseBrowser, UseAPI, UseDB |
| Ops | Атомарная операция. Работает со Skill. | Click, HttpRequest, ExecuteSQL |
| Step | Бизнес-шаг. Группирует Ops. | LoginStep, CreateOrder |
| Fact | Запрос состояния (без изменений). | CurrentPath, ElementText |
| Expectation | Проверка значения. | IsEqualTo, ContainsText |
2. Универсальные Элементы (New!)
Больше нет разделения на Element и ElementContainer. Любой элемент может содержать другие элементы.
element.add_element(...): Регистрирует дочерний элемент.- Иерархия:
Page -> Container -> Element. - Локаторы: Строятся автоматически по цепочке родителей.
3. Генераторный подход
Все шаги (Step, CombinedStep) — это генераторы, которые "выдают" (yield) операции для исполнения Персоной. Это позволяет persona-dsl перехватывать каждый шаг, логировать его в Allure и обрабатывать ошибки.
🛠 Инструменты и Утилиты
Генерация Page Objects
Не пишите селекторы вручную. Используйте генератор:
# Снять ARIA-снапшот и сгенерировать класс страницы
persona-page-gen --url http://localhost:8080 --output pages/home.py
Генерация API клиентов
# Генерация из OpenAPI/Swagger
persona-api-gen --url http://api.example.com/openapi.json --output skills/my_api.py
Запуск тестов
Тесты запускаются стандартной командой pytest:
pytest --env=dev tests/
⚙️ Конфигурация
conftest.py
Декларативное описание навыков и ролей:
PERSONA_SKILLS = [BaseSkill.BROWSER, BaseSkill.API]
config/{env}.yaml
Параметры окружения (dev, test, prod). Выбирается через --env=test.
Примеры конфигурации
Ниже представлен полный справочник всех возможных настроек. Большинство параметров унифицированы и работают идентично для Локального запуска и Selenoid.
Полный справочник (Global Reference)
Этот конфиг покрывает все возможности фреймворка. Неиспользуемые параметры можно опускать.
skills:
browser:
default:
base_url: "https://my-app.test" # URL должен быть внутри навыка
# --- Базовые настройки (Basic) ---
type: chromium # Тип: chromium, firefox, webkit, sberbrowser, msedge
headless: true # true = без UI (в контейнере тоже работает)
channel: chrome # (Optional) Канал: chrome, msedge, chrome-beta
executable_path: "" # (Optional) Кастомный путь к бинарнику
version: "128.0" # (Optional) Версия (для Selenoid или скачивания)
# --- Размеры и Тайминги (Dimensions & Timings) ---
viewport:
width: 1920
height: 1080 # Всегда используйте многострочный формат для читаемости
slow_mo: 50.0 # Задержка между действиями (мс)
default_timeout: 30000.0 # Таймаут поиска элементов (мс)
default_navigation_timeout: 30000.0 # Таймаут загрузки (мс)
# --- Аргументы и Флаги (Arguments) ---
# Применяются и локально, и удаленно (через goog:chromeOptions)
no_sandbox: true # --no-sandbox
ignore_https_errors: true # --ignore-certificate-errors
disable_features: # --disable-features=...
- SidePanel
- SberWhatsNew
args: # Дополнительные аргументы
- "--start-maximized"
- "--disable-notifications"
- "--disable-gpu"
# --- Удаленный запуск (Remote / Selenoid) ---
# Если URL задан, тесты пойдут в облако/контейнер
selenoid_url: "http://selenoid.company.com:4444"
session_retries: 3 # Повторные попытки при ошибке создания сессии
session_timeout: 60.0 # Таймаут ожидания слота (сек)
selenoid_options:
enableVNC: true # Включить Live-просмотр
enableVideo: false # Включить запись видео
# name/videoName проставляются автоматически
📊 Отчетность (Allure + TaaS)
Фреймворк автоматически:
- Создает вложенные Allure Steps для каждого действия.
- Прикрепляет Скриншоты и Page Source при падении.
- Логирует HTTP запросы/ответы (если включено).
- Интегрируется с платформой TaaS (Test as a Service) для аналитики.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file persona_dsl-26.1.21.37.tar.gz.
File metadata
- Download URL: persona_dsl-26.1.21.37.tar.gz
- Upload date:
- Size: 102.3 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
ade5c81539117c82f42ff98b97f4ab8012a052315d37aefa3abc62e06200ed73
|
|
| MD5 |
ea68acc008df8edcec4960286b666b7f
|
|
| BLAKE2b-256 |
981051ee34710386fb9a016f31dab21e5afd1a6afeca0f08de3da99ce9b48312
|
File details
Details for the file persona_dsl-26.1.21.37-py3-none-any.whl.
File metadata
- Download URL: persona_dsl-26.1.21.37-py3-none-any.whl
- Upload date:
- Size: 133.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
0509eae483a2ae706e8edfe5d1eca690d2fe308044fdd32faf713f3bccd641c1
|
|
| MD5 |
7acfef1043715bb5324416364839d57a
|
|
| BLAKE2b-256 |
bb34a554079e9761309e5621fbc88f9623b945b902bbfcab8563cd3f34e41da3
|