conflict checker: skip packages obsoleted by packages under test (#20) #21
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.
As explained in issue #20, when checking for conflicts, it's not enough to skip only existing packages with the same name as the one they are being checked against. We should skip all existing packages that the set of packages being tested would replace.
Fortunately, we already have
_select_obsoleted_by
to do this exact job, so let's just use it here.We keep the existing 'skip if the names are the same' check to avoid generating confusing results if the update under test contains a package with the same name as an existing package but with a lower EVR. This is wrong, but we should leave it to be caught by other checks; handling it here would give a rather confusing failure about file conflicts between the two packages, which the packager might not understand.