diff --git a/plugins/labhub.py b/plugins/labhub.py index 7419eea6..4d01253e 100644 --- a/plugins/labhub.py +++ b/plugins/labhub.py @@ -266,9 +266,27 @@ def process_short_ref(issue_reference): return m.group(1), m.group(2), m.group(3) + # Super short issue reference (e.g. `#1234`) + def process_super_short_ref(issue_reference): + issue_rgx = r'#(\d+)' + issue_reference_match = re.fullmatch(issue_rgx, issue_reference) + + if issue_reference_match is None: + return None + + roomname_rgx = r'(.+?)/(.+)' + roomname_match = re.fullmatch( + roomname_rgx, msg.frm.room.idd, re.IGNORECASE) + + if roommatch is None: + return None + + return roommatch.group(1), roommatch.group(2), m.group(1) + issue_processors = [ process_full_url, - process_short_ref + process_short_ref, + process_super_short_ref ] for issue_processor in issue_processors: diff --git a/tests/labhub_test.py b/tests/labhub_test.py index 8f1f42a7..16ff3fd7 100644 --- a/tests/labhub_test.py +++ b/tests/labhub_test.py @@ -158,6 +158,12 @@ def test_assign_cmd(self): testbot.assertCommand('!assign coala/a#23', "You've been assigned to the issue") + # test super-short issue reference + mock_issue.assignees = tuple() + self.mock_team.is_member.return_value = False + testbot.assertCommand('!assign #23', + "You've been assigned to the issue") + cmd = '!assign https://github.com/{}/{}/issues/{}' # no assignee, not newcomer mock_issue.assignees = tuple()