Skip to content

Commit

Permalink
Merge pull request #472 from edx/dcs/dashboard-404
Browse files Browse the repository at this point in the history
When there is no instructor dashboard for the backend, return a 404 instead of a 500
  • Loading branch information
davestgermain authored Nov 30, 2018
2 parents 7e72fda + 524d0ad commit f1029a6
Show file tree
Hide file tree
Showing 6 changed files with 71 additions and 15 deletions.
2 changes: 1 addition & 1 deletion edx_proctoring/__init__.py
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,6 @@

from __future__ import absolute_import

__version__ = '1.5.0b2'
__version__ = '1.5.0b3'

default_app_config = 'edx_proctoring.apps.EdxProctoringConfig' # pylint: disable=invalid-name
7 changes: 5 additions & 2 deletions edx_proctoring/apps.py
Original file line number Diff line number Diff line change
Expand Up @@ -53,11 +53,14 @@ def ready(self):
config = settings.PROCTORING_BACKENDS

self.backends = {} # pylint: disable=W0201
not_found = []
for extension in ExtensionManager(namespace='openedx.proctoring'):
name = extension.name
try:
options = config[name]
self.backends[name] = extension.plugin(**options)
except KeyError:
warnings.warn("No proctoring backend configured for '{}'. "
"Available: {}".format(name, list(self.backends)))
not_found.append(name)
if not_found: # pragma: no branch
warnings.warn("No proctoring backend configured for '{}'. "
"Available: {}".format(not_found, list(self.backends)))
7 changes: 7 additions & 0 deletions edx_proctoring/backends/backend.py
Original file line number Diff line number Diff line change
Expand Up @@ -82,3 +82,10 @@ def get_attempt(self, attempt):
dict: backend exam attempt object
"""
return attempt

# pylint: disable=unused-argument
def get_instructor_url(self, course_id, user, exam_id=None, attempt_id=None):
"""
Returns the instructor dashboard url for reviews
"""
return None
6 changes: 3 additions & 3 deletions edx_proctoring/backends/tests/test_rest.py
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,7 @@
import responses

from django.test import TestCase
from django.utils.translation import activate
from django.utils import translation

from edx_proctoring.backends.rest import BaseRestProctoringProvider

Expand Down Expand Up @@ -93,7 +93,6 @@ def test_get_attempt(self):

@responses.activate
def test_get_attempt_i18n(self):
activate('es')
attempt = {
'id': 1,
'external_id': 'abcd',
Expand All @@ -107,7 +106,8 @@ def test_get_attempt_i18n(self):
exam_id=self.backend_exam['external_id'], attempt_id=attempt['external_id']),
json=attempt
)
external_attempt = self.provider.get_attempt(attempt)
with translation.override('es'):
external_attempt = self.provider.get_attempt(attempt)
self.assertEqual(external_attempt, attempt)
self.assertEqual(responses.calls[1].request.headers['Accept-Language'], 'es;en-us')

Expand Down
37 changes: 37 additions & 0 deletions edx_proctoring/tests/test_views.py
Original file line number Diff line number Diff line change
Expand Up @@ -2569,3 +2569,40 @@ def test_error_with_no_exams(self):
kwargs={'course_id': course_id})
)
self.assertEqual(response.status_code, 404)

# test the case of no PROCTORED exams
ProctoredExam.objects.create(
course_id=course_id,
content_id='test_content',
exam_name='Timed Exam',
external_id='123aXqe3',
time_limit_mins=90,
is_active=True,
is_proctored=False,
backend='software_secure',
)
response = self.client.get(
reverse('edx_proctoring.instructor_dashboard_course',
kwargs={'course_id': course_id})
)
self.assertEqual(response.status_code, 404)

def test_error_with_no_dashboard(self):
course_id = 'a/b/d'

ProctoredExam.objects.create(
course_id=course_id,
content_id='test_content',
exam_name='Test Exam',
external_id='123aXqe3',
time_limit_mins=90,
is_active=True,
is_proctored=True,
backend='software_secure',
)
response = self.client.get(
reverse('edx_proctoring.instructor_dashboard_course',
kwargs={'course_id': course_id})
)
self.assertEqual(response.status_code, 404)
self.assertEqual('No instructor dashboard for RPNow', response.data)
27 changes: 18 additions & 9 deletions edx_proctoring/views.py
Original file line number Diff line number Diff line change
Expand Up @@ -978,12 +978,21 @@ def get(self, request, course_id, exam_id=None):
else:
found_backend = exam_backend
if exam is None:
return Response(data='No exam found for course %r.' % course_id, status=404)
backend = get_backend_provider(exam)
user = {
'id': request.user.id,
'full_name': request.user.get_full_name(),
'email': request.user.email
}
url = backend.get_instructor_url(exam['course_id'], user, exam_id=exam_id)
return redirect(url)
error = _('No exams in course {course_id}.').format(course_id=course_id)
else:
backend = get_backend_provider(exam)
if backend:
user = {
'id': request.user.id,
'full_name': request.user.get_full_name(),
'email': request.user.email
}
url = backend.get_instructor_url(exam['course_id'], user, exam_id=exam_id)
if url:
return redirect(url)
else:
error = _('No instructor dashboard for {proctor_service}').format(
proctor_service=backend.verbose_name)
else:
error = _('No proctored exams in course {course_id}').format(course_id=course_id)
return Response(data=error, status=404, headers={'X-Frame-Options': 'sameorigin'})

0 comments on commit f1029a6

Please sign in to comment.