Fix Resolver::APISet to always include prereleases when necessary #4113
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
What was the end-user or developer problem that led to this PR?
fails to install the latest rails prerelease.
What is your fix for the problem, implemented in this PR?
Previous versions of molinillo, specifically before CocoaPods/Molinillo@d29a053, would include special logic for dealing with prereleases. Now this logic needs to be implemented by the specification provider, in this case, rubygems.
That change in molinillo made an issue in our
Resolver::APISet
implementation manifest, where even if the set has been created with theprerelease
flag, it would fail to return prereleases unless the dependency explicitly allowed them. For example, it would return prereleases given the dependency "activesupport, = 6.1.rc2", but it will fail to return prereleases given the dependency "activesupport, >= 4.2.0". In the latter case, we also want prereleases returned when the--pre
flag has been passed togem install
, i.e., when the API set has been created with the prerelease flag.Fixes #4112.
Make sure the following tasks are checked