Введение
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 и как они могут помочь вам в написании более эффективных и гибких тестов. Удачного тестирования!
ссылка на оригинал статьи https://habr.com/ru/articles/829612/
Добавить комментарий