Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Support Poetry 2.0 and PEP 621 #1223

Merged
merged 1 commit into from
Jan 10, 2025
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
25 changes: 21 additions & 4 deletions noxfile.py
Original file line number Diff line number Diff line change
Expand Up @@ -171,12 +171,30 @@ def mypy(session: Session) -> None:
@nox.parametrize(
"python,poetry",
[
(python_versions[0], "1.6.1"),
(python_versions[0], "poetry==1.6.1"),
(python_versions[0], "poetry==1.8.5"),
(python_versions[0], "poetry==2.0.0"),
(
python_versions[0],
"poetry @ git+https://github.com/python-poetry/poetry.git@main",
),
*((python, None) for python in python_versions),
],
)
def tests(session: Session, poetry: Optional[str]) -> None:
"""Run the test suite."""
# Install poetry first to ensure the correct version is used for 'poetry build'.
if poetry is not None:
session.run_always(
"python",
"-m",
"pip",
"install",
poetry,
"poetry-plugin-export",
silent=True,
)

session.install(".")
session.install(
"coverage[toml]",
Expand All @@ -187,10 +205,9 @@ def tests(session: Session, poetry: Optional[str]) -> None:
"typing_extensions",
)

# Override nox-poetry's locked Poetry version.
if poetry is not None:
session.run_always(
"python", "-m", "pip", "install", f"poetry=={poetry}", silent=True
)
session.run_always("python", "-m", "pip", "install", poetry, silent=True)

try:
session.run("coverage", "run", "--parallel", "-m", "pytest", *session.posargs)
Expand Down
286 changes: 143 additions & 143 deletions poetry.lock

Large diffs are not rendered by default.

5 changes: 3 additions & 2 deletions src/nox_poetry/poetry.py
Original file line number Diff line number Diff line change
Expand Up @@ -33,12 +33,13 @@ def __init__(self, project: Path) -> None:
path = project / "pyproject.toml"
text = path.read_text(encoding="utf-8")
data: Any = tomlkit.parse(text)
self._config = data["tool"]["poetry"]
self._config = data.get("tool", {}).get("poetry", {})
self._pyproject = data.get("project", {})

@property
def name(self) -> str:
"""Return the package name."""
name = self._config["name"]
name = self._config.get("name", self._pyproject.get("name"))
assert isinstance(name, str) # noqa: S101
return name

Expand Down
4 changes: 3 additions & 1 deletion tests/functional/conftest.py
Original file line number Diff line number Diff line change
Expand Up @@ -46,7 +46,9 @@ def _read_toml(self, filename: str) -> Any:

def _get_config(self, key: str) -> Any:
data: Any = self._read_toml("pyproject.toml")
return data["tool"]["poetry"][key]
poetry_config = data.get("tool", {}).get("poetry", {})
pyproject = data.get("project", {})
return poetry_config.get(key, pyproject.get(key))

def get_dependency(self, name: str, data: Any = None) -> Package:
"""Return the package with the given name."""
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
"""A project that uses PEP 621."""
17 changes: 17 additions & 0 deletions tests/functional/data/pep-621/poetry.lock

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

11 changes: 11 additions & 0 deletions tests/functional/data/pep-621/pyproject.toml
Original file line number Diff line number Diff line change
@@ -0,0 +1,11 @@
[project]
name = "pep-621-pyproject"
version = "0.1.0"
description = ""
authors = [{ name = "Your Name", email = "<you@example.com>" }]
requires-python = ">=3.7"
dependencies = ["pyflakes>=2.1.1"]

[build-system]
requires = ["poetry-core"]
build-backend = "poetry.core.masonry.api"
21 changes: 21 additions & 0 deletions tests/functional/test_session.py
Original file line number Diff line number Diff line change
Expand Up @@ -182,3 +182,24 @@ def test(session: nox_poetry.Session) -> None:
packages = list_packages(project, test)

assert set(expected) == set(packages)


@pytest.mark.skipif(
Version(version("poetry")) < Version("2.0.0.dev0"),
reason=f"Poetry {version('poetry')} < 2.0 does not support PEP 621",
)
def test_pep621_pyproject_support(shared_datadir: Path) -> None:
"""It installs packages from PEP 621 pyproject.toml."""
project = Project(shared_datadir / "pep-621")

@nox_poetry.session
def test(session: nox_poetry.Session) -> None:
"""Install the dependencies."""
session.install(".")

run_nox_with_noxfile(project, [test], [nox_poetry])

expected = [project.package, *project.locked_packages]
packages = list_packages(project, test)

assert set(expected) == set(packages)
Loading