Skip to content

Commit

Permalink
fix: isolate actions and raise exceptions as a group
Browse files Browse the repository at this point in the history
  • Loading branch information
Ned Batchelder committed Oct 19, 2023
1 parent 476d3b8 commit 7bd580a
Showing 1 changed file with 25 additions and 4 deletions.
29 changes: 25 additions & 4 deletions openedx_webhooks/tasks/pr_tracking.py
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@

from __future__ import annotations

import contextlib
import copy
import dataclasses
import itertools
Expand Down Expand Up @@ -318,10 +319,23 @@ def __init__(

self.bot_data = copy.deepcopy(current.bot_data)
self.fix_result: FixResult = FixResult()
self.exceptions: List[Exception] = []

def result(self) -> FixResult:
return self.fix_result

@contextlib.contextmanager
def saved_exceptions(self):
"""
A context manager to wrap around isolatable steps.
An exception raised in the with-block will be added to `self.exceptions`.
"""
try:
yield
except Exception as exc:
self.exceptions.append(exc)

Check warning on line 337 in openedx_webhooks/tasks/pr_tracking.py

View check run for this annotation

Codecov / codecov/patch

openedx_webhooks/tasks/pr_tracking.py#L336-L337

Added lines #L336 - L337 were not covered by tests

def fix(self) -> None:
"""
The main routine for making needed changes.
Expand All @@ -335,19 +349,26 @@ def fix(self) -> None:

if self.desired.cla_check != self.current.cla_check:
assert self.desired.cla_check is not None
self.actions.set_cla_status(status=self.desired.cla_check)
with self.saved_exceptions():
self.actions.set_cla_status(status=self.desired.cla_check)

if self.desired.is_ospr:
self._fix_ospr()
with self.saved_exceptions():
self._fix_ospr()

if self.desired.is_refused:
self._fix_comments()
with self.saved_exceptions():
self._fix_comments()

# Make needed Jira issues.
current_jira_nicks = {ji.nick for ji in self.current.bot_data.jira_issues}
for jira_nick in self.desired.jira_nicks:
if jira_nick not in current_jira_nicks:
self._make_jira_issue(jira_nick)
with self.saved_exceptions():
self._make_jira_issue(jira_nick)

if self.exceptions:
raise ExceptionGroup("Some actions failed", self.exceptions)

Check warning on line 371 in openedx_webhooks/tasks/pr_tracking.py

View check run for this annotation

Codecov / codecov/patch

openedx_webhooks/tasks/pr_tracking.py#L371

Added line #L371 was not covered by tests

def _fix_comments(self) -> None:
fix_comment = True
Expand Down

0 comments on commit 7bd580a

Please sign in to comment.