diff options
-rw-r--r-- | exam/models.py | 10 | ||||
-rw-r--r-- | exam/views.py | 62 | ||||
-rw-r--r-- | templates/exam/complete.html | 2 | ||||
-rw-r--r-- | templates/exam/monitor.html | 6 | ||||
-rw-r--r-- | templates/exam/question.html | 8 |
5 files changed, 45 insertions, 43 deletions
diff --git a/exam/models.py b/exam/models.py index 61de093..1e8ba69 100644 --- a/exam/models.py +++ b/exam/models.py @@ -42,17 +42,17 @@ class Answer(models.Model): return self.answer -class Quiz(models.Model): - """A quiz for a student. +class QuestionPaper(models.Model): + """A question paper for a student -- one per student typically. """ - # The user taking this quiz. + # The user taking this question paper. user = models.ForeignKey(User) # User's IP which is logged. user_ip = models.CharField(max_length=15) # Unused currently. key = models.CharField(max_length=10) - # used to allow/stop a user from retaking the quiz + # used to allow/stop a user from retaking the question paper. is_active = models.BooleanField(default = True) # The questions (a list of ids separated by '|') @@ -111,4 +111,4 @@ class Quiz(models.Model): def __unicode__(self): u = self.user - return u'Quiz for {0} {1}'.format(u.first_name, u.last_name) + return u'Question paper for {0} {1}'.format(u.first_name, u.last_name) diff --git a/exam/views.py b/exam/views.py index c9d8b7a..0c48f08 100644 --- a/exam/views.py +++ b/exam/views.py @@ -7,7 +7,7 @@ from os.path import dirname, pardir, abspath, join, exists from django.contrib.auth import login, logout, authenticate from django.shortcuts import render_to_response, get_object_or_404, redirect from django.template import RequestContext -from exam.models import Question, Quiz, Profile, Answer +from exam.models import Question, QuestionPaper, Profile, Answer from exam.forms import UserRegisterForm, UserLoginForm from exam.xmlrpc_clients import python_server @@ -26,7 +26,7 @@ def get_user_dir(user): def index(request): """The start page. """ - # Largely copied from Nishanth's quiz app. + # Largely copied from Nishanth's QuestionPaper app. user = request.user if user.is_authenticated(): return redirect("/exam/start/") @@ -92,15 +92,15 @@ def show_question(request, q_id): def start(request): user = request.user try: - old_quiz = Quiz.objects.get(user=user) - if not old_quiz.is_active: + old_paper = QuestionPaper.objects.get(user=user) + if not old_paper.is_active: return redirect("/exam/complete/") - q = old_quiz.current_question() - return redirect('/exam/%s'%q) - except Quiz.DoesNotExist: + p = old_paper.current_question() + return redirect('/exam/%s'%p) + except QuestionPaper.DoesNotExist: ip = request.META['REMOTE_ADDR'] key = gen_key(10) - new_quiz = Quiz(user=user, user_ip=ip, key=key) + new_paper = QuestionPaper(user=user, user_ip=ip, key=key) # Make user directory. user_dir = get_user_dir(user) @@ -114,8 +114,8 @@ def start(request): questions = [ str(_.id) for _ in Question.objects.all() ] random.shuffle(questions) - new_quiz.questions = "|".join(questions) - new_quiz.save() + new_paper.questions = "|".join(questions) + new_paper.save() # Show the user the intro page. context = {'user': user} @@ -127,10 +127,10 @@ def question(request, q_id): user = request.user q = get_object_or_404(Question, pk=q_id) try: - quiz = Quiz.objects.get(user=request.user) - except Quiz.DoesNotExist: + paper = QuestionPaper.objects.get(user=request.user) + except QuestionPaper.DoesNotExist: redirect('/exam/start') - context = {'question': q, 'quiz': quiz, 'user': user} + context = {'question': q, 'paper': paper, 'user': user} ci = RequestContext(request) return render_to_response('exam/question.html', context, context_instance=ci) @@ -138,18 +138,18 @@ def question(request, q_id): def check(request, q_id): user = request.user question = get_object_or_404(Question, pk=q_id) - quiz = Quiz.objects.get(user=user) + paper = QuestionPaper.objects.get(user=user) answer = request.POST.get('answer') skip = request.POST.get('skip', None) if skip is not None: - next_q = quiz.skip() + next_q = paper.skip() return show_question(request, next_q) # Add the answer submitted, regardless of it being correct or not. new_answer = Answer(question=question, answer=answer, correct=False) new_answer.save() - quiz.answers.add(new_answer) + paper.answers.add(new_answer) # Otherwise we were asked to check. We obtain the results via XML-RPC # with the code executed safely in a separate process (the python_server.py) @@ -165,11 +165,11 @@ def check(request, q_id): ci = RequestContext(request) if not success: context = {'question': question, 'error_message': err_msg, - 'quiz': quiz, 'last_attempt': answer} + 'paper': paper, 'last_attempt': answer} return render_to_response('exam/question.html', context, context_instance=ci) else: - next_q = quiz.answered_question(question.id) + next_q = paper.answered_question(question.id) return show_question(request, next_q) def quit(request): @@ -182,41 +182,41 @@ def complete(request): if request.method == 'POST': yes = request.POST.get('yes', None) if yes: - quiz = Quiz.objects.get(user=user) - quiz.is_active = False - quiz.save() + paper = QuestionPaper.objects.get(user=user) + paper.is_active = False + paper.save() logout(request) return render_to_response('exam/complete.html') else: return redirect('/exam/') def monitor(request): - """Monitor the progress of the quizzes taken so far.""" - quizzes = Quiz.objects.all() + """Monitor the progress of the papers taken so far.""" + q_papers = QuestionPaper.objects.all() questions = Question.objects.all() # Mapping from question id to points marks = dict( ( (q.id, q.points) for q in questions) ) - quiz_list = [] - for quiz in quizzes: + paper_list = [] + for q_paper in q_papers: paper = {} - user = quiz.user + user = q_paper.user try: profile = Profile.objects.get(user=user) except Profile.DoesNotExist: - # Admin user may have a quiz by accident but no profile. + # Admin user may have a paper by accident but no profile. continue paper['username'] = str(user.first_name) + ' ' + str(user.last_name) paper['rollno'] = str(profile.roll_number) - qa = quiz.questions_answered.split('|') + qa = q_paper.questions_answered.split('|') answered = ', '.join(sorted(qa)) paper['answered'] = answered if answered else 'None' total = sum( [marks[int(id)] for id in qa if id] ) paper['total'] = total - quiz_list.append(paper) + paper_list.append(paper) - quiz_list.sort(cmp=lambda x, y: cmp(x['total'], y['total']), + paper_list.sort(cmp=lambda x, y: cmp(x['total'], y['total']), reverse=True) - context = {'quiz_list': quiz_list} + context = {'paper_list': paper_list} return render_to_response('exam/monitor.html', context, context_instance=RequestContext(request)) diff --git a/templates/exam/complete.html b/templates/exam/complete.html index e42704f..ded38f7 100644 --- a/templates/exam/complete.html +++ b/templates/exam/complete.html @@ -1,3 +1,3 @@ -<p>Quiz is complete. Thank you. </p> +<p>Exam is complete. Thank you. </p> <br /> <p>You may now close the browser.</p> diff --git a/templates/exam/monitor.html b/templates/exam/monitor.html index 12360a2..f1c7779 100644 --- a/templates/exam/monitor.html +++ b/templates/exam/monitor.html @@ -2,12 +2,12 @@ <meta http-equiv="refresh" content="30"/> -{% if quiz_list %} +{% if paper_list %} <table border="1" cellpadding="3"> <tr> <th>Student </th> <th> Roll number </th> <th>Questions answered</th> <th>Total marks</th> </tr> - {% for paper in quiz_list %} + {% for paper in paper_list %} <tr> <td> {{ paper.username }} </td> <td> {{ paper.rollno }} </td> @@ -18,6 +18,6 @@ {% endfor %} </table> {% else %} - <p> No quizzes so far. </p> + <p> No answer papers so far. </p> {% endif %} diff --git a/templates/exam/question.html b/templates/exam/question.html index 1798606..75e5a62 100644 --- a/templates/exam/question.html +++ b/templates/exam/question.html @@ -1,6 +1,7 @@ <h2> {{ question.summary }} </h2> -<script language="javascript"> +<script type="text/javascript"> +<!-- function submitCode() { document.forms["code"].submit(); @@ -11,6 +12,7 @@ function submitCode() x.value = "Checking Answer ..."; document.getElementById("skip").disabled = true; } +//--> </script> <p>{{ question.description }} </p> @@ -29,11 +31,11 @@ function submitCode() <br/> <input id="check" type="submit" name="check" value="Check Answer" -onclick="javascript:submitCode();"/> +onclick="submitCode();"/> <input id="skip" type="submit" name="skip" value="Skip question" /> </form> -<p> {{ user.first_name.title }} {{ user.last_name.title }}, you have {{ quiz.questions_left }} question(s) left. </p> +<p> {{ user.first_name.title }} {{ user.last_name.title }}, you have {{ paper.questions_left }} question(s) left. </p> <hr/> <form action="/exam/quit/" method="post"> |