Skip to content

Commit

Permalink
Fix for "poetry lock --no-update" so that dependencies with extras ar…
Browse files Browse the repository at this point in the history
…e not updated unnecessarily
  • Loading branch information
radoering committed Nov 21, 2021
1 parent 7aefbd6 commit 8b5b090
Show file tree
Hide file tree
Showing 2 changed files with 45 additions and 4 deletions.
19 changes: 15 additions & 4 deletions src/poetry/mixology/version_solver.py
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
import time

from contextlib import suppress
from typing import TYPE_CHECKING
from typing import Dict
from typing import List
Expand Down Expand Up @@ -374,10 +375,20 @@ def _get_min(dependency: Dependency) -> Tuple[bool, int]:
)
return dependency.complete_name

try:
version = packages[0]
except IndexError:
version = None
version = None
if dependency.name not in self._use_latest:
# prefer locked version of compatible (not exact same) dependency;
# required in order to not unnecessarily update dependencies with
# extras, e.g. "coverage" vs. "coverage[toml]"
locked = self._locked.get(dependency.name, None)
if locked is not None:
for version in packages:
if version.version <= locked.version:
if version.version != locked.version:
version = None
break
with suppress(IndexError):
version = version or packages[0]

if version is None:
# If there are no versions that satisfy the constraint,
Expand Down
30 changes: 30 additions & 0 deletions tests/mixology/version_solver/test_with_lock.py
Original file line number Diff line number Diff line change
Expand Up @@ -134,3 +134,33 @@ def test_with_compatible_locked_dependencies_use_latest(
},
use_latest=["foo"],
)


def test_with_compatible_locked_dependencies_with_extras(root, provider, repo):
root.add_dependency(Factory.create_dependency("foo", "^1.0"))

package_foo_0 = get_package("foo", "1.0.0")
package_foo_1 = get_package("foo", "1.0.1")
bar_extra_dep = Factory.create_dependency(
"bar", {"version": "^1.0", "extras": "extra"}
)
for package_foo in (package_foo_0, package_foo_1):
package_foo.add_dependency(bar_extra_dep)
repo.add_package(package_foo)

bar_deps = {"baz": {"version": "^1.0", "extras": ["extra"]}}
add_to_repo(repo, "bar", "1.0.0", bar_deps)
add_to_repo(repo, "bar", "1.0.1", bar_deps)
add_to_repo(repo, "baz", "1.0.0")
add_to_repo(repo, "baz", "1.0.1")

check_solver_result(
root,
provider,
result={"foo": "1.0.0", "bar": "1.0.0", "baz": "1.0.0"},
locked={
"foo": get_package("foo", "1.0.0"),
"bar": get_package("bar", "1.0.0"),
"baz": get_package("baz", "1.0.0"),
},
)

0 comments on commit 8b5b090

Please sign in to comment.