summaryrefslogtreecommitdiff
path: root/yaksh/models.py
diff options
context:
space:
mode:
authoradityacp2016-04-25 14:34:54 +0530
committeradityacp2016-05-04 22:47:34 +0530
commit83b4826a242a6825197e42eb233f9301f99f3716 (patch)
tree7468566dcc8dcd9cdfd9162873d03f1cf90253d8 /yaksh/models.py
parentb74128df59de974032d630a267a15e7d0c91a593 (diff)
downloadonline_test-83b4826a242a6825197e42eb233f9301f99f3716.tar.gz
online_test-83b4826a242a6825197e42eb233f9301f99f3716.tar.bz2
online_test-83b4826a242a6825197e42eb233f9301f99f3716.zip
added test cases for loading and dumping questions
Diffstat (limited to 'yaksh/models.py')
-rw-r--r--yaksh/models.py21
1 files changed, 21 insertions, 0 deletions
diff --git a/yaksh/models.py b/yaksh/models.py
index c76d655..b7df67c 100644
--- a/yaksh/models.py
+++ b/yaksh/models.py
@@ -211,6 +211,27 @@ class Question(models.Model):
return json.dumps(question_info_dict)
+ def dump_questions_into_json(self, user):
+ questions = Question.objects.filter(user_id = user.id)
+ questions_dict = [{'summary': question.summary,
+ 'description': question.description,
+ 'points': question.points, 'test': question.test,
+ 'ref_code_path': question.ref_code_path,
+ 'options': question.options, 'language': question.language,
+ 'type': question.type, 'active': question.active,
+ 'snippet': question.snippet} for question in questions]
+ return json.dumps(questions_dict, indent=2)
+
+ def load_questions_from_json(self, questions_list, user):
+ questions = json.loads(questions_list)
+ for question in questions:
+ Question.objects.get_or_create(summary=question['summary'],
+ description=question['description'], points=question['points'],
+ test=question['test'], ref_code_path=question['ref_code_path'],
+ options=question['options'], language=question['language'],
+ type=question['type'], active=question['active'],
+ snippet=question['snippet'], user=user)
+
def __unicode__(self):
return self.summary