Use Excuse.is_valid when iterating through checks and Policies

This gives Policies the opportunity to see if a previous check
(build/installability) or earlier policies already invalidated the update. This
allows writing policies that work on groups of packages, or skipping expensive
checks (such as triggering autopkgtests while the package is not built or
installable yet).
pre-rebase-2016-12-12
Martin Pitt 8 years ago
parent df38b9e687
commit 497edc6d6c

@ -1446,9 +1446,6 @@ class Britney(object):
source_u.maintainer and excuse.set_maint(source_u.maintainer) source_u.maintainer and excuse.set_maint(source_u.maintainer)
source_u.section and excuse.set_section(source_u.section) source_u.section and excuse.set_section(source_u.section)
# the starting point is that we will update the candidate
update_candidate = True
# if the version in unstable is older, then stop here with a warning in the excuse and return False # if the version in unstable is older, then stop here with a warning in the excuse and return False
if source_t and apt_pkg.version_compare(source_u.version, source_t.version) < 0: if source_t and apt_pkg.version_compare(source_u.version, source_t.version) < 0:
excuse.addhtml("ALERT: %s is newer in testing (%s %s)" % (src, source_t.version, source_u.version)) excuse.addhtml("ALERT: %s is newer in testing (%s %s)" % (src, source_t.version, source_u.version))
@ -1456,10 +1453,13 @@ class Britney(object):
excuse.addreason("newerintesting") excuse.addreason("newerintesting")
return False return False
# the starting point is that we will update the candidate
excuse.is_valid = True
# check if the source package really exists or if it is a fake one # check if the source package really exists or if it is a fake one
if source_u.is_fakesrc: if source_u.is_fakesrc:
excuse.addhtml("%s source package doesn't exist" % (src)) excuse.addhtml("%s source package doesn't exist" % (src))
update_candidate = False excuse.is_valid = False
# if there is a `remove' hint and the requested version is the same as the # if there is a `remove' hint and the requested version is the same as the
# version in testing, then stop here and return False # version in testing, then stop here and return False
@ -1469,7 +1469,7 @@ class Britney(object):
excuse.add_hint(hint) excuse.add_hint(hint)
excuse.addhtml("Removal request by %s" % (hint.user)) excuse.addhtml("Removal request by %s" % (hint.user))
excuse.addhtml("Trying to remove package, not update it") excuse.addhtml("Trying to remove package, not update it")
update_candidate = False excuse.is_valid = False
# check if there is a `block' or `block-udeb' hint for this package, or a `block-all source' hint # check if there is a `block' or `block-udeb' hint for this package, or a `block-all source' hint
blocked = {} blocked = {}
@ -1523,7 +1523,7 @@ class Britney(object):
else: else:
excuse.addhtml("NEEDS APPROVAL BY RM") excuse.addhtml("NEEDS APPROVAL BY RM")
excuse.addreason("block") excuse.addreason("block")
update_candidate = False excuse.is_valid = False
# at this point, we check the status of the builds on all the supported architectures # at this point, we check the status of the builds on all the supported architectures
# to catch the out-of-date ones # to catch the out-of-date ones
@ -1562,9 +1562,9 @@ class Britney(object):
if binary_u.architecture != 'all' or arch in self.options.nobreakall_arches: if binary_u.architecture != 'all' or arch in self.options.nobreakall_arches:
is_valid = self.excuse_unsat_deps(pkg, src, arch, suite, excuse) is_valid = self.excuse_unsat_deps(pkg, src, arch, suite, excuse)
if not is_valid and not source_t: if not is_valid and not source_t:
update_candidate = False excuse.is_valid = False
# if there are out-of-date packages, warn about them in the excuse and set update_candidate # if there are out-of-date packages, warn about them in the excuse and set is_valid
# to False to block the update; if the architecture where the package is out-of-date is # to False to block the update; if the architecture where the package is out-of-date is
# in the `outofsync_arches' list, then do not block the update # in the `outofsync_arches' list, then do not block the update
if oodbins: if oodbins:
@ -1592,22 +1592,22 @@ class Britney(object):
if self.options.ignore_cruft: if self.options.ignore_cruft:
text = text + " (but ignoring cruft, so nevermind)" text = text + " (but ignoring cruft, so nevermind)"
else: else:
update_candidate = False excuse.is_valid = False
else: else:
update_candidate = False excuse.is_valid = False
excuse.missing_build_on_arch(arch) excuse.missing_build_on_arch(arch)
excuse.addhtml(text) excuse.addhtml(text)
# if the source package has no binaries, set update_candidate to False to block the update # if the source package has no binaries, set is_valid to False to block the update
if not source_u.binaries: if not source_u.binaries:
excuse.addhtml("%s has no binaries on any arch" % src) excuse.addhtml("%s has no binaries on any arch" % src)
excuse.addreason("no-binaries") excuse.addreason("no-binaries")
update_candidate = False excuse.is_valid = False
# if the suite is unstable, then we have to check the urgency and the minimum days of # if the suite is unstable, then we have to check the urgency and the minimum days of
# permanence in unstable before updating testing; if the source package is too young, # permanence in unstable before updating testing; if the source package is too young,
# the check fails and we set update_candidate to False to block the update; consider # the check fails and we set is_valid to False to block the update; consider
# the age-days hint, if specified for the package # the age-days hint, if specified for the package
policy_info = excuse.policy_info policy_info = excuse.policy_info
policy_verdict = PolicyVerdict.PASS policy_verdict = PolicyVerdict.PASS
@ -1618,7 +1618,7 @@ class Britney(object):
policy_verdict = v policy_verdict = v
if policy_verdict.is_rejected: if policy_verdict.is_rejected:
update_candidate = False excuse.is_valid = False
if suite in ('pu', 'tpu') and source_t: if suite in ('pu', 'tpu') and source_t:
# o-o-d(ish) checks for (t-)p-u # o-o-d(ish) checks for (t-)p-u
@ -1649,7 +1649,7 @@ class Britney(object):
text = text + " (but %s isn't keeping up, so never mind)" % (arch) text = text + " (but %s isn't keeping up, so never mind)" % (arch)
excuse.missing_build_on_ood_arch(arch) excuse.missing_build_on_ood_arch(arch)
else: else:
update_candidate = False excuse.is_valid = False
excuse.missing_build_on_arch(arch) excuse.missing_build_on_arch(arch)
excuse.addhtml(text) excuse.addhtml(text)
@ -1658,17 +1658,13 @@ class Britney(object):
forces = self.hints.search('force', package=src, version=source_u.version) forces = self.hints.search('force', package=src, version=source_u.version)
if forces: if forces:
excuse.dontinvalidate = True excuse.dontinvalidate = True
if not update_candidate and forces: if not excuse.is_valid and forces:
excuse.addhtml("Should ignore, but forced by %s" % (forces[0].user)) excuse.addhtml("Should ignore, but forced by %s" % (forces[0].user))
excuse.force() excuse.force()
update_candidate = True
# if the package can be updated, it is a valid candidate
if update_candidate:
excuse.is_valid = True excuse.is_valid = True
self.excuses[excuse.name] = excuse self.excuses[excuse.name] = excuse
return update_candidate return excuse.is_valid
def reversed_exc_deps(self): def reversed_exc_deps(self):
"""Reverse the excuses dependencies """Reverse the excuses dependencies

Loading…
Cancel
Save