15. Venv, Poetry и управление зависимостями проекта - qa-guru/knowledge-base GitHub Wiki

Данный раздел разделен на несколько частей(каждый пункт - это ссылка на соответствующий раздел):

Виртуальное окружение и управление зависимостями проекта

Venv

Venv — библиотека в дистрибутиве Python, позволяющая создавать виртуальные окружения. Она идёт «из коробки» и её не надо устанавливать отдельно.

  • python3 -m venv --help — вывод справки по командам в Venv;

Создание виртуального окружения

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

Windows:

python -m venv {name}  # папка получит имя `{name}`, обычно указывают название `venv`;

python -m venv venv

MacOS/Linux:

python3 -m venv {name} # папка получит имя `{name}`, обычно указывают название `venv`;

python3 -m venv venv

После выполнения команды в папке проекта появится папка venv.

Активация виртуального окружения

Для активации виртуального окружения необходимо выполнить команду:

Windows:

venv\Scripts\activate

MacOS/Linux:

source venv/bin/activate

После активации виртуального окружения в терминале появится префикс (venv).

Внутри папка venv выглядит следующим образом:

venv
├── include
├── lib
|   └── ...
├── Scripts
└── pyvenv.cfg
  • в файле pyvenv.cfg прописан путь до Python, его версия и остальные настройки;
  • папка include содержит заголовочные файлы;
  • папка lib содержит библиотеки, которые используются и установлены в виртуальном окружении;
  • папка Scripts содержит исполняемые файлы для Windows.
  • папка bin содержит исполняемые файлы для MacOS/Linux.

Деактивация виртуального окружения

Для деактивации виртуального окружения необходимо выполнить команду:

deactivate

Установка пакетов через pip в виртуальное окружение происходит также, как и в обычном окружении. Например, для установки библиотеки pytest:

pip install pytest

Если в проекте есть файл requirements.txt, то можно установить все зависимости из него:

pip install -r requirements.txt

Команда pip freeze позволяет увидеть все установленные пакеты в виртуальном окружении.

Зависимости в проекте можно отобразить в файл requirements.txt:

selene>=2.0.0rc9  # знак `>` установить версию 2.0.0rc9 и выше
pytest==6.2.5  # знак `==` установить только версию 6.2.5
allure-pytest~=2.9.43  # знак `~=` установить версию 2.9.43 и выше, но не 3.0.0. Это означает, что версия не должна быть выше 2.9.99
allure  # если не указана версия, то установится последняя версия

Более правильный способ для указания зависимостей, это строгое указание версий библиотек. Это позволяет избежать проблем совместимости библиотек. А именно, указывать версии библиотек в файле requirements.txt через ==:

pytest==6.2.5

Virtualenv

Такая же библиотека, как Venv. Важно заметить, что она не идёт по умолчанию вместе с Python. Выполняет те же задачи, но содержит чуть больше функций.

  • pip install virtualenv — установка Virtualenv;
  • virtualenv --help — справка по всем аргументам.

PyPA

PyPA — организация, разрабатывающая инструменты управлениям проектами в Python. В GitHub-репозитории организации можно найти официальную документацию и исходный код инструментов.

pipenv

pipenv — объединяет в себе возможности Virtualenv (venv) и pip. К примеру, в pipenv может одной командой создать окружение и установить зависимости.

pipenv проверяет хеш-суммы установленных пакетов и их зависимостей, что позволяет избежать проблем совместимости. Или же вредоносного кода, который может быть в пакете.

pipenv создаёт файл Pipfile, содержащий в себе все настройки и зависимости, а также файл Pipfile.lock, в котором хранятся хеш-суммы установленных пакетов.

[source](/qa-guru/knowledge-base/wiki/source)
url = "https://pypi.org/simple"
verify_ssl = true
name = "pypi"

[packages]
pytest = "*"

[dev-packages]
pylint = "*"

[requires]
python_version = "3.11"

В файле:

  • source — источник из которого берутся пакеты;

  • packages — описание зависимостей;

  • dev-packages — зависимости, которые не нужны для запуска проекта, но нужны для разработчика;

  • requires — указание используемой версии Python.

  • url — ссылка на источник пакетов;

  • verify_ssl — проверка SSL-сертификата;

  • name — имя источника.

  • python_version — версия Python.

  • * — устанавливается последняя версия пакета.

  • == — устанавливается строго указанная версия пакета.

  • >= — устанавливается версия пакета и выше.

  • ~= — устанавливается версия пакета и выше, но не выше следующей версии.

Команды:

  • pipenv shell — активация виртуального окружения;
  • pipenv install — установка пакетов;
  • pipenv instal -dev — установка пакетов в [dev-packages].

Poetry

Poetry — решает все те же проблемы, что описаны выше, и выполняет функции pipenv. Также позволяет управлять метаданными проекта.

Команды:

  • poetry --version — справка по версии;
  • poetry --help — справка по функциям и аргументам;
  • poetry new {name} — создание окружения;
  • poetry build — сборка проекта.
  • poetry init — инициализация проекта;

  • poetry install — установка зависимостей;

  • poetry add {package} — добавление пакета;
  • poetry remove {package} — удаление пакета.
  • poetry check — проверка на ошибки в проекте;

После создания Poetry создаёт папку со всем необходимым содержимым. Она включает в себя:

  • tests — папка с тестами;
  • README.rst — файл README;
  • pyproject.toml — файл с метаданными о проекте.

После установки зависимостей, Poetry создаёт файл poetry.lock, в котором хранятся хеш-суммы установленных пакетов.

Файл pyproject.toml содержит в себе метаданные о проекте:

[tool.poetry]
name = "with-poetry"
version = "0.1.0"
description = ""
authors = ["Your Name <[email protected]>"]
readme = "README.md"
license = "MIT"

[tool.poetry.dependencies]
python = "^3.9"

[build-system]
requires = ["poetry-core>=1.0.0"]

[tool.poetry.dev-dependencies]
pytest = "^6.2"
  • name — название проекта;
  • version — версия проекта;
  • description — описание проекта;
  • authors — авторы проекта и их контакты;
  • readme — файл README;
  • license — лицензия проекта;
  • python — версия Python;
  • requires — версия Poetry;
  • dev-dependencies — зависимости для разработки.

Чтобы добавить значение в dev-dependencies, необходимо выполнить команду:

poetry add --dev pytest

А если нужно добавить значение в dependencies, то:

poetry add pytest