Commit ee12def2 by Eric Fischer

Fix for EDUCATOR-1090

Now that uuids exist in the database both with and without hyphens, we must be
resilient to both.
parent 7e835ff0
...@@ -33,7 +33,7 @@ def load_requirements(*requirements_paths): ...@@ -33,7 +33,7 @@ def load_requirements(*requirements_paths):
setup( setup(
name='edx-submissions', name='edx-submissions',
version='2.0.6', version='2.0.8',
author='edX', author='edX',
description='An API for creating submissions and scores.', description='An API for creating submissions and scores.',
url='http://github.com/edx/edx-submissions.git', url='http://github.com/edx/edx-submissions.git',
......
...@@ -196,6 +196,20 @@ def create_submission(student_item_dict, answer, submitted_at=None, attempt_numb ...@@ -196,6 +196,20 @@ def create_submission(student_item_dict, answer, submitted_at=None, attempt_numb
raise SubmissionInternalError(error_message) raise SubmissionInternalError(error_message)
def _get_submission_model(uuid, read_replica=False):
"""
Helper to retrieve a given Submission object from the database. Helper is needed to centralize logic that fixes
EDUCATOR-1090, because uuids are stored both with and without hyphens.
"""
submission_qs = Submission.objects
if read_replica:
submission_qs = _use_read_replica(submission_qs)
query_regex = "^{}$|^{}$".format(uuid, uuid.replace("-",""))
submission = submission_qs.get(uuid__regex=query_regex)
return submission
def get_submission(submission_uuid, read_replica=False): def get_submission(submission_uuid, read_replica=False):
"""Retrieves a single submission by uuid. """Retrieves a single submission by uuid.
...@@ -244,11 +258,7 @@ def get_submission(submission_uuid, read_replica=False): ...@@ -244,11 +258,7 @@ def get_submission(submission_uuid, read_replica=False):
return cached_submission_data return cached_submission_data
try: try:
submission_qs = Submission.objects submission = _get_submission_model(submission_uuid, read_replica)
if read_replica:
submission_qs = _use_read_replica(submission_qs)
submission = submission_qs.get(uuid=submission_uuid)
submission_data = SubmissionSerializer(submission).data submission_data = SubmissionSerializer(submission).data
cache.set(cache_key, submission_data) cache.set(cache_key, submission_data)
except Submission.DoesNotExist: except Submission.DoesNotExist:
...@@ -701,7 +711,7 @@ def get_latest_score_for_submission(submission_uuid, read_replica=False): ...@@ -701,7 +711,7 @@ def get_latest_score_for_submission(submission_uuid, read_replica=False):
""" """
try: try:
# Ensure that submission_uuid is valid before fetching score # Ensure that submission_uuid is valid before fetching score
submission_model = Submission.objects.get(uuid=submission_uuid) submission_model = _get_submission_model(submission_uuid, read_replica)
score_qs = Score.objects.filter( score_qs = Score.objects.filter(
submission__uuid=submission_model.uuid submission__uuid=submission_model.uuid
).order_by("-id").select_related("submission") ).order_by("-id").select_related("submission")
...@@ -824,7 +834,7 @@ def set_score(submission_uuid, points_earned, points_possible, ...@@ -824,7 +834,7 @@ def set_score(submission_uuid, points_earned, points_possible,
""" """
try: try:
submission_model = Submission.objects.get(uuid=submission_uuid) submission_model = _get_submission_model(submission_uuid)
except Submission.DoesNotExist: except Submission.DoesNotExist:
raise SubmissionNotFoundError( raise SubmissionNotFoundError(
u"No submission matching uuid {}".format(submission_uuid) u"No submission matching uuid {}".format(submission_uuid)
......
...@@ -68,11 +68,7 @@ class TestSubmissionsApi(TestCase): ...@@ -68,11 +68,7 @@ class TestSubmissionsApi(TestCase):
retrieved = api.get_submission_and_student(submission['uuid']) retrieved = api.get_submission_and_student(submission['uuid'])
self.assertItemsEqual(submission, retrieved) self.assertItemsEqual(submission, retrieved)
# Should raise an exception if uuid is malformed # Should raise an exception if the student item does not exist
with self.assertRaises(api.SubmissionInternalError):
api.get_submission_and_student(u'no such uuid')
# Should raise a different exception if the student item does not exist
with self.assertRaises(api.SubmissionNotFoundError): with self.assertRaises(api.SubmissionNotFoundError):
api.get_submission_and_student(u'deadbeef-1234-5678-9100-1234deadbeef') api.get_submission_and_student(u'deadbeef-1234-5678-9100-1234deadbeef')
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment