Add src_policy option to policies.

The src_policy defines wether, for source items, the source policy should be
run (RUN_SRC, the default), the arch policy should be run on every arch
(RUN_ON_EVERY_ARCH_ONLY), or both (RUN_SRC_AND_EVERY_ARCH).

Signed-off-by: Ivo De Decker <ivodd@debian.org>
ubuntu/rebased
Ivo De Decker 6 years ago
parent 82fa58df20
commit 15e5228669

@ -56,3 +56,33 @@ class PolicyVerdict(Enum):
PolicyVerdict.REJECTED_CANNOT_DETERMINE_IF_PERMANENT, # Assuming the worst PolicyVerdict.REJECTED_CANNOT_DETERMINE_IF_PERMANENT, # Assuming the worst
PolicyVerdict.REJECTED_PERMANENTLY, PolicyVerdict.REJECTED_PERMANENTLY,
} }
@unique
class ApplySrcPolicy(Enum):
"""
For a source item, run the source policy (this is the default)
"""
RUN_SRC = 1
"""
For a source item, run the arch policy on every arch
"""
RUN_ON_EVERY_ARCH_ONLY = 2
"""
For a source item, run the source policy and run the arch policy on every arch
"""
RUN_SRC_AND_EVERY_ARCH = 3
@property
def run_src(self):
return self in {
ApplySrcPolicy.RUN_SRC,
ApplySrcPolicy.RUN_SRC_AND_EVERY_ARCH,
}
@property
def run_arch(self):
return self in {
ApplySrcPolicy.RUN_ON_EVERY_ARCH_ONLY,
ApplySrcPolicy.RUN_SRC_AND_EVERY_ARCH,
}

@ -12,7 +12,7 @@ import apt_pkg
from britney2 import SuiteClass from britney2 import SuiteClass
from britney2.hints import Hint, split_into_one_hint_per_package from britney2.hints import Hint, split_into_one_hint_per_package
from britney2.inputs.suiteloader import SuiteContentLoader from britney2.inputs.suiteloader import SuiteContentLoader
from britney2.policies import PolicyVerdict from britney2.policies import PolicyVerdict, ApplySrcPolicy
from britney2.utils import get_dependency_solvers, compute_item_name from britney2.utils import get_dependency_solvers, compute_item_name
from britney2 import DependencyType from britney2 import DependencyType
@ -44,9 +44,15 @@ class PolicyEngine(object):
suite_class = source_suite.suite_class suite_class = source_suite.suite_class
for policy in self._policies: for policy in self._policies:
if suite_class in policy.applicable_suites: if suite_class in policy.applicable_suites:
v = policy.apply_src_policy(policy_info, suite_name, src, source_t, source_u, excuse) if policy.src_policy.run_arch:
if v.value > policy_verdict.value: for arch in policy.options.architectures:
policy_verdict = v v = policy.apply_srcarch_policy(policy_info, suite_name, src, arch, source_t, source_u, excuse)
if v.value > policy_verdict.value:
policy_verdict = v
if policy.src_policy.run_src:
v = policy.apply_src_policy(policy_info, suite_name, src, source_t, source_u, excuse)
if v.value > policy_verdict.value:
policy_verdict = v
excuse.policy_verdict = policy_verdict excuse.policy_verdict = policy_verdict
def apply_srcarch_policies(self, source_suite, src, arch, source_t, source_u, excuse): def apply_srcarch_policies(self, source_suite, src, arch, source_t, source_u, excuse):
@ -64,7 +70,7 @@ class PolicyEngine(object):
class BasePolicy(object): class BasePolicy(object):
def __init__(self, policy_id, options, suite_info, applicable_suites): def __init__(self, policy_id, options, suite_info, applicable_suites, src_policy = ApplySrcPolicy.RUN_SRC):
"""The BasePolicy constructor """The BasePolicy constructor
:param policy_id An string identifying the policy. It will :param policy_id An string identifying the policy. It will
@ -80,6 +86,7 @@ class BasePolicy(object):
self.options = options self.options = options
self.suite_info = suite_info self.suite_info = suite_info
self.applicable_suites = applicable_suites self.applicable_suites = applicable_suites
self.src_policy = src_policy
self.hints = None self.hints = None
logger_name = ".".join((self.__class__.__module__, self.__class__.__name__)) logger_name = ".".join((self.__class__.__module__, self.__class__.__name__))
self.logger = logging.getLogger(logger_name) self.logger = logging.getLogger(logger_name)

Loading…
Cancel
Save