summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorPrabhu Ramachandran2014-07-26 18:50:53 +0530
committerPrabhu Ramachandran2014-07-26 18:50:53 +0530
commitec33daea9185bb783c5dcd4f8daddc135b25a0fa (patch)
treee6d6bdc32e2f4930225800ce50887eb76af75d6c
parentbefad018f2e59389e92eaa109c6968bea30d06f9 (diff)
parent0e6c82690650c61049ae8641a2801f0fcbc9c25c (diff)
downloadonline_test-ec33daea9185bb783c5dcd4f8daddc135b25a0fa.tar.gz
online_test-ec33daea9185bb783c5dcd4f8daddc135b25a0fa.tar.bz2
online_test-ec33daea9185bb783c5dcd4f8daddc135b25a0fa.zip
Merge pull request #33 from prathamesh920/initial_fixtures
Added initial fixture.
-rw-r--r--testapp/docs/sample_questions.py24
-rw-r--r--testapp/exam/management/commands/add_group.py33
2 files changed, 50 insertions, 7 deletions
diff --git a/testapp/docs/sample_questions.py b/testapp/docs/sample_questions.py
index 45bb8a8..60f32cb 100644
--- a/testapp/docs/sample_questions.py
+++ b/testapp/docs/sample_questions.py
@@ -4,7 +4,8 @@ questions = [
[Question(
summary='Factorial',
points=2,
- type="python",
+ language='python',
+ type='code',
description='''
Write a function called <code>fact</code> which takes a single integer argument
(say <code>n</code>) and returns the factorial of the number.
@@ -14,7 +15,9 @@ For example:<br/>
test='''
assert fact(0) == 1
assert fact(5) == 120
-'''),
+''',
+ snippet="def fact(num):"
+ ),
#Add tags here as a list of string.
['Python','function','factorial'],
],
@@ -22,7 +25,8 @@ assert fact(5) == 120
[Question(
summary='Simple function',
points=1,
- type="python",
+ language='python',
+ type='code',
description='''Create a simple function called <code>sqr</code> which takes a single
argument and returns the square of the argument. For example: <br/>
<code>sqr(3) -> 9</code>.''',
@@ -30,7 +34,9 @@ argument and returns the square of the argument. For example: <br/>
import math
assert sqr(3) == 9
assert abs(sqr(math.sqrt(2)) - 2.0) < 1e-14
- '''),
+ ''',
+ snippet="def sqr(num):"
+ ),
#Add tags here as a list of string.
['Python','function'],
],
@@ -38,13 +44,16 @@ assert abs(sqr(math.sqrt(2)) - 2.0) < 1e-14
[Question(
summary='Bash addition',
points=2,
- type="bash",
+ language='bash',
+ type='code',
description='''Write a shell script which takes two arguments on the
command line and prints the sum of the two on the output.''',
test='''\
docs/sample.sh
docs/sample.args
-'''),
+''',
+ snippet="#!/bin/bash"
+ ),
#Add tags here as a list of string.
[''],
],
@@ -52,7 +61,8 @@ docs/sample.args
[Question(
summary='Size of integer in Python',
points=0.5,
- type="mcq",
+ language='python',
+ type='mcq',
description='''What is the largest integer value that can be represented
in Python?''',
options='''No Limit
diff --git a/testapp/exam/management/commands/add_group.py b/testapp/exam/management/commands/add_group.py
new file mode 100644
index 0000000..76cc655
--- /dev/null
+++ b/testapp/exam/management/commands/add_group.py
@@ -0,0 +1,33 @@
+'''
+ This command adds moderator group with permissions to add, change and delete
+ the objects in the exam app.
+ We can modify this command to add more groups by providing arguments.
+ Arguments like group-name, app-name can be passed.
+'''
+
+# django imports
+from django.core.management.base import BaseCommand, CommandError
+from django.contrib.auth.models import Group, Permission
+from django.contrib.contenttypes.models import ContentType
+from django.db.utils import IntegrityError
+
+class Command(BaseCommand):
+ help = 'Adds the moderator group'
+
+ def handle(self, *args, **options):
+ app = 'exam'
+ group = Group(name='moderator')
+ try:
+ group.save()
+ except IntegrityError:
+ raise CommandError("The group already exits")
+ else:
+ # Get the models for the given app
+ content_types = ContentType.objects.filter(app_label=app)
+ # Get list of permissions for the models
+ permission_list = Permission.objects.filter(content_type=content_types)
+ for permission in permission_list:
+ group.permissions.add(permission)
+ group.save()
+
+ self.stdout.write('Moderator group added successfully')