Skip to content

Commit

Permalink
feat: Add is_editable wrapper function (#37)
Browse files Browse the repository at this point in the history
<!-- readthedocs-preview pep610 start -->
----
πŸ“š Documentation preview πŸ“š:
https://pep610--37.org.readthedocs.build/en/37/

<!-- readthedocs-preview pep610 end -->
  • Loading branch information
edgarrmondragon committed Feb 6, 2024
1 parent 401df76 commit 1c3a76e
Show file tree
Hide file tree
Showing 4 changed files with 83 additions and 2 deletions.
2 changes: 1 addition & 1 deletion .readthedocs.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@ version: 2
build:
os: ubuntu-22.04
tools:
python: "3.11"
python: "3.12"
jobs:
post_checkout:
- git fetch --unshallow || true
Expand Down
4 changes: 4 additions & 0 deletions docs/index.md
Original file line number Diff line number Diff line change
Expand Up @@ -117,3 +117,7 @@ for package in report["install"]:
```{eval-rst}
.. autofunction:: pep610.read_from_distribution
```

```{eval-rst}
.. autofunction:: pep610.is_editable
```
27 changes: 26 additions & 1 deletion src/pep610/__init__.py
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,7 @@
import typing as t
from dataclasses import dataclass
from functools import singledispatch
from importlib.metadata import version
from importlib.metadata import distribution, version

if t.TYPE_CHECKING:
import sys
Expand Down Expand Up @@ -355,13 +355,38 @@ def read_from_distribution(dist: Distribution) -> VCSData | ArchiveData | DirDat
Returns:
The parsed PEP 610 file.
>>> import importlib.metadata
>>> dist = importlib.metadata.distribution("pep610")
>>> read_from_distribution(dist) # doctest: +SKIP
DirData(url='file:///home/user/pep610', dir_info=DirInfo(editable=False))
"""
if contents := dist.read_text("direct_url.json"):
return parse(json.loads(contents))

return None


def is_editable(distribution_name: str) -> bool:
"""Wrapper around :func:`read_from_distribution` to check if a distribution is editable.
Args:
distribution_name: The distribution name.
Returns:
Whether the distribution is editable.
Raises:
importlib_metadata.PackageNotFoundError: If the distribution is not found.
>>> is_editable("pep610") # doctest: +SKIP
False
""" # noqa: DAR402, RUF100
dist = distribution(distribution_name)
data = read_from_distribution(dist)
return isinstance(data, DirData) and data.dir_info.is_editable()


def write_to_distribution(dist: PathDistribution, data: dict) -> int:
"""Write the direct URL data to a distribution.
Expand Down
52 changes: 52 additions & 0 deletions tests/test_parse.py
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,7 @@
HashData,
VCSData,
VCSInfo,
is_editable,
parse,
read_from_distribution,
to_dict,
Expand Down Expand Up @@ -347,3 +348,54 @@ def test_parse_pip_install_report(pip_install_report: dict):
),
),
}


@pytest.mark.parametrize(
("data", "expected"),
[
pytest.param(
{
"url": "file:///home/user/project",
"dir_info": {"editable": True},
},
True,
id="editable",
),
pytest.param(
{
"url": "file:///home/user/project",
"dir_info": {"editable": False},
},
False,
id="not_editable",
),
pytest.param(
{
"url": "file:///home/user/project",
"dir_info": {},
},
False,
id="no_editable_info",
),
pytest.param(
{
"url": "https://github.com/pypa/pip.git",
"vcs_info": {
"vcs": "git",
"requested_revision": "1.3.1",
"resolved_revision_type": "tag",
"commit_id": "7921be1537eac1e97bc40179a57f0349c2aee67d",
},
},
False,
id="vcs_git",
),
],
)
def test_is_editable(tmp_path: Path, monkeypatch: pytest.MonkeyPatch, data: dict, expected: bool): # noqa: FBT001
"""Test the is_editable function."""
dist = Distribution.at(tmp_path)
write_to_distribution(dist, data)

monkeypatch.setattr("pep610.distribution", lambda _: dist)
assert is_editable("my_package") is expected

0 comments on commit 1c3a76e

Please # to comment.