Pass excuse to BasePolicy.apply_policy()

This allows tests to check whether there are any missing builds or old
binaries, so that expensive actions such as "trigger an autopkgtest" are not
done too early/in vain.
pre-rebase-2016-12-12
Martin Pitt 8 years ago
parent a401a463bf
commit 1e9a16499a

@ -1613,7 +1613,7 @@ class Britney(object):
policy_verdict = PolicyVerdict.PASS policy_verdict = PolicyVerdict.PASS
for policy in self.policies: for policy in self.policies:
if suite in policy.applicable_suites: if suite in policy.applicable_suites:
v = policy.apply_policy(policy_info, suite, src, source_t, source_u) v = policy.apply_policy(policy_info, suite, src, source_t, source_u, excuse)
if v.value > policy_verdict.value: if v.value > policy_verdict.value:
policy_verdict = v policy_verdict = v

@ -93,15 +93,15 @@ class BasePolicy(object):
pass pass
def apply_policy(self, general_policy_info, suite, source_name, source_data_tdist, source_data_srcdist): def apply_policy(self, general_policy_info, suite, source_name, source_data_tdist, source_data_srcdist, excuse):
if self.policy_id not in general_policy_info: if self.policy_id not in general_policy_info:
general_policy_info[self.policy_id] = pinfo = {} general_policy_info[self.policy_id] = pinfo = {}
else: else:
pinfo = general_policy_info[self.policy_id] pinfo = general_policy_info[self.policy_id]
return self.apply_policy_impl(pinfo, suite, source_name, source_data_tdist, source_data_srcdist) return self.apply_policy_impl(pinfo, suite, source_name, source_data_tdist, source_data_srcdist, excuse)
@abstractmethod @abstractmethod
def apply_policy_impl(self, policy_info, suite, source_name, source_data_tdist, source_data_srcdist): def apply_policy_impl(self, policy_info, suite, source_name, source_data_tdist, source_data_srcdist, excuse):
"""Apply a policy on a given source migration """Apply a policy on a given source migration
Britney will call this method on a given source package, when Britney will call this method on a given source package, when
@ -227,7 +227,7 @@ class AgePolicy(BasePolicy):
super().save_state(britney) super().save_state(britney)
self._write_dates_file() self._write_dates_file()
def apply_policy_impl(self, age_info, suite, source_name, source_data_tdist, source_data_srcdist): def apply_policy_impl(self, age_info, suite, source_name, source_data_tdist, source_data_srcdist, excuse):
# retrieve the urgency for the upload, ignoring it if this is a NEW package (not present in testing) # retrieve the urgency for the upload, ignoring it if this is a NEW package (not present in testing)
urgency = self._urgencies.get(source_name, self.options.default_urgency) urgency = self._urgencies.get(source_name, self.options.default_urgency)
@ -419,7 +419,7 @@ class RCBugPolicy(BasePolicy):
self._bugs['unstable'] = self._read_bugs(filename_unstable) self._bugs['unstable'] = self._read_bugs(filename_unstable)
self._bugs['testing'] = self._read_bugs(filename_testing) self._bugs['testing'] = self._read_bugs(filename_testing)
def apply_policy_impl(self, rcbugs_info, suite, source_name, source_data_tdist, source_data_srcdist): def apply_policy_impl(self, rcbugs_info, suite, source_name, source_data_tdist, source_data_srcdist, excuse):
bugs_t = set() bugs_t = set()
bugs_u = set() bugs_u = set()

Loading…
Cancel
Save