From e5247de7b870c20611475b43ee8baf5934043b7b Mon Sep 17 00:00:00 2001 From: Steve Langasek Date: Mon, 6 Mar 2023 11:21:13 -0800 Subject: [PATCH] Add a dry-run option for the autopkgtest policy specifically For rolling out britney on a new machine, we want to generate update_excuses and update_output to confirm it's working correctly all the way through, so we don't want to use the global --dry-run option; but we *do* want to disable queuing tests and instead let the production instance of britney queue the tests while we simply query the results. Add support for ADT_ENABLE=dry-run in britney.conf, parallelling the behavior of other policies. --- britney.py | 5 +++-- britney2/policies/autopkgtest.py | 8 +++++--- 2 files changed, 8 insertions(+), 5 deletions(-) diff --git a/britney.py b/britney.py index b5deff2..0f45ff2 100755 --- a/britney.py +++ b/britney.py @@ -521,8 +521,9 @@ class Britney(object): self._policy_engine.add_policy(RCBugPolicy(self.options, self.suite_info)) if getattr(self.options, 'piuparts_enable', 'yes') == 'yes': self._policy_engine.add_policy(PiupartsPolicy(self.options, self.suite_info)) - if getattr(self.options, 'adt_enable') == 'yes': - self._policy_engine.add_policy(AutopkgtestPolicy(self.options, self.suite_info)) + add_autopkgtest_policy = getattr(self.options, 'adt_enable', 'no') + if add_autopkgtest_policy in ('yes', 'dry-run'): + self._policy_engine.add_policy(AutopkgtestPolicy(self.options, self.suite_info, dry_run=add_autopkgtest_policy)) self._policy_engine.add_policy(AgePolicy(self.options, self.suite_info, MINDAYS)) # XXX this policy results in asymmetric enforcement of # build-dependencies in the release pocket (nothing blocks diff --git a/britney2/policies/autopkgtest.py b/britney2/policies/autopkgtest.py index 7ff8c1f..546a03c 100644 --- a/britney2/policies/autopkgtest.py +++ b/britney2/policies/autopkgtest.py @@ -117,7 +117,8 @@ class AutopkgtestPolicy(BasePolicy): reject the upload if any of those regress. """ - def __init__(self, options, suite_info): + def __init__(self, options, suite_info, dry_run=False): + super().__init__('autopkgtest', options, suite_info, {SuiteClass.PRIMARY_SOURCE_SUITE}) # tests requested in this and previous runs # trigger -> src -> [arch] @@ -126,6 +127,7 @@ class AutopkgtestPolicy(BasePolicy): self.testsuite_triggers = {} self.result_in_baseline_cache = collections.defaultdict(dict) self.database_path = os.path.join(self.state_dir, 'autopkgtest.db') + self.dry_run = dry_run # results map: trigger -> src -> arch -> [passed, version, run_id, seen] # - trigger is "source/version" of an unstable package that triggered @@ -292,7 +294,7 @@ class AutopkgtestPolicy(BasePolicy): # Initialize AMQP connection self.amqp_channel = None self.amqp_file = None - if self.options.dry_run: + if self.options.dry_run or self.dry_run: return amqp_url = self.options.adt_amqp @@ -1117,7 +1119,7 @@ class AutopkgtestPolicy(BasePolicy): If huge is true, then the request will be put into the -huge instead of normal queue. ''' - if self.options.dry_run: + if self.options.dry_run or self.dry_run: return params = {'triggers': triggers}