@ -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