Skip to content

Commit

Permalink
use tempfile.TemporaryDirectory
Browse files Browse the repository at this point in the history
  • Loading branch information
dimbleby committed Mar 18, 2023
1 parent 6088821 commit 64d7c86
Show file tree
Hide file tree
Showing 3 changed files with 16 additions and 26 deletions.
10 changes: 0 additions & 10 deletions src/poetry/core/utils/helpers.py
Original file line number Diff line number Diff line change
Expand Up @@ -3,14 +3,11 @@
import os
import shutil
import stat
import tempfile
import unicodedata
import warnings

from contextlib import contextmanager
from pathlib import Path
from typing import Any
from typing import Iterator

from packaging.utils import canonicalize_name

Expand All @@ -34,13 +31,6 @@ def normalize_version(version: str) -> str:
return PEP440Version.parse(version).to_string()


@contextmanager
def temporary_directory(*args: Any, **kwargs: Any) -> Iterator[str]:
name = tempfile.mkdtemp(*args, **kwargs)
yield name
safe_rmtree(name)


def parse_requires(requires: str) -> list[str]:
lines = requires.split("\n")

Expand Down
28 changes: 14 additions & 14 deletions tests/masonry/test_api.py
Original file line number Diff line number Diff line change
Expand Up @@ -6,11 +6,11 @@
from contextlib import contextmanager
from pathlib import Path
from typing import TYPE_CHECKING
from tempfile import TemporaryDirectory
from typing import Iterator

from poetry.core import __version__
from poetry.core.masonry import api
from poetry.core.utils.helpers import temporary_directory
from tests.testutils import validate_sdist_contents
from tests.testutils import validate_wheel_contents

Expand Down Expand Up @@ -45,7 +45,7 @@ def test_get_requires_for_build_sdist() -> None:


def test_build_wheel() -> None:
with temporary_directory() as tmp_dir, cwd(os.path.join(fixtures, "complete")):
with TemporaryDirectory() as tmp_dir, cwd(os.path.join(fixtures, "complete")):
filename = api.build_wheel(tmp_dir)
validate_wheel_contents(
name="my_package",
Expand All @@ -56,7 +56,7 @@ def test_build_wheel() -> None:


def test_build_wheel_with_include() -> None:
with temporary_directory() as tmp_dir, cwd(os.path.join(fixtures, "with-include")):
with TemporaryDirectory() as tmp_dir, cwd(os.path.join(fixtures, "with-include")):
filename = api.build_wheel(tmp_dir)
validate_wheel_contents(
name="with_include",
Expand All @@ -67,14 +67,14 @@ def test_build_wheel_with_include() -> None:


def test_build_wheel_with_bad_path_dev_dep_succeeds() -> None:
with temporary_directory() as tmp_dir, cwd(
with TemporaryDirectory() as tmp_dir, cwd(
os.path.join(fixtures, "with_bad_path_dev_dep")
):
api.build_wheel(tmp_dir)


def test_build_wheel_with_bad_path_dep_succeeds(caplog: LogCaptureFixture) -> None:
with temporary_directory() as tmp_dir, cwd(
with TemporaryDirectory() as tmp_dir, cwd(
os.path.join(fixtures, "with_bad_path_dep")
):
api.build_wheel(tmp_dir)
Expand All @@ -85,15 +85,15 @@ def test_build_wheel_with_bad_path_dep_succeeds(caplog: LogCaptureFixture) -> No


def test_build_wheel_extended() -> None:
with temporary_directory() as tmp_dir, cwd(os.path.join(fixtures, "extended")):
with TemporaryDirectory() as tmp_dir, cwd(os.path.join(fixtures, "extended")):
filename = api.build_wheel(tmp_dir)
whl = Path(tmp_dir) / filename
assert whl.exists()
validate_wheel_contents(name="extended", version="0.1", path=whl.as_posix())


def test_build_sdist() -> None:
with temporary_directory() as tmp_dir, cwd(os.path.join(fixtures, "complete")):
with TemporaryDirectory() as tmp_dir, cwd(os.path.join(fixtures, "complete")):
filename = api.build_sdist(tmp_dir)
validate_sdist_contents(
name="my-package",
Expand All @@ -104,7 +104,7 @@ def test_build_sdist() -> None:


def test_build_sdist_with_include() -> None:
with temporary_directory() as tmp_dir, cwd(os.path.join(fixtures, "with-include")):
with TemporaryDirectory() as tmp_dir, cwd(os.path.join(fixtures, "with-include")):
filename = api.build_sdist(tmp_dir)
validate_sdist_contents(
name="with-include",
Expand All @@ -115,14 +115,14 @@ def test_build_sdist_with_include() -> None:


def test_build_sdist_with_bad_path_dev_dep_succeeds() -> None:
with temporary_directory() as tmp_dir, cwd(
with TemporaryDirectory() as tmp_dir, cwd(
os.path.join(fixtures, "with_bad_path_dev_dep")
):
api.build_sdist(tmp_dir)


def test_build_sdist_with_bad_path_dep_succeeds(caplog: LogCaptureFixture) -> None:
with temporary_directory() as tmp_dir, cwd(
with TemporaryDirectory() as tmp_dir, cwd(
os.path.join(fixtures, "with_bad_path_dep")
):
api.build_sdist(tmp_dir)
Expand Down Expand Up @@ -182,7 +182,7 @@ def test_prepare_metadata_for_build_wheel() -> None:
==========
"""
with temporary_directory() as tmp_dir, cwd(os.path.join(fixtures, "complete")):
with TemporaryDirectory() as tmp_dir, cwd(os.path.join(fixtures, "complete")):
dirname = api.prepare_metadata_for_build_wheel(tmp_dir)

assert dirname == "my_package-1.2.3.dist-info"
Expand All @@ -204,7 +204,7 @@ def test_prepare_metadata_for_build_wheel() -> None:


def test_prepare_metadata_for_build_wheel_with_bad_path_dev_dep_succeeds() -> None:
with temporary_directory() as tmp_dir, cwd(
with TemporaryDirectory() as tmp_dir, cwd(
os.path.join(fixtures, "with_bad_path_dev_dep")
):
api.prepare_metadata_for_build_wheel(tmp_dir)
Expand All @@ -213,7 +213,7 @@ def test_prepare_metadata_for_build_wheel_with_bad_path_dev_dep_succeeds() -> No
def test_prepare_metadata_for_build_wheel_with_bad_path_dep_succeeds(
caplog: LogCaptureFixture,
) -> None:
with temporary_directory() as tmp_dir, cwd(
with TemporaryDirectory() as tmp_dir, cwd(
os.path.join(fixtures, "with_bad_path_dep")
):
api.prepare_metadata_for_build_wheel(tmp_dir)
Expand All @@ -226,7 +226,7 @@ def test_prepare_metadata_for_build_wheel_with_bad_path_dep_succeeds(
def test_build_editable_wheel() -> None:
pkg_dir = Path(fixtures) / "complete"

with temporary_directory() as tmp_dir, cwd(pkg_dir):
with TemporaryDirectory() as tmp_dir, cwd(pkg_dir):
filename = api.build_editable(tmp_dir)
wheel_pth = Path(tmp_dir) / filename

Expand Down
4 changes: 2 additions & 2 deletions tests/utils/test_helpers.py
Original file line number Diff line number Diff line change
Expand Up @@ -4,13 +4,13 @@

from pathlib import Path
from stat import S_IREAD
from tempfile import TemporaryDirectory

import pytest

from poetry.core.utils.helpers import combine_unicode
from poetry.core.utils.helpers import parse_requires
from poetry.core.utils.helpers import readme_content_type
from poetry.core.utils.helpers import temporary_directory


def test_parse_requires() -> None:
Expand Down Expand Up @@ -93,7 +93,7 @@ def test_utils_helpers_combine_unicode() -> None:


def test_utils_helpers_temporary_directory_readonly_file() -> None:
with temporary_directory() as temp_dir:
with TemporaryDirectory() as temp_dir:
readonly_filename = os.path.join(temp_dir, "file.txt")
with open(readonly_filename, "w+") as readonly_file:
readonly_file.write("Poetry rocks!")
Expand Down

0 comments on commit 64d7c86

Please sign in to comment.