-
Notifications
You must be signed in to change notification settings - Fork 34
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
Resolvelib 0.9.0 passes identifiers to Provider's get_preference
method without accompanying PreferenceInformation
#120
Comments
I have not looked at the behaviour changes closely, but it does seem intentional.
|
Interesting, I guess the question is is it expected that these should be more preferred or less preferred? It's a little frustrating that this hasn't been adapted by Pip before landing #113 as I can't cleanly test how #111 vs #113 affected real world requirements. I guess I will just retest everything once this is vendored in to Pip. |
I see you've landed 0.9.0 on to Pip, I'll run some tests with the updated get_preference. |
@notatallshaw Do you have some notes/listing of the test cases that you're trying with the resolver? If so, would you be willing to share this list? |
Unfortunately I've never formalized it, I just ad-hoc try issues listed in the Pip issue tracker, especially ones that are still open. My testing process once I have a requirements file that is expected to be problematic is:
If I had more time to work on this there's a lot of things I would do to improve automation and reliability of testing. The most important thing would be attempting to write upper bound constraints files so new releases wouldn't break examples of long backtracking. For pip + resolvelib 0.9 (as is on pip main right now) I took the test cases I mentioned in this thread #113 and found that on Python 3.9 on Linux the following requirements both improved quite significantly:
And:
This one however still takes a long time backtracking, but I believe that #113 will find a resolution in a relatively short amount of time:
Another problem I haven't attempted to deal with is resolvelib/pip backtracking is non-deterministic. While I've never found a situation where this directly affects whether backtracking resolves in a "short" or "long" amount of time it would certainly make automating this testing even trickier. |
Prerequisites
Steps to reproduce
Output
Notes
Seems to be a regression from #111
Interestingly if I patch
get_preference
to either prefer or not prefer these identifiers the download still completes, so not sure exactly what it happening.The text was updated successfully, but these errors were encountered: