summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--exam/models.py10
-rw-r--r--exam/views.py62
-rw-r--r--templates/exam/complete.html2
-rw-r--r--templates/exam/monitor.html6
-rw-r--r--templates/exam/question.html8
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">