Skip to content

Commit

Permalink
Add fields id, status & url for OpenProject bug details
Browse files Browse the repository at this point in the history
API: when integration with a 3rd party bug tracker is configured
correctly the Bug.details() API method will now return the additional
fields `id`, `status` and `url` alongside the existing `description` and
`title`!

Refs kiwitcms/Kiwi#3748
  • Loading branch information
atodorov committed Nov 8, 2024
1 parent 1ca0ea9 commit f5bc64b
Show file tree
Hide file tree
Showing 2 changed files with 10 additions and 3 deletions.
8 changes: 6 additions & 2 deletions trackers_integration/issuetracker/openproject.py
Original file line number Diff line number Diff line change
Expand Up @@ -202,10 +202,14 @@ def details(self, url):
"""
Fetches WorkPackage details from OpenProject to be displayed in tooltips.
"""
issue = self.rpc.get_workpackage(self.bug_id_from_url(url))
issue_id = self.bug_id_from_url(url)
issue = self.rpc.get_workpackage(issue_id)
issue_type = issue["_embedded"]["type"]["name"].upper()
status = issue["_embedded"]["status"]["name"].upper()
return {
"title": f"{status} {issue_type}: " + issue["subject"],
"id": issue_id,
"description": issue["description"]["raw"],
"status": status,
"title": f"{issue_type}: " + issue["subject"],
"url": url,
}
5 changes: 4 additions & 1 deletion trackers_integration/tests/test_openproject.py
Original file line number Diff line number Diff line change
Expand Up @@ -58,8 +58,11 @@ def test_bug_id_from_url(self):
def test_details(self):
result = self.integration.details(self.existing_bug_url)

self.assertEqual("NEW TASK: Setup conference website", result["title"])
self.assertEqual(self.existing_bug_id, result["id"])
self.assertEqual("", result["description"])
self.assertEqual("NEW", result["status"])
self.assertEqual("TASK: Setup conference website", result["title"])
self.assertEqual(self.existing_bug_url, result["url"])

def test_auto_update_bugtracker(self):
last_comment = None
Expand Down

0 comments on commit f5bc64b

Please sign in to comment.