Введение

pytest — один из самых популярных и мощных инструментов для тестирования в Python. Помимо своей простоты и выразительности, он предлагает мощный механизм расширения через хуки. В этой статье мы разберем, что такое хуки в pytest, как они работают, и как их можно использовать для настройки и расширения поведения вашего тестового окружения.

Что такое хуки?

Хуки в pytest — это специальные точки расширения, позволяющие разработчикам вмешиваться в различные этапы процесса тестирования. Они предоставляют интерфейс для выполнения дополнительных действий до, после или во время выполнения тестов. Хуки определяются как функции с префиксом pytest_.

Основные хуки pytest

1. pytest_configure(config)

Этот хук вызывается после инициализации конфигурации pytest, но до запуска тестов. Он позволяет настроить поведение тестового окружения.

def pytest_configure(config):
    config.addinivalue_line(
        "markers", "custom_marker: описание вашего маркера"
    )

2. pytest_collection_modifyitems(config, items)

Этот хук вызывается после того, как все тесты собраны, но до их запуска. Он позволяет изменять или фильтровать список тестов.

def pytest_collection_modifyitems(config, items):
    for item in items:
        if "slow" in item.keywords:
            item.add_marker(pytest.mark.skip(reason="Пропускаем медленные тесты"))

3. pytest_runtest_setup(item)

Этот хук вызывается перед запуском каждого теста. Он позволяет настроить окружение для каждого теста.

def pytest_runtest_setup(item):
    if "need_env" in item.keywords and not os.getenv("MY_ENV_VAR"):
        pytest.skip("Требуется переменная окружения MY_ENV_VAR")

4. pytest_runtest_teardown(item, nextitem)

Этот хук вызывается после выполнения каждого теста. Он используется для очистки окружения после теста.

def pytest_runtest_teardown(item, nextitem):
    if "temp_file" in item.keywords:
        os.remove("/tmp/tempfile")

5. pytest_terminal_summary(terminalreporter, exitstatus)

Этот хук вызывается после завершения всех тестов и используется для добавления пользовательских данных к итоговому отчету.

def pytest_terminal_summary(terminalreporter, exitstatus):
    terminalreporter.write_sep("=", "Мой пользовательский отчет")
    terminalreporter.write_line("Все тесты выполнены успешно!")

Примеры использования хуков

Пример 1: Счетчик выполненных тестов

Создадим хук, который будет считать количество выполненных тестов и выводить эту информацию после завершения тестирования.

# conftest.py

def pytest_sessionstart(session):
    session.tests_ran = 0

def pytest_runtest_logreport(report):
    if report.when == 'call' and report.passed:
        session.tests_ran += 1

def pytest_terminal_summary(terminalreporter, exitstatus):
    terminalreporter.write_sep("=", f"Количество успешно выполненных тестов: {session.tests_ran}")

Пример 2: Условное пропускание тестов

Пропустим все тесты, если они отмечены маркером skip_if_no_db, и база данных не доступна.

# conftest.py

def pytest_runtest_setup(item):
    if "skip_if_no_db" in item.keywords and not check_database_connection():
        pytest.skip("База данных недоступна")

Пример 3: Добавление пользовательского маркера

Добавим новый маркер и будем использовать его для выполнения дополнительных действий перед тестами.

# conftest.py

def pytest_configure(config):
    config.addinivalue_line(
        "markers", "dbtest: тесты, требующие подключения к базе данных"
    )

def pytest_runtest_setup(item):
    if "dbtest" in item.keywords:
        setup_database()

Хуки pytest предоставляют мощные возможности для настройки и расширения тестового процесса. Используя хуки, можно настроить сбор тестов, подготовку окружения, выполнение тестов и обработку результатов. Это делает pytest невероятно гибким и расширяемым инструментом для автоматизации тестирования.

Применяя хуки на практике, вы сможете создать более управляемое, повторяемое и эффективное тестовое окружение, адаптированное к вашим конкретным требованиям и условиям.

Надеюсь, эта статья помогла вам лучше понять, как работать с хуками в pytest и как они могут помочь вам в написании более эффективных и гибких тестов. Удачного тестирования!

Комментарии (0)