From 3fc5cc37b6ccf43240caee73d39162183d833519 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Juan=20Luis=20Cano=20Rodr=C3=ADguez?= Date: Fri, 26 May 2023 18:09:36 +0200 Subject: [PATCH] Safely parse requirements files everywhere MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Signed-off-by: Juan Luis Cano Rodríguez --- kedro/framework/cli/micropkg.py | 18 ++++++------------ 1 file changed, 6 insertions(+), 12 deletions(-) diff --git a/kedro/framework/cli/micropkg.py b/kedro/framework/cli/micropkg.py index fcf94a2144..fecf4260fa 100644 --- a/kedro/framework/cli/micropkg.py +++ b/kedro/framework/cli/micropkg.py @@ -574,15 +574,6 @@ def _sync_path_list(source: list[tuple[Path, str]], target: Path) -> None: _sync_dirs(source_path, target_with_suffix) -def _make_install_requires(requirements_txt: Path) -> list[str]: - """Parses each line of requirements.txt into a version specifier valid to put in - install_requires.""" - if not requirements_txt.exists(): - return [] - requirements = pkg_resources.parse_requirements(requirements_txt.read_text()) - return [str(requirement) for requirement in requirements] - - def _create_nested_package(project: Project, package_path: Path) -> Path: # fails if parts of the path exists already packages = package_path.parts @@ -746,9 +737,12 @@ def _generate_sdist_file( # Build a setup.py on the fly try: - install_requires = _make_install_requires( - metadata.project_path / "requirements.txt" # type: ignore - ) + install_requires = [ + str(req) + for req in _safe_parse_requirements( + (metadata.project_path / "requirements.txt").read_text() # type: ignore + ) + ] except Exception as exc: click.secho("FAILED", fg="red") cls = exc.__class__