Skip to content

[XRAY] add get_test_run_iteration method and add more meaningful error raising for incorrect token in XRAY #1504

New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Merged
merged 3 commits into from
Feb 28, 2025
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
30 changes: 30 additions & 0 deletions atlassian/xray.py
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
# coding=utf-8
import logging
import re
from requests import HTTPError
from .rest_client import AtlassianRestAPI

log = logging.getLogger(__name__)
Expand All @@ -13,6 +14,25 @@ def __init__(self, *args, **kwargs):
kwargs["api_root"] = "rest/raven"
super(Xray, self).__init__(*args, **kwargs)

def raise_for_status(self, response):
"""
Checks the response for an error status and raises an exception with the error message provided by the server
:param response:
:return:
"""
if response.status_code == 401 and response.headers.get("Content-Type") != "application/json;charset=UTF-8":
raise HTTPError("Unauthorized (401)", response=response)

if 400 <= response.status_code < 600:
try:
j = response.json()
error_msg = j["message"]
except Exception as e:
log.error(e)
response.raise_for_status()
else:
raise HTTPError(error_msg, response=response)

def resource_url(self, resource, api_root=None, api_version=None):
"""
Overloading the method from AtlassianRestAPI to be compatible with the "middle man" version used by Xray.
Expand Down Expand Up @@ -463,6 +483,16 @@ def update_test_run_assignee(self, test_run_id, assignee):
url = self.resource_url("testrun/{0}".format(test_run_id))
return self.put(url, update)

def get_test_run_iteration(self, test_run_id, iteration_id):
"""
Retrieve the specified iteration for the given test run.
:param test_run_id: ID of the test run (e.g. 100).
:param iteration_id: ID of the iteration.
:return: Returns the specified iteration for the given test run.
"""
url = self.resource_url("testrun/{0}/iteration/{1}".format(test_run_id, iteration_id))
return self.get(url)

def get_test_run_status(self, test_run_id):
"""
Retrieve the status for the given test run.
Expand Down
3 changes: 3 additions & 0 deletions docs/xray.rst
Original file line number Diff line number Diff line change
Expand Up @@ -136,6 +136,9 @@ Manage Test Runs
# Update the assignee for the given test run
xray.update_test_run_assignee(100, 'bob')

# Retrieve a iteration of the given test run
xray.get_test_run_iteration(100, 200)

# Retrieve the status for the given test run
xray.get_test_run_status(100)

Expand Down
Loading