summaryrefslogtreecommitdiff
path: root/testapp/exam/views.py
diff options
context:
space:
mode:
authorprathamesh2015-04-07 17:22:00 +0530
committerprathamesh2015-04-07 17:22:00 +0530
commitefadb4672e78f58796fe5bfa7153d6e1a0035981 (patch)
tree3991e59bcc800f43e7cd65dc51981938a5ff958f /testapp/exam/views.py
parent8fcc1ab1de747bea09b443ba591a684e3054f65b (diff)
parentcff2b481b5f8a62dd9df877a4ef190dc10585db6 (diff)
downloadonline_test-efadb4672e78f58796fe5bfa7153d6e1a0035981.tar.gz
online_test-efadb4672e78f58796fe5bfa7153d6e1a0035981.tar.bz2
online_test-efadb4672e78f58796fe5bfa7153d6e1a0035981.zip
cleaned url.
User can resume the quiz from where the left, if time permits. Useful where browser crashes or user by mistake closes the quiz. Also, on refresh during the quiz will not throw error.
Diffstat (limited to 'testapp/exam/views.py')
-rw-r--r--testapp/exam/views.py44
1 files changed, 40 insertions, 4 deletions
diff --git a/testapp/exam/views.py b/testapp/exam/views.py
index 4165b7f..11aca06 100644
--- a/testapp/exam/views.py
+++ b/testapp/exam/views.py
@@ -165,7 +165,6 @@ def intro(request, questionpaper_id):
quest_paper = QuestionPaper.objects.get(id=questionpaper_id)
attempt_number = quest_paper.quiz.attempts_allowed
time_lag = quest_paper.quiz.time_between_attempts
-
if quest_paper.quiz.prerequisite:
try:
pre_quest = QuestionPaper.objects.get(
@@ -189,10 +188,29 @@ def intro(request, questionpaper_id):
'attempt_num': already_attempted + 1}
return my_render_to_response('exam/intro.html', context,
context_instance=ci)
+
+ if already_attempted == attempt_number:
+ inprogress, previous_attempt = _check_previous_attempt(attempted_papers,
+ already_attempted)
+ if inprogress:
+ return show_question(request,
+ previous_attempt.current_question(),
+ previous_attempt.attempt_number,
+ previous_attempt.question_paper.id)
+ else:
+ return my_redirect("/exam/quizzes")
+
+
if already_attempted < attempt_number or attempt_number < 0:
- previous_attempt_day = attempted_papers[already_attempted-1].start_time
- today = datetime.datetime.today()
- days_after_attempt = (today - previous_attempt_day).days
+ inprogress, previous_attempt = _check_previous_attempt(attempted_papers,
+ already_attempted)
+ if inprogress:
+ return show_question(request,
+ previous_attempt.current_question(),
+ previous_attempt.attempt_number,
+ previous_attempt.question_paper.id)
+ days_after_attempt = (datetime.datetime.today() - \
+ previous_attempt.start_time).days
if days_after_attempt >= time_lag:
context = {'user': user, 'paper_id': questionpaper_id,\
'attempt_num': already_attempted + 1}
@@ -204,6 +222,20 @@ def intro(request, questionpaper_id):
return my_redirect("/exam/quizzes/")
+def _check_previous_attempt(attempted_papers, already_attempted):
+ previous_attempt = attempted_papers[already_attempted-1]
+ previous_attempt_day = previous_attempt.start_time
+ today = datetime.datetime.today()
+ if previous_attempt.status == 'inprogress':
+ end_time = previous_attempt.end_time
+ quiz_time = previous_attempt.question_paper.quiz.duration*60
+ if quiz_time > (today-previous_attempt_day).seconds:
+ return True, previous_attempt
+ else:
+ return False, previous_attempt
+ else:
+ return False, previous_attempt
+
def results_user(request):
"""Show list of Results of Quizzes that is taken by logged-in user."""
user = request.user
@@ -809,6 +841,10 @@ def check(request, q_id, attempt_num=None, questionpaper_id=None):
q_paper = QuestionPaper.objects.get(id=questionpaper_id)
paper = AnswerPaper.objects.get(user=request.user, attempt_number=attempt_num,
question_paper=q_paper)
+ if q_id in paper.questions_answered:
+ next_q = paper.skip()
+ return show_question(request, next_q, attempt_num, questionpaper_id)
+
if not user.is_authenticated() or paper.end_time < datetime.datetime.now():
return my_redirect('/exam/login/')
question = get_object_or_404(Question, pk=q_id)