From cf4f0ffae557074fe8c43c4251afd02d7043a977 Mon Sep 17 00:00:00 2001 From: Maarten Derickx Date: Tue, 6 Jun 2023 17:10:56 +0200 Subject: [PATCH 1/5] Optionally use resolved references in to_pep_508 --- src/poetry/core/packages/dependency.py | 7 +++- src/poetry/core/packages/vcs_dependency.py | 17 ++++++-- tests/packages/test_vcs_dependency.py | 45 ++++++++++++++++++++++ 3 files changed, 64 insertions(+), 5 deletions(-) diff --git a/src/poetry/core/packages/dependency.py b/src/poetry/core/packages/dependency.py index 94d12030b..36f8a7470 100644 --- a/src/poetry/core/packages/dependency.py +++ b/src/poetry/core/packages/dependency.py @@ -279,10 +279,13 @@ def is_directory(self) -> bool: def is_url(self) -> bool: return False - def to_pep_508(self, with_extras: bool = True) -> str: + def to_pep_508(self, with_extras: bool = True, resolved: bool = False) -> str: from poetry.core.packages.utils.utils import convert_markers - requirement = self.base_pep_508_name + if resolved and hasattr(self, "base_pep_508_name_resolved"): + requirement: str = self.base_pep_508_name_resolved + else: + requirement = self.base_pep_508_name markers = [] has_extras = False diff --git a/src/poetry/core/packages/vcs_dependency.py b/src/poetry/core/packages/vcs_dependency.py index 24e39d0f0..b9cbbbaf8 100644 --- a/src/poetry/core/packages/vcs_dependency.py +++ b/src/poetry/core/packages/vcs_dependency.py @@ -101,8 +101,7 @@ def pretty_constraint(self) -> str: return f"{what} {version}" - @property - def base_pep_508_name(self) -> str: + def _base_pep_508_name(self, resolved: bool = False) -> str: from poetry.core.vcs import git requirement = self.pretty_name @@ -117,7 +116,9 @@ def base_pep_508_name(self) -> str: else: requirement += f" @ {self._vcs}+ssh://{parsed_url.format()}" - if self.reference: + if resolved and self.source_resolved_reference: + requirement += f"@{self.source_resolved_reference}" + elif self.reference: requirement += f"@{self.reference}" if self._directory: @@ -125,5 +126,15 @@ def base_pep_508_name(self) -> str: return requirement + @property + def base_pep_508_name(self) -> str: + requirement = self._base_pep_508_name() + return requirement + + @property + def base_pep_508_name_resolved(self) -> str: + requirement = self._base_pep_508_name(resolved=True) + return requirement + def is_vcs(self) -> bool: return True diff --git a/tests/packages/test_vcs_dependency.py b/tests/packages/test_vcs_dependency.py index 0d9d01910..e6961e1a4 100644 --- a/tests/packages/test_vcs_dependency.py +++ b/tests/packages/test_vcs_dependency.py @@ -54,6 +54,51 @@ def test_to_pep_508(kwargs: dict[str, Any], expected: str) -> None: assert dependency.to_pep_508() == expected +@pytest.mark.parametrize( + "kwargs, expected", + [ + ({}, "poetry @ git+https://github.com/python-poetry/poetry.git"), + ( + {"extras": ["foo"]}, + "poetry[foo] @ git+https://github.com/python-poetry/poetry.git", + ), + ( + {"extras": ["foo", "bar"]}, + "poetry[bar,foo] @ git+https://github.com/python-poetry/poetry.git", + ), + ( + {"branch": "main", "resolved_rev": "aaaa"}, + "poetry @ git+https://github.com/python-poetry/poetry.git@aaaa", + ), + ( + {"tag": "1.0", "resolved_rev": "aaaa"}, + "poetry @ git+https://github.com/python-poetry/poetry.git@aaaa", + ), + ( + {"rev": "12345", "resolved_rev": "aaaa"}, + "poetry @ git+https://github.com/python-poetry/poetry.git@aaaa", + ), + ( + {"directory": "sub"}, + "poetry @ git+https://github.com/python-poetry/poetry.git#subdirectory=sub", + ), + ( + {"branch": "main", "directory": "sub", "resolved_rev": "aaaa"}, + ( + "poetry @ git+https://github.com/python-poetry/poetry.git" + "@aaaa#subdirectory=sub" + ), + ), + ], +) +def test_to_pep_508_resolved(kwargs: dict[str, Any], expected: str) -> None: + dependency = VCSDependency( + "poetry", "git", "https://github.com/python-poetry/poetry.git", **kwargs + ) + + assert dependency.to_pep_508(resolved=True) == expected + + def test_to_pep_508_ssh() -> None: dependency = VCSDependency("poetry", "git", "git@github.com:sdispater/poetry.git") From b187291230bf6cfd1aa8c921e7aee7db8cc34404 Mon Sep 17 00:00:00 2001 From: Maarten Derickx Date: Sun, 11 Jun 2023 16:31:00 +0200 Subject: [PATCH 2/5] Apply suggestions from code review MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Co-authored-by: Randy Döring <30527984+radoering@users.noreply.github.com> --- src/poetry/core/packages/dependency.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/poetry/core/packages/dependency.py b/src/poetry/core/packages/dependency.py index 36f8a7470..34eb339ea 100644 --- a/src/poetry/core/packages/dependency.py +++ b/src/poetry/core/packages/dependency.py @@ -279,7 +279,7 @@ def is_directory(self) -> bool: def is_url(self) -> bool: return False - def to_pep_508(self, with_extras: bool = True, resolved: bool = False) -> str: + def to_pep_508(self, with_extras: bool = True, *, resolved: bool = False) -> str: from poetry.core.packages.utils.utils import convert_markers if resolved and hasattr(self, "base_pep_508_name_resolved"): From 21949b231dc72eb232b55a94783cd1af0ffd9f78 Mon Sep 17 00:00:00 2001 From: Maarten Derickx Date: Sun, 11 Jun 2023 19:50:05 +0200 Subject: [PATCH 3/5] Address reviewer comments --- src/poetry/core/packages/dependency.py | 8 ++++++-- tests/packages/test_vcs_dependency.py | 8 ++++++++ 2 files changed, 14 insertions(+), 2 deletions(-) diff --git a/src/poetry/core/packages/dependency.py b/src/poetry/core/packages/dependency.py index 34eb339ea..4d2b3ef90 100644 --- a/src/poetry/core/packages/dependency.py +++ b/src/poetry/core/packages/dependency.py @@ -258,6 +258,10 @@ def base_pep_508_name(self) -> str: return requirement + @property + def base_pep_508_name_resolved(self) -> str: + return self.base_pep_508_name + def allows_prereleases(self) -> bool: return self._allows_prereleases @@ -282,8 +286,8 @@ def is_url(self) -> bool: def to_pep_508(self, with_extras: bool = True, *, resolved: bool = False) -> str: from poetry.core.packages.utils.utils import convert_markers - if resolved and hasattr(self, "base_pep_508_name_resolved"): - requirement: str = self.base_pep_508_name_resolved + if resolved: + requirement = self.base_pep_508_name_resolved else: requirement = self.base_pep_508_name diff --git a/tests/packages/test_vcs_dependency.py b/tests/packages/test_vcs_dependency.py index e6961e1a4..214dd90b4 100644 --- a/tests/packages/test_vcs_dependency.py +++ b/tests/packages/test_vcs_dependency.py @@ -21,6 +21,10 @@ {"extras": ["foo", "bar"]}, "poetry[bar,foo] @ git+https://github.com/python-poetry/poetry.git", ), + ( + {"extras": ["foo", "bar"], "branch": "main"}, + "poetry[bar,foo] @ git+https://github.com/python-poetry/poetry.git@main", + ), ( {"branch": "main"}, "poetry @ git+https://github.com/python-poetry/poetry.git@main", @@ -66,6 +70,10 @@ def test_to_pep_508(kwargs: dict[str, Any], expected: str) -> None: {"extras": ["foo", "bar"]}, "poetry[bar,foo] @ git+https://github.com/python-poetry/poetry.git", ), + ( + {"extras": ["foo", "bar"], "branch": "main", "resolved_rev": "aaaa"}, + "poetry[bar,foo] @ git+https://github.com/python-poetry/poetry.git@aaaa", + ), ( {"branch": "main", "resolved_rev": "aaaa"}, "poetry @ git+https://github.com/python-poetry/poetry.git@aaaa", From 0cc040f60ef79092de96fe9537b6722ac96faebd Mon Sep 17 00:00:00 2001 From: Maarten Derickx Date: Mon, 12 Jun 2023 21:49:32 +0200 Subject: [PATCH 4/5] Address second round of comments --- tests/packages/test_dependency.py | 1 + 1 file changed, 1 insertion(+) diff --git a/tests/packages/test_dependency.py b/tests/packages/test_dependency.py index cf2e7e1c4..822dfb8bd 100644 --- a/tests/packages/test_dependency.py +++ b/tests/packages/test_dependency.py @@ -137,6 +137,7 @@ def test_to_pep_508_with_patch_python_version( expected = f"Django (>=1.23,<2.0) ; {marker}" assert dependency.to_pep_508() == expected + assert dependency.to_pep_508(resolved=True) == expected assert str(dependency.marker) == marker From a5496a9c7fac3777f52c3582910111981c3434df Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Randy=20D=C3=B6ring?= <30527984+radoering@users.noreply.github.com> Date: Tue, 13 Jun 2023 17:17:34 +0200 Subject: [PATCH 5/5] Update src/poetry/core/packages/vcs_dependency.py --- src/poetry/core/packages/vcs_dependency.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/poetry/core/packages/vcs_dependency.py b/src/poetry/core/packages/vcs_dependency.py index b9cbbbaf8..409af4a72 100644 --- a/src/poetry/core/packages/vcs_dependency.py +++ b/src/poetry/core/packages/vcs_dependency.py @@ -101,7 +101,7 @@ def pretty_constraint(self) -> str: return f"{what} {version}" - def _base_pep_508_name(self, resolved: bool = False) -> str: + def _base_pep_508_name(self, *, resolved: bool = False) -> str: from poetry.core.vcs import git requirement = self.pretty_name