summaryrefslogtreecommitdiff
path: root/testapp/exam/management/commands/load_exam.py
diff options
context:
space:
mode:
authorPrabhu Ramachandran2011-12-24 05:46:36 -0800
committerPrabhu Ramachandran2011-12-24 05:46:36 -0800
commit95e9ea0f60b21595fa0f6ffea12da13b33821018 (patch)
tree8114286da06869c7059d6dbb2322641f15202408 /testapp/exam/management/commands/load_exam.py
parent7104f495d01fb934af11c8dfd09da087174c1b12 (diff)
parent7b819758d4d60822c19611845a44f8c5301a391c (diff)
downloadonline_test-95e9ea0f60b21595fa0f6ffea12da13b33821018.tar.gz
online_test-95e9ea0f60b21595fa0f6ffea12da13b33821018.tar.bz2
online_test-95e9ea0f60b21595fa0f6ffea12da13b33821018.zip
Merge pull request #2 from parth115/master
Changed to Buildout
Diffstat (limited to 'testapp/exam/management/commands/load_exam.py')
-rw-r--r--testapp/exam/management/commands/load_exam.py55
1 files changed, 55 insertions, 0 deletions
diff --git a/testapp/exam/management/commands/load_exam.py b/testapp/exam/management/commands/load_exam.py
new file mode 100644
index 0000000..3f247a1
--- /dev/null
+++ b/testapp/exam/management/commands/load_exam.py
@@ -0,0 +1,55 @@
+# System library imports.
+from os.path import basename
+
+# Django imports.
+from django.core.management.base import BaseCommand
+
+# Local imports.
+from exam.models import Question, Quiz
+
+def clear_exam():
+ """Deactivate all questions from the database."""
+ for question in Question.objects.all():
+ question.active = False
+ question.save()
+
+ # Deactivate old quizzes.
+ for quiz in Quiz.objects.all():
+ quiz.active = False
+ quiz.save()
+
+def load_exam(filename):
+ """Load questions and quiz from the given Python file. The Python file
+ should declare a list of name "questions" which define all the questions
+ in pure Python. It can optionally load a Quiz from an optional 'quiz'
+ object.
+ """
+ # Simply exec the given file and we are done.
+ exec(open(filename).read())
+
+ if 'questions' not in locals():
+ msg = 'No variable named "questions" with the Questions in file.'
+ raise NameError(msg)
+
+ for question in questions:
+ question.save()
+
+ if 'quiz' in locals():
+ quiz.save()
+
+class Command(BaseCommand):
+ args = '<q_file1.py q_file2.py>'
+ help = '''loads the questions from given Python files which declare the
+ questions in a list called "questions".'''
+
+ def handle(self, *args, **options):
+ """Handle the command."""
+ # Delete existing stuff.
+ clear_exam()
+
+ # Load from files.
+ for fname in args:
+ self.stdout.write('Importing from {0} ... '.format(basename(fname)))
+ load_exam(fname)
+ self.stdout.write('Done\n')
+