mirror of
https://github.com/enpaul/tox-poetry-installer.git
synced 2025-01-15 08:43:29 +00:00
Add support for running in a non-poetry project
Handle the error poetry raises when not in a poetry managed project and use that as a sign to skip further usage of the plugin in that environment
This commit is contained in:
parent
e28159060d
commit
b7961bec58
@ -266,7 +266,23 @@ def tox_testenv_install_deps(venv: ToxVirtualEnv, action: ToxAction):
|
||||
)
|
||||
return
|
||||
|
||||
poetry = PoetryFactory().create_poetry(venv.envconfig.config.toxinidir)
|
||||
try:
|
||||
poetry = PoetryFactory().create_poetry(venv.envconfig.config.toxinidir)
|
||||
except RuntimeError as err:
|
||||
# Support running the plugin when the current tox project does not use Poetry for its
|
||||
# environment/dependency management.
|
||||
#
|
||||
# ``RuntimeError`` is dangerous to blindly catch because it can be (and in Poetry's case,
|
||||
# is) raised in many different places for different purposes. This check of the error
|
||||
# content, while crude and potentially fragile, will hopefully prevent ``RuntimeError``s
|
||||
# not caused by this specific condition to be re-raised as genuine errors. This may need
|
||||
# tuning in the future.
|
||||
if "[tool.poetry] section not found" in str(err):
|
||||
reporter.verbosity1(
|
||||
f"{_REPORTER_PREFIX} project does not use Poetry for env management, skipping installation of locked dependencies"
|
||||
)
|
||||
return
|
||||
raise err
|
||||
|
||||
reporter.verbosity1(
|
||||
f"{_REPORTER_PREFIX} loaded project pyproject.toml from {poetry.file}"
|
||||
|
Loading…
Reference in New Issue
Block a user