Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Pip fails to install satisfiable requirements due to bug in backjumping optimization #12317

Open
1 task done
notatallshaw opened this issue Oct 4, 2023 · 5 comments · May be fixed by #13001
Open
1 task done

Pip fails to install satisfiable requirements due to bug in backjumping optimization #12317

notatallshaw opened this issue Oct 4, 2023 · 5 comments · May be fixed by #13001
Labels
C: dependency resolution About choosing which dependencies to install type: bug A confirmed bug or unintended behavior
Milestone

Comments

@notatallshaw
Copy link
Member

notatallshaw commented Oct 4, 2023

Description

On Python 3.9 Linux pip fails to install with the following requirements:

pandas>=1.3.5,<=1.4.0
pystac>=1.8.2,<=1.8.3
pystac-client>=0.3.2,<=0.3.3
sat-stac<=0.1.1

Expected behavior

Should install the satisfiable requirements:

pandas==1.3.5
pystac==1.8.3
pystac-client==0.3.3
sat-stac==0.1.1

pip version

23.2.1

Python version

3.9

OS

Linux

How to Reproduce

python3.9 -m venv .venv
source .venv/bin/activate
python -m pip install pip --upgrade
pip install "pandas>=1.3.5,<=1.4.0" "pystac>=1.8.2,<=1.8.3" "pystac-client>=0.3.2,<=0.3.3" "sat-stac<=0.1.1"

Output

INFO: pip is looking at multiple versions of pystac-client to determine which version is compatible with other requirements. This could take a while.
ERROR: Cannot install pystac-client==0.3.2 and pystac<=1.8.3 and >=1.8.2 because these package versions have conflicting dependencies.

The conflict is caused by:
    The user requested pystac<=1.8.3 and >=1.8.2
    pystac-client 0.3.2 depends on pystac~=1.2.0

To fix this you could try to:
1. loosen the range of package versions you've specified
2. remove package versions to allow pip attempt to solve the dependency conflict

ERROR: ResolutionImpossible: for help visit https://pip.pypa.io/en/latest/topics/dependency-resolution/#dealing-with-dependency-conflicts

Code of Conduct

Context

This is a regression since Pip 23.1 which vendored resolvelib which included this change to backtracking: sarugaku/resolvelib#113

There is already an issue on resolvelib side: sarugaku/resolvelib#134

But given this has a bigger impact because it causes Pip to fail to install requirements when there is a valid solution I feel there should be an issue on Pip side until it is resolved.

@notatallshaw notatallshaw added S: needs triage Issues/PRs that need to be triaged type: bug A confirmed bug or unintended behavior labels Oct 4, 2023
@notatallshaw notatallshaw changed the title Pip fails to install satisfiable requirements Pip fails to install satisfiable requirements due to bug in backtracking Oct 28, 2023
@notatallshaw notatallshaw changed the title Pip fails to install satisfiable requirements due to bug in backtracking Pip fails to install satisfiable requirements due to bug in backjumping optimization Oct 28, 2023
@ichard26 ichard26 added C: dependency resolution About choosing which dependencies to install and removed S: needs triage Issues/PRs that need to be triaged labels Apr 19, 2024
@ichard26
Copy link
Member

Hi @notatallshaw, just checking in on the status of this issue. I know that we haven't bumped the vendored resolvelib yet, but would sarugaku/resolvelib#152 address this? (yes, I'm aware that you've seemingly ran into an edge-case surrounding extras.)

@ichard26
Copy link
Member

Ah, nevermind. My apologies! sarugaku/resolvelib#154

@notatallshaw
Copy link
Member Author

Yeah, sarugaku/resolvelib#152 helps some known failures, but isn't an overall fix, it's a fallback with the hope that the resolution algorithm can recover.

I thought the edge cases might be caused by extras, but they are not, backjumping requires the provider to act in a certain way which pip does not do, at least yet.

@notatallshaw
Copy link
Member Author

notatallshaw commented Aug 16, 2024

This issue will be fixed once resolvelib is released and vendored: sarugaku/resolvelib#152 (and the other cases I mentioned are covered by #12768)

@notatallshaw
Copy link
Member Author

Updating to pip 25.0 milestone as I reason here: sarugaku/resolvelib#159 (comment)

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
C: dependency resolution About choosing which dependencies to install type: bug A confirmed bug or unintended behavior
Projects
None yet
Development

Successfully merging a pull request may close this issue.

3 participants
@notatallshaw @ichard26 and others