From f8185b86cd0c9a601e56bf1d72e97b4a5a84aec8 Mon Sep 17 00:00:00 2001
From: Luciano Falchetto <10196111+falkets@users.noreply.github.com>
Date: Tue, 3 Sep 2024 22:47:38 +0100
Subject: [PATCH] Add support to Poetry's non_package mode
Since Poetry version 1.8.0 there's a non_package mode allowing using Poetry for dependency management only.
This adds support to that feature, enabling bundling the virtual environment only, without building the package wheel
---
.../bundlers/venv_bundler.py | 53 +++++++++++--------
tests/bundlers/test_venv_bundler.py | 27 ++++++++++
tests/fixtures/non_package_mode/poetry.lock | 11 ++++
.../fixtures/non_package_mode/pyproject.toml | 17 ++++++
4 files changed, 85 insertions(+), 23 deletions(-)
create mode 100644 tests/fixtures/non_package_mode/poetry.lock
create mode 100644 tests/fixtures/non_package_mode/pyproject.toml
diff --git a/src/poetry_plugin_bundle/bundlers/venv_bundler.py b/src/poetry_plugin_bundle/bundlers/venv_bundler.py
index e3672ef..7a948d2 100644
--- a/src/poetry_plugin_bundle/bundlers/venv_bundler.py
+++ b/src/poetry_plugin_bundle/bundlers/venv_bundler.py
@@ -165,30 +165,37 @@ def locked_repository(self) -> LockfileRepository:
)
return False
- self._write(
- io,
- f"{message}: Installing {poetry.package.pretty_name}"
- f" ({poetry.package.pretty_version})",
- )
+ # Skip building the wheel if is_package_mode exists and is set to false
+ if hasattr(poetry, "is_package_mode") and not poetry.is_package_mode:
+ self._write(
+ io,
+ f"{message}: Skipping installation for non package project {poetry.package.pretty_name}",
+ )
+ else:
+ self._write(
+ io,
+ f"{message}: Installing {poetry.package.pretty_name}"
+ f" ({poetry.package.pretty_version})",
+ )
- # Build a wheel of the project in a temporary directory
- # and install it in the newly create virtual environment
- with TemporaryDirectory() as directory:
- try:
- wheel_name = WheelBuilder.make_in(poetry, directory=Path(directory))
- wheel = Path(directory).joinpath(wheel_name)
- package = Package(
- poetry.package.name,
- poetry.package.version,
- source_type="file",
- source_url=str(wheel),
- )
- installer.executor.execute([Install(package)])
- except ModuleOrPackageNotFound:
- warnings.append(
- "The root package was not installed because no matching module or"
- " package was found."
- )
+ # Build a wheel of the project in a temporary directory
+ # and install it in the newly create virtual environment
+ with TemporaryDirectory() as directory:
+ try:
+ wheel_name = WheelBuilder.make_in(poetry, directory=Path(directory))
+ wheel = Path(directory).joinpath(wheel_name)
+ package = Package(
+ poetry.package.name,
+ poetry.package.version,
+ source_type="file",
+ source_url=str(wheel),
+ )
+ installer.executor.execute([Install(package)])
+ except ModuleOrPackageNotFound:
+ warnings.append(
+ "The root package was not installed because no matching module or"
+ " package was found."
+ )
self._write(io, self._get_message(poetry, self._path, done=True))
diff --git a/tests/bundlers/test_venv_bundler.py b/tests/bundlers/test_venv_bundler.py
index 4cd2b27..3ddaf8f 100644
--- a/tests/bundlers/test_venv_bundler.py
+++ b/tests/bundlers/test_venv_bundler.py
@@ -395,3 +395,30 @@ def test_bundler_should_build_a_venv_at_specified_path_if_centralized_venv_exist
• Bundled simple-project (1.2.3) into {path}
"""
assert expected == io.fetch_output()
+
+
+def test_bundler_non_package_mode(
+ io: BufferedIO, tmp_venv: VirtualEnv, mocker: MockerFixture, config: Config
+) -> None:
+ poetry = Factory().create_poetry(
+ Path(__file__).parent.parent / "fixtures" / "non_package_mode"
+ )
+ poetry.set_config(config)
+
+ mocker.patch("poetry.installation.executor.Executor._execute_operation")
+
+ bundler = VenvBundler()
+ bundler.set_path(tmp_venv.path)
+ bundler.set_remove(True)
+
+ assert bundler.bundle(poetry, io)
+
+ path = str(tmp_venv.path)
+ expected = f"""\
+ • Bundling simple-project-non-package-mode (1.2.3) into {path}
+ • Bundling simple-project-non-package-mode (1.2.3) into {path}: Creating a virtual environment using Poetry-determined Python
+ • Bundling simple-project-non-package-mode (1.2.3) into {path}: Installing dependencies
+ • Bundling simple-project-non-package-mode (1.2.3) into {path}: Skipping installation for non package project simple-project-non-package-mode
+ • Bundled simple-project-non-package-mode (1.2.3) into {path}
+"""
+ assert expected == io.fetch_output()
diff --git a/tests/fixtures/non_package_mode/poetry.lock b/tests/fixtures/non_package_mode/poetry.lock
new file mode 100644
index 0000000..fb78887
--- /dev/null
+++ b/tests/fixtures/non_package_mode/poetry.lock
@@ -0,0 +1,11 @@
+# This file is automatically @generated by Poetry 1.8.3 and should not be changed by hand.
+package = []
+
+[metadata]
+lock-version = "2.0"
+python-versions = "~2.7 || ^3.4"
+content-hash = "ea8246031ba3d40ce95b77e8f186836ce4a26fbba7b2be93f6a2f70047c04b66"
+
+
+[metadata.files]
+foo = []
diff --git a/tests/fixtures/non_package_mode/pyproject.toml b/tests/fixtures/non_package_mode/pyproject.toml
new file mode 100644
index 0000000..0e811aa
--- /dev/null
+++ b/tests/fixtures/non_package_mode/pyproject.toml
@@ -0,0 +1,17 @@
+[tool.poetry]
+name = "simple-project-non-package-mode"
+version = "1.2.3"
+package-mode = false
+
+# Requirements
+[tool.poetry.dependencies]
+python = "~2.7 || ^3.4"
+
+
+[tool.poetry.group.dev]
+optional = true
+dependencies = {}
+
+[tool.poetry.scripts]
+foo = "foo:bar"
+baz = "bar:baz.boom.bim"