mirror of
https://github.com/enpaul/tox-poetry-installer.git
synced 2025-01-15 08:43:29 +00:00
Change version to 0.9, address some review nits and use poetry 1.2 rather than pre-release.
This commit is contained in:
parent
a181da95b3
commit
73ddd43284
3
.github/scripts/setup-env.sh
vendored
3
.github/scripts/setup-env.sh
vendored
@ -8,8 +8,7 @@
|
|||||||
set -e;
|
set -e;
|
||||||
|
|
||||||
CI_CACHE=$HOME/.cache;
|
CI_CACHE=$HOME/.cache;
|
||||||
POETRY_VERSION=1.2.0b3;
|
POETRY_VERSION=1.2.0;
|
||||||
POETRY_PREVIEW=1;
|
|
||||||
|
|
||||||
mkdir --parents "$CI_CACHE";
|
mkdir --parents "$CI_CACHE";
|
||||||
|
|
||||||
|
2
.github/workflows/ci.yaml
vendored
2
.github/workflows/ci.yaml
vendored
@ -69,7 +69,7 @@ jobs:
|
|||||||
~/.cache/pip
|
~/.cache/pip
|
||||||
~/.cache/pypoetry/cache
|
~/.cache/pypoetry/cache
|
||||||
~/.poetry
|
~/.poetry
|
||||||
# Hardcoded 'py310' slug here lets this cache piggyback on the 'py38' cache
|
# Hardcoded 'py310' slug here lets this cache piggyback on the 'py310' cache
|
||||||
# that is generated for the tests above
|
# that is generated for the tests above
|
||||||
key: ${{ runner.os }}-py310-${{ hashFiles('**/poetry.lock') }}
|
key: ${{ runner.os }}-py310-${{ hashFiles('**/poetry.lock') }}
|
||||||
|
|
||||||
|
15
CHANGELOG.md
15
CHANGELOG.md
@ -2,15 +2,18 @@
|
|||||||
|
|
||||||
See also: [Github Release Page](https://github.com/enpaul/tox-poetry-installer/releases).
|
See also: [Github Release Page](https://github.com/enpaul/tox-poetry-installer/releases).
|
||||||
|
|
||||||
## Version 1.0a1
|
## Version 0.9
|
||||||
|
|
||||||
View this release on:
|
View this release on:
|
||||||
[Github](https://github.com/enpaul/tox-poetry-installer/releases/tag/1.0a1),
|
[Github](https://github.com/enpaul/tox-poetry-installer/releases/tag/0.9.0),
|
||||||
[PyPI](https://pypi.org/project/tox-poetry-installer/1.0a1/)
|
[PyPI](https://pypi.org/project/tox-poetry-installer/0.9.0/)
|
||||||
|
|
||||||
- Drop python3.6 support, since Poetry 1.2 dropped py3.6 support
|
- Add support for Poetry-1.2.x (#73)
|
||||||
- Support Poetry==1.2.0b3 (prerelease)
|
- Update Black formatting to stable release version
|
||||||
- Added direct dep on cleo (prerelease) to support passing in NullIO to poetry functions
|
- Remove support for Python-3.6
|
||||||
|
- Remove support for Poetry-1.1.x
|
||||||
|
- Fix installing dependencies multiple times when transient dependencies are duplicated in
|
||||||
|
the dependency tree
|
||||||
|
|
||||||
## Version 0.8.5
|
## Version 0.8.5
|
||||||
|
|
||||||
|
678
poetry.lock
generated
678
poetry.lock
generated
File diff suppressed because it is too large
Load Diff
@ -1,6 +1,6 @@
|
|||||||
[tool.poetry]
|
[tool.poetry]
|
||||||
name = "tox-poetry-installer"
|
name = "tox-poetry-installer"
|
||||||
version = "1.0a1"
|
version = "0.9.0"
|
||||||
license = "MIT"
|
license = "MIT"
|
||||||
authors = ["Ethan Paul <24588726+enpaul@users.noreply.github.com>"]
|
authors = ["Ethan Paul <24588726+enpaul@users.noreply.github.com>"]
|
||||||
description = "A plugin for Tox that lets you install test environment dependencies from the Poetry lockfile"
|
description = "A plugin for Tox that lets you install test environment dependencies from the Poetry lockfile"
|
||||||
@ -39,21 +39,21 @@ poetry = ["poetry", "cleo"]
|
|||||||
[tool.poetry.dependencies]
|
[tool.poetry.dependencies]
|
||||||
python = "^3.7"
|
python = "^3.7"
|
||||||
cleo = {version = "^1.0.0a5", optional = true, allow-prereleases = true}
|
cleo = {version = "^1.0.0a5", optional = true, allow-prereleases = true}
|
||||||
poetry = {version = "1.2.0b3", optional = true, allow-prereleases = true}
|
poetry = {version = "^1.2.0", optional = true}
|
||||||
poetry-core = {version = "1.1.0b3", allow-prereleases = true}
|
poetry-core = "^1.1.0"
|
||||||
tox = "^3.8.0"
|
tox = "^3.8.0"
|
||||||
|
|
||||||
[tool.poetry.group.dev.dependencies]
|
[tool.poetry.group.dev.dependencies]
|
||||||
bandit = "^1.6.2"
|
bandit = "^1.6.2"
|
||||||
black = "^22.3.0"
|
black = "^22.3.0"
|
||||||
blacken-docs = { version = "^1.8.0", python = "^3.7" }
|
blacken-docs = "^1.8.0"
|
||||||
ipython = { version = "^7.18.1", python = "^3.7" }
|
ipython = "^7.18.1"
|
||||||
mdformat = "^0.6"
|
mdformat = "^0.6"
|
||||||
mdformat-gfm = "^0.2"
|
mdformat-gfm = "^0.2"
|
||||||
mypy = "^0.930"
|
mypy = "^0.930"
|
||||||
pre-commit = "^2.7.1"
|
pre-commit = "^2.7.1"
|
||||||
pre-commit-hooks = "^3.3.0"
|
pre-commit-hooks = "^3.3.0"
|
||||||
pylint = { version = "^2.13.0", python = "^3.7" }
|
pylint = "^2.13.0"
|
||||||
pytest = "^6.0.2"
|
pytest = "^6.0.2"
|
||||||
pytest-cov = "^2.10.1"
|
pytest-cov = "^2.10.1"
|
||||||
reorder-python-imports = "^2.3.5"
|
reorder-python-imports = "^2.3.5"
|
||||||
@ -63,5 +63,5 @@ tox = "^3.20.0"
|
|||||||
types-toml = "^0.10.1"
|
types-toml = "^0.10.1"
|
||||||
|
|
||||||
[build-system]
|
[build-system]
|
||||||
requires = ["poetry-core>=1.1.0b3"]
|
requires = ["poetry-core>=1.1.0"]
|
||||||
build-backend = "poetry.core.masonry.api"
|
build-backend = "poetry.core.masonry.api"
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
# pylint: disable=missing-docstring
|
# pylint: disable=missing-docstring
|
||||||
__title__ = "tox-poetry-installer"
|
__title__ = "tox-poetry-installer"
|
||||||
__summary__ = "A plugin for Tox that lets you install test environment dependencies from the Poetry lockfile"
|
__summary__ = "A plugin for Tox that lets you install test environment dependencies from the Poetry lockfile"
|
||||||
__version__ = "1.0a1"
|
__version__ = "0.9.0"
|
||||||
__url__ = "https://github.com/enpaul/tox-poetry-installer/"
|
__url__ = "https://github.com/enpaul/tox-poetry-installer/"
|
||||||
__license__ = "MIT"
|
__license__ = "MIT"
|
||||||
__authors__ = ["Ethan Paul <24588726+enpaul@users.noreply.github.com>"]
|
__authors__ = ["Ethan Paul <24588726+enpaul@users.noreply.github.com>"]
|
||||||
|
@ -20,6 +20,7 @@ PEP508_VERSION_DELIMITERS: Tuple[str, ...] = ("~=", "==", "!=", ">", "<")
|
|||||||
REPORTER_PREFIX: str = f"{__about__.__title__}:"
|
REPORTER_PREFIX: str = f"{__about__.__title__}:"
|
||||||
|
|
||||||
# Internal list of packages that poetry has deemed unsafe and are excluded from the lockfile
|
# Internal list of packages that poetry has deemed unsafe and are excluded from the lockfile
|
||||||
|
# TODO: This functionality is no longer needed, should remove in a future update.
|
||||||
UNSAFE_PACKAGES: Set[str] = set()
|
UNSAFE_PACKAGES: Set[str] = set()
|
||||||
|
|
||||||
# Number of threads to use for installing dependencies by default
|
# Number of threads to use for installing dependencies by default
|
||||||
|
@ -193,7 +193,7 @@ def tox_testenv_install_deps(venv: ToxVirtualEnv, action: ToxAction) -> Optional
|
|||||||
f"Identified {len(dev_deps)} development dependencies to install to env"
|
f"Identified {len(dev_deps)} development dependencies to install to env"
|
||||||
)
|
)
|
||||||
else:
|
else:
|
||||||
dev_deps = set()
|
dev_deps = []
|
||||||
logger.info("Env does not install development dependencies, skipping")
|
logger.info("Env does not install development dependencies, skipping")
|
||||||
|
|
||||||
env_deps = utilities.find_additional_deps(
|
env_deps = utilities.find_additional_deps(
|
||||||
@ -220,7 +220,7 @@ def tox_testenv_install_deps(venv: ToxVirtualEnv, action: ToxAction) -> Optional
|
|||||||
f"Identified {len(project_deps)} project dependencies to install to env"
|
f"Identified {len(project_deps)} project dependencies to install to env"
|
||||||
)
|
)
|
||||||
else:
|
else:
|
||||||
project_deps = set()
|
project_deps = []
|
||||||
logger.info("Env does not install project package dependencies, skipping")
|
logger.info("Env does not install project package dependencies, skipping")
|
||||||
except exceptions.ToxPoetryInstallerException as err:
|
except exceptions.ToxPoetryInstallerException as err:
|
||||||
venv.status = err.__class__.__name__
|
venv.status = err.__class__.__name__
|
||||||
@ -231,7 +231,7 @@ def tox_testenv_install_deps(venv: ToxVirtualEnv, action: ToxAction) -> Optional
|
|||||||
logger.error(f"Internal plugin error: {err}")
|
logger.error(f"Internal plugin error: {err}")
|
||||||
raise err
|
raise err
|
||||||
|
|
||||||
dependencies = dev_deps | env_deps | project_deps
|
dependencies = utilities.dedupe_packages(dev_deps + env_deps + project_deps)
|
||||||
if (
|
if (
|
||||||
venv.envconfig.config.option.parallel_install_threads
|
venv.envconfig.config.option.parallel_install_threads
|
||||||
!= constants.DEFAULT_INSTALL_THREADS
|
!= constants.DEFAULT_INSTALL_THREADS
|
||||||
|
@ -182,7 +182,7 @@ def find_project_deps(
|
|||||||
venv: "_poetry.VirtualEnv",
|
venv: "_poetry.VirtualEnv",
|
||||||
poetry: "_poetry.Poetry",
|
poetry: "_poetry.Poetry",
|
||||||
extras: Sequence[str] = (),
|
extras: Sequence[str] = (),
|
||||||
) -> Set[PoetryPackage]:
|
) -> List[PoetryPackage]:
|
||||||
"""Find the root project dependencies
|
"""Find the root project dependencies
|
||||||
|
|
||||||
Recursively identify the dependencies of the root project package
|
Recursively identify the dependencies of the root project package
|
||||||
@ -218,7 +218,7 @@ def find_project_deps(
|
|||||||
dep_name.lower(), packages, venv, allow_missing=[poetry.package.name]
|
dep_name.lower(), packages, venv, allow_missing=[poetry.package.name]
|
||||||
)
|
)
|
||||||
|
|
||||||
return set(dependencies)
|
return dedupe_packages(dependencies)
|
||||||
|
|
||||||
|
|
||||||
def find_additional_deps(
|
def find_additional_deps(
|
||||||
@ -226,7 +226,7 @@ def find_additional_deps(
|
|||||||
venv: "_poetry.VirtualEnv",
|
venv: "_poetry.VirtualEnv",
|
||||||
poetry: "_poetry.Poetry",
|
poetry: "_poetry.Poetry",
|
||||||
dep_names: Sequence[str],
|
dep_names: Sequence[str],
|
||||||
) -> Set[PoetryPackage]:
|
) -> List[PoetryPackage]:
|
||||||
"""Find additional dependencies
|
"""Find additional dependencies
|
||||||
|
|
||||||
Recursively identify the dependencies of an arbitrary list of package names
|
Recursively identify the dependencies of an arbitrary list of package names
|
||||||
@ -243,12 +243,12 @@ def find_additional_deps(
|
|||||||
dep_name.lower(), packages, venv, allow_missing=[poetry.package.name]
|
dep_name.lower(), packages, venv, allow_missing=[poetry.package.name]
|
||||||
)
|
)
|
||||||
|
|
||||||
return set(dependencies)
|
return dedupe_packages(dependencies)
|
||||||
|
|
||||||
|
|
||||||
def find_dev_deps(
|
def find_dev_deps(
|
||||||
packages: PackageMap, venv: "_poetry.VirtualEnv", poetry: "_poetry.Poetry"
|
packages: PackageMap, venv: "_poetry.VirtualEnv", poetry: "_poetry.Poetry"
|
||||||
) -> Set[PoetryPackage]:
|
) -> List[PoetryPackage]:
|
||||||
"""Find the dev dependencies
|
"""Find the dev dependencies
|
||||||
|
|
||||||
Recursively identify the Poetry dev dependencies
|
Recursively identify the Poetry dev dependencies
|
||||||
@ -277,4 +277,15 @@ def find_dev_deps(
|
|||||||
)
|
)
|
||||||
|
|
||||||
# Poetry 1.2 unions these two toml sections.
|
# Poetry 1.2 unions these two toml sections.
|
||||||
return dev_group_deps | legacy_dev_group_deps
|
return dedupe_packages(dev_group_deps + legacy_dev_group_deps)
|
||||||
|
|
||||||
|
|
||||||
|
def dedupe_packages(packages: Sequence[PoetryPackage]) -> List[PoetryPackage]:
|
||||||
|
"""Deduplicates a sequence of PoetryPackages while preserving ordering
|
||||||
|
|
||||||
|
Adapted from StackOverflow: https://stackoverflow.com/a/480227
|
||||||
|
"""
|
||||||
|
seen: Set[PoetryPackage] = set()
|
||||||
|
# Make this faster, avoid method lookup below
|
||||||
|
seen_add = seen.add
|
||||||
|
return [p for p in packages if not (p in seen or seen_add(p))]
|
||||||
|
Loading…
Reference in New Issue
Block a user