Track uninstallable arch:all packages on non-nobreakall archs

When an arch:all binary is uninstallable on a non-nobreakall arch, don't
block it, but still mark it as uninstallable, so the autopkgtest policy
knows not to schedule tests for it.
ubuntu/rebased
Ivo De Decker 5 years ago
parent 455d962ebd
commit 976accaf57

@ -821,9 +821,6 @@ class DependsPolicy(BasePolicy):
binary_u = packages_s_a[pkg_name] binary_u = packages_s_a[pkg_name]
pkg_arch = binary_u.architecture pkg_arch = binary_u.architecture
if pkg_arch == 'all' and arch not in self.nobreakall_arches:
continue
if (binary_u.source_version != source_data_srcdist.version): if (binary_u.source_version != source_data_srcdist.version):
# don't check cruft in unstable # don't check cruft in unstable
continue continue
@ -850,14 +847,21 @@ class DependsPolicy(BasePolicy):
if pkg_id in self.broken_packages: if pkg_id in self.broken_packages:
# dependencies can't be satisfied by all the known binaries - # dependencies can't be satisfied by all the known binaries -
# this certainly won't work # this certainly won't work...
excuse.add_unsatisfiable_on_arch(arch)
if pkg_arch == 'all' and arch not in self.nobreakall_arches:
# ...but if the binary is arch all on a non-nobreakarch
# all, we don't care
# we still wan't the binary to be listed as uninstallable,
# so the autopkgtest policy knows not to try to run tests
continue
verdict = PolicyVerdict.REJECTED_PERMANENTLY verdict = PolicyVerdict.REJECTED_PERMANENTLY
excuse.add_verdict_info(verdict, "%s/%s has unsatisfiable dependency" % ( excuse.add_verdict_info(verdict, "%s/%s has unsatisfiable dependency" % (
pkg_name, arch)) pkg_name, arch))
excuse.addreason("depends") excuse.addreason("depends")
# TODO does this also need to happen on non-nobreakarch if the
# arch:all packages are uninstallable? if pkg_arch == 'all' and arch not in self.nobreakall_arches:
excuse.add_unsatisfiable_on_arch(arch) continue
deps = self.pkg_universe.dependencies_of(pkg_id) deps = self.pkg_universe.dependencies_of(pkg_id)

Loading…
Cancel
Save