Skip to content

Commit

Permalink
Merge pull request #19 from googleartsculture/issue/13/500-error-scipy
Browse files Browse the repository at this point in the history
Catch QhullError
  • Loading branch information
justingrayston authored Aug 4, 2020
2 parents 9e61ddb + deffeac commit 9f37e02
Show file tree
Hide file tree
Showing 3 changed files with 31 additions and 0 deletions.
9 changes: 9 additions & 0 deletions src/main.py
Original file line number Diff line number Diff line change
Expand Up @@ -30,6 +30,7 @@
from PIL import Image
from PIL.PngImagePlugin import PngImageFile
from scipy.spatial import ConvexHull
from scipy.spatial.qhull import QhullError
from sklearn.cluster import DBSCAN
from werkzeug.exceptions import (BadRequest, Forbidden, HTTPException,
InternalServerError)
Expand All @@ -45,6 +46,10 @@
if DEBUG == 'False' or DEBUG == '0':
DEBUG = False

QHULL_ERROR_MESSAGE = 'Unable to process image do to pixel' + \
' dimensions or geometrical degeneracy. Please use the ' + \
'marquee tool to refine your selection.'

# Pixels limit
pixel_limit = 50000
# Threshold value for DBSCAN
Expand Down Expand Up @@ -757,8 +762,12 @@ def cluster_analysis(payload):
except BadRequest as e:
raise BadRequest(e.description)

except QhullError as e:
raise BadRequest(QHULL_ERROR_MESSAGE)

except Exception as e:
logging.error(e)
logging.traceback.extract_tb(e)
raise InternalServerError('Something went wrong!')


Expand Down
17 changes: 17 additions & 0 deletions src/test/main_test.py
Original file line number Diff line number Diff line change
Expand Up @@ -280,6 +280,23 @@ def test_valid_clusteranalysis_requests(self):
self.assertIn('height', cluster.get('bounds'))
self.assertIn('width', cluster.get('bounds'))

def test_scipy_error_is_handled(self):
"""
Asserts that a request with an image that causes
an error is handled (see Issue #13).
"""
json_path = os.path.join(os.path.dirname(__file__),
'scipy_error_request.json')
invalid = open(json_path)
payload = json.load(invalid)
response = self.client.post('/clusteranalysis', json=payload)
self.assertEqual('400 BAD REQUEST', response.status)
data = json.loads(response.data)
self.assertEqual(400, data.get('code'))
self.assertEqual(
main.QHULL_ERROR_MESSAGE,
data.get('message'))

def test_warmup_request_responds_200(self):
"""
Asserts that a reuqest to /_ah/warmup is handled.
Expand Down
5 changes: 5 additions & 0 deletions src/test/scipy_error_request.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
{
"image": "",
"direction": "ltr",
"threshold": 200
}

0 comments on commit 9f37e02

Please sign in to comment.