summaryrefslogtreecommitdiff
path: root/yaksh/models.py
diff options
context:
space:
mode:
authorPalaparthy Adityachandra2020-12-10 17:47:24 +0530
committerGitHub2020-12-10 17:47:24 +0530
commit6b7feb2f3f1a090e76087c8ba7ac2b600fecacd0 (patch)
tree5df0961b50b76af69cce423e7ea5fcf872676e07 /yaksh/models.py
parent56883784cdcd2a4f1a60cdaa7ba28525cfd21132 (diff)
parent60503c9bd1ea49177f0adfc39ff129bfba86c9de (diff)
downloadonline_test-6b7feb2f3f1a090e76087c8ba7ac2b600fecacd0.tar.gz
online_test-6b7feb2f3f1a090e76087c8ba7ac2b600fecacd0.tar.bz2
online_test-6b7feb2f3f1a090e76087c8ba7ac2b600fecacd0.zip
Merge pull request #803 from prathamesh920/fix-answerpaper-view
Fix answer paper view.
Diffstat (limited to 'yaksh/models.py')
-rw-r--r--yaksh/models.py55
1 files changed, 21 insertions, 34 deletions
diff --git a/yaksh/models.py b/yaksh/models.py
index 50e9363..2978f43 100644
--- a/yaksh/models.py
+++ b/yaksh/models.py
@@ -2321,14 +2321,20 @@ class AnswerPaper(models.Model):
secs = dt.seconds + dt.days*24*3600
return secs
+ def _get_marks_for_question(self, question):
+ marks = 0.0
+ answers = question.answer_set.filter(answerpaper=self)
+ if answers.exists():
+ marks = [answer.marks for answer in answers]
+ max_marks = max(marks)
+ marks = max_marks
+ return marks
+
def _update_marks_obtained(self):
"""Updates the total marks earned by student for this paper."""
- marks = 0
+ marks = 0.0
for question in self.questions.all():
- marks_list = [a.marks
- for a in self.answers.filter(question=question)]
- max_marks = max(marks_list) if marks_list else 0.0
- marks += max_marks
+ marks += self._get_marks_for_question(question)
self.marks_obtained = marks
def _update_percent(self):
@@ -2376,38 +2382,19 @@ class AnswerPaper(models.Model):
corresponding answers.
"""
q_a = {}
- for answer in self.answers.all():
- question = answer.question
- if question in q_a:
- q_a[question].append({
- 'answer': answer,
- 'error_list': [e for e in json.loads(answer.error)]
- })
- else:
- q_a[question] = [{
+ for question in self.questions.all():
+ answers = question.answer_set.filter(answerpaper=self)
+ if not answers.exists():
+ q_a[question] = [None, 0.0]
+ continue
+ ans_errs = []
+ for answer in answers:
+ ans_errs.append({
'answer': answer,
'error_list': [e for e in json.loads(answer.error)]
- }]
-
- q_a.update(
- { q: [] for q in self.questions_unanswered.all() }
- )
-
- for question, answers in q_a.items():
- answers = q_a[question]
- if answers:
- q_a[question].append({
- 'marks': max([
- answer['answer'].marks
- for answer in answers
- if question == answer['answer'].question
- ]),
})
- else:
- q_a[question].append({
- 'marks': 0.0,
- })
-
+ q_a[question] = ans_errs
+ q_a[question].append(self._get_marks_for_question(question))
return q_a
def get_latest_answer(self, question_id):