Skip to content

Commit

Permalink
Parse extras correctly at 'poetry add'
Browse files Browse the repository at this point in the history
  • Loading branch information
dimbleby committed Apr 30, 2023
1 parent 22efbad commit 3a7b8f7
Show file tree
Hide file tree
Showing 2 changed files with 53 additions and 1 deletion.
2 changes: 1 addition & 1 deletion src/poetry/console/commands/add.py
Original file line number Diff line number Diff line change
Expand Up @@ -192,7 +192,7 @@ def handle(self) -> int:
for extra in self.option("extras"):
extras += extra.split()

constraint["extras"] = self.option("extras")
constraint["extras"] = extras

if self.option("editable"):
if "git" in _constraint or "path" in _constraint:
Expand Down
52 changes: 52 additions & 0 deletions tests/console/commands/test_add.py
Original file line number Diff line number Diff line change
Expand Up @@ -1415,3 +1415,55 @@ def test_add_with_path_dependency_no_loopiness(

with pytest.raises(SolverProblemError):
tester.execute("requests")


def test_add_extras_are_parsed_and_included(
app: PoetryTestApplication,
repo: TestRepository,
tester: CommandTester,
) -> None:
msgpack_dep = get_dependency("msgpack-python", ">=0.5 <0.6", optional=True)
redis_dep = get_dependency("redis", ">=3.3.6 <4.0.0", optional=True)

cachy = get_package("cachy", "0.2.0")
cachy.add_dependency(msgpack_dep)
cachy.add_dependency(redis_dep)
cachy.extras = {
canonicalize_name("redis"): [redis_dep],
canonicalize_name("msgpack"): [msgpack_dep],
}
repo.add_package(cachy)

msgpack = get_package("msgpack-python", "0.5.1")
repo.add_package(msgpack)

redis = get_package("redis", "3.4.0")
repo.add_package(redis)

tester.execute('cachy --extras "redis msgpack"')

expected = """\
Using version ^0.2.0 for cachy
Updating dependencies
Resolving dependencies...
Package operations: 3 installs, 0 updates, 0 removals
• Installing msgpack-python (0.5.1)
• Installing redis (3.4.0)
• Installing cachy (0.2.0)
Writing lock file
"""

assert tester.io.fetch_output() == expected

pyproject: dict[str, Any] = app.poetry.file.read()
content = pyproject["tool"]["poetry"]

assert "cachy" in content["dependencies"]
assert content["dependencies"]["cachy"] == {
"version": "^0.2.0",
"extras": ["redis", "msgpack"],
}

0 comments on commit 3a7b8f7

Please sign in to comment.