summaryrefslogtreecommitdiff
path: root/yaksh/views.py
diff options
context:
space:
mode:
authorCruiseDevice2019-01-03 16:08:50 +0530
committerCruiseDevice2019-01-28 13:07:02 +0530
commitf72b744db670d88c095200832a638b69f514f55c (patch)
tree0cc697b405fd2123d3c6e727e0c70cfd12e7eed3 /yaksh/views.py
parentae5e8ca5eb5d47afb14ba83e665de6f10e46bdac (diff)
downloadonline_test-f72b744db670d88c095200832a638b69f514f55c.tar.gz
online_test-f72b744db670d88c095200832a638b69f514f55c.tar.bz2
online_test-f72b744db670d88c095200832a638b69f514f55c.zip
Code refactor
- Move get_question_by_index() and get_question_by_type() from views.py to models.py . - Change variable names.
Diffstat (limited to 'yaksh/views.py')
-rw-r--r--yaksh/views.py74
1 files changed, 34 insertions, 40 deletions
diff --git a/yaksh/views.py b/yaksh/views.py
index af4eec1..4c23ba6 100644
--- a/yaksh/views.py
+++ b/yaksh/views.py
@@ -561,20 +561,6 @@ def start(request, questionpaper_id=None, attempt_num=None, course_id=None,
raise Http404(msg)
-def _get_question_by_index(all_ordered_questions, questions_by_type):
- return [index+1 for index, item in enumerate(all_ordered_questions)
- if item in set(questions_by_type)]
-
-
-def _get_questions_by_type(all_ordered_questions, objective_types):
- questions_by_type = []
- for types in objective_types:
- for question in all_ordered_questions:
- if question.type == types:
- questions_by_type.append(question)
- return _get_question_by_index(all_ordered_questions, questions_by_type)
-
-
@login_required
@email_verified
def show_question(request, question, paper, error_message=None,
@@ -632,45 +618,53 @@ def show_question(request, question, paper, error_message=None,
all_modules = course.get_learning_modules()
all_question_types = [types[0] for types in question_types]
types = {}
- categories = {}
- categories["objectives"] = questions.filter(Q(type="mcq") |
- Q(type="mcc") |
- Q(type="arrange"))
- categories["blanks"] = questions.filter(Q(type="integer") |
- Q(type="string") |
- Q(type="float"))
- categories["programming"] = questions.filter(Q(type="code"))
- categories["upload"] = questions.filter(Q(type="upload"))
- types["objective_types"] = set([type_.type
- for type_ in categories["objectives"]])
- types["blank_types"] = set([type_.type
- for type_ in categories["blanks"]])
- types["programming_types"] = set([type_.type
- for type_ in categories["programming"]])
- types["upload_types"] = set([type_.type
- for type_ in categories["upload"]])
+ categorized_questions = {}
+ categorized_questions["objectives"] = questions.filter(Q(type="mcq") |
+ Q(type="mcc") |
+ Q(type="arrange"))
+ categorized_questions["blanks"] = questions.filter(Q(type="integer") |
+ Q(type="string") |
+ Q(type="float"))
+ categorized_questions["programming"] = questions.filter(Q(type="code"))
+ categorized_questions["upload"] = questions.filter(Q(type="upload"))
+
+ types["objective_types"] = set([_type.type
+ for _type in
+ categorized_questions["objectives"]])
+ types["blank_types"] = set([_type.type
+ for _type in
+ categorized_questions["blanks"]])
+ types["programming_types"] = set([_type.type
+ for _type in
+ categorized_questions["programming"]])
+ types["upload_types"] = set([_type.type
+ for _type in categorized_questions["upload"]])
+
all_ordered_questions = paper.get_all_ordered_questions()
- objectives_index = _get_questions_by_type(
+
+ objectives_index = paper.get_questions_by_type(
all_ordered_questions,
types["objective_types"]
)
- blanks_index = _get_questions_by_type(
+ blanks_index = paper.get_questions_by_type(
all_ordered_questions,
types["blank_types"]
)
- programming_index = _get_questions_by_type(
+ programming_index = paper.get_questions_by_type(
all_ordered_questions,
types["programming_types"]
)
- upload_index = _get_questions_by_type(
+ upload_index = paper.get_questions_by_type(
all_ordered_questions,
types["upload_types"]
)
- index = {}
- index["objectives_index"] = objectives_index
- index["blanks_index"] = blanks_index
- index["programming_index"] = programming_index
- index["upload_index"] = upload_index
+
+ index = {
+ 'objectives_index': objectives_index,
+ 'blanks_index': blanks_index,
+ 'programming_index': programming_index,
+ 'upload_index': upload_index
+ }
context = {
'question': question,
'paper': paper,