Set the verdict correctly too.

sil2100/cloud-only-run-once
Łukasz 'sil2100' Zemczak 2 years ago
parent 340b41afe1
commit 85c6716af6

@ -87,6 +87,7 @@ class CloudPolicy(BasePolicy):
self.failures = {} self.failures = {}
self.errors = {} self.errors = {}
self.email_needed = False
def initialise(self, britney): def initialise(self, britney):
super().initialise(britney) super().initialise(britney)
@ -112,7 +113,8 @@ class CloudPolicy(BasePolicy):
self.sources, self.source_type) self.sources, self.source_type)
if len(self.failures) > 0 or len(self.errors) > 0: if len(self.failures) > 0 or len(self.errors) > 0:
self._send_emails_if_needed(item.package, source_data_srcdist.version, self.options.series) if self.email_needed:
self._send_emails_if_needed(item.package, source_data_srcdist.version, self.options.series)
self._cleanup_work_directory() self._cleanup_work_directory()
verdict = PolicyVerdict.REJECTED_PERMANENTLY verdict = PolicyVerdict.REJECTED_PERMANENTLY
@ -139,7 +141,13 @@ class CloudPolicy(BasePolicy):
self.state[cloud][source_type] = {} self.state[cloud][source_type] = {}
if series not in self.state[cloud][source_type]: if series not in self.state[cloud][source_type]:
self.state[cloud][source_type][series] = {} self.state[cloud][source_type][series] = {}
self.state[cloud][source_type][series][package] = version self.state[cloud][source_type][series][package] = {
"version": version,
"failures": len(self.failures),
"errors": len(self.errors)
}
self.email_needed = True
self._save_state() self._save_state()
@ -154,10 +162,26 @@ class CloudPolicy(BasePolicy):
:param cloud The name of the cloud being tested (e.g. azure) :param cloud The name of the cloud being tested (e.g. azure)
""" """
try: try:
return self.state[cloud][source_type][series][package] == version return self.state[cloud][source_type][series][package]["version"] == version
except KeyError: except KeyError:
return False return False
def _set_previous_failure_and_error(self, package, version, series, source_type, cloud):
"""Sets the failures and errors from the previous run.
This takes which cloud we're testing into consideration.
:param package The name of the package to test
:param version Version of the package
:param series The Ubuntu codename for the series (e.g. jammy)
:param source_type Either 'archive' or 'ppa'
:param cloud The name of the cloud being tested (e.g. azure)
"""
if self.state[cloud][source_type][series][package]["failures"] > 0:
self.failures[cloud] = {}
if self.state[cloud][source_type][series][package]["errors"] > 0:
self.errors[cloud] = {}
def _load_state(self): def _load_state(self):
"""Load the save state of which packages have already been tested.""" """Load the save state of which packages have already been tested."""
if os.path.exists(self.state_filename): if os.path.exists(self.state_filename):
@ -233,6 +257,7 @@ class CloudPolicy(BasePolicy):
:param source_type Either 'archive' or 'ppa' :param source_type Either 'archive' or 'ppa'
""" """
if self._check_if_tests_run(package, version, series, source_type, "azure"): if self._check_if_tests_run(package, version, series, source_type, "azure"):
self._set_previous_failure_and_error(package, version, series, source_type, "azure")
return return
urn = self._retrieve_urn(series) urn = self._retrieve_urn(series)

@ -55,7 +55,11 @@ class T(unittest.TestCase):
"azure": { "azure": {
"archive": { "archive": {
"zazzy": { "zazzy": {
"chromium-browser": "55.0" "chromium-browser": {
"version": "55.0",
"failures": 0,
"errors": 0,
}
} }
} }
} }
@ -70,13 +74,17 @@ class T(unittest.TestCase):
mock_run.assert_not_called() mock_run.assert_not_called()
# A new package appears, tests should run # A new package appears, tests should run
expected_state["azure"]["archive"]["zazzy"]["hello"] = "2.10" expected_state["azure"]["archive"]["zazzy"]["hello"] = {
"version": "2.10",
"failures": 0,
"errors": 0,
}
self.policy._run_cloud_tests("hello", "2.10", "zazzy", ["proposed"], "archive") self.policy._run_cloud_tests("hello", "2.10", "zazzy", ["proposed"], "archive")
self.assertDictEqual(expected_state, self.policy.state) self.assertDictEqual(expected_state, self.policy.state)
mock_run.assert_called() mock_run.assert_called()
# A new version of existing package, tests should run # A new version of existing package, tests should run
expected_state["azure"]["archive"]["zazzy"]["chromium-browser"] = "55.1" expected_state["azure"]["archive"]["zazzy"]["chromium-browser"]["version"] = "55.1"
self.policy._run_cloud_tests("chromium-browser", "55.1", "zazzy", ["proposed"], "archive") self.policy._run_cloud_tests("chromium-browser", "55.1", "zazzy", ["proposed"], "archive")
self.assertDictEqual(expected_state, self.policy.state) self.assertDictEqual(expected_state, self.policy.state)
self.assertEqual(mock_run.call_count, 2) self.assertEqual(mock_run.call_count, 2)

Loading…
Cancel
Save