Skip to content

Commit

Permalink
Merge pull request #180 from kalikiana/browser_get_json_decode
Browse files Browse the repository at this point in the history
Catch JSON decoding errors in browser.get
  • Loading branch information
kalikiana authored Oct 25, 2021
2 parents e0669b4 + be7fe50 commit 5955994
Show file tree
Hide file tree
Showing 2 changed files with 26 additions and 3 deletions.
10 changes: 8 additions & 2 deletions openqa_review/browser.py
Original file line number Diff line number Diff line change
Expand Up @@ -148,15 +148,21 @@ def _get(self, url, as_json=False): # pragma: no cover
msg = "Request to {} was not successful: {}".format(url, str(e))
log.warn(msg)
raise DownloadError(msg)

try:
r.raise_for_status()
except requests.exceptions.HTTPError as e:
msg = "Request to {} failed: {}".format(url, str(e))
log.warn(msg)
raise DownloadError(msg)
return self._decode_content(r.content.decode("utf-8"), url, as_json)

content = r.json() if as_json else r.content.decode("utf8")
def _decode_content(self, url, raw, as_json=False):
try:
content = json.loads(raw) if as_json else raw
except json.decoder.JSONDecodeError as e:
msg = 'Unable to decode JSON for {}: {} (Content was: "{}")'.format(url, str(e), raw)
log.warning(msg)
raise DownloadError(msg)
return content

def json_rpc_get(self, url, method, params, cache=True):
Expand Down
19 changes: 18 additions & 1 deletion tests/test_openqa_review.py
Original file line number Diff line number Diff line change
Expand Up @@ -22,7 +22,7 @@

sys.path.insert(0, os.path.abspath(os.path.join(os.path.dirname(__file__), "..")))

from openqa_review.browser import filename_to_url
from openqa_review.browser import filename_to_url, DownloadError
from openqa_review import openqa_review # SUT


Expand Down Expand Up @@ -573,3 +573,20 @@ def test_arch_distinguish():

report = str(openqa_review.generate_report(args))
assert "ppc64le" in report


def test_browser_decode_content():
args = cache_test_args_factory()
args.include_softfails = True
browser = browser_factory(args)
url = "http://example.com"
json = '{"spam": "eggs"}'

content = browser._decode_content(url, json)
assert content == json
content = browser._decode_content(url, json, as_json=True)
assert "spam" in content

with pytest.raises(DownloadError) as e:
browser._decode_content("http://example.com", "", as_json=True)
assert "Unable to decode JSON" in str(e)

0 comments on commit 5955994

Please sign in to comment.