diff options
author | Prabhu Ramachandran | 2014-07-26 18:50:53 +0530 |
---|---|---|
committer | Prabhu Ramachandran | 2014-07-26 18:50:53 +0530 |
commit | ec33daea9185bb783c5dcd4f8daddc135b25a0fa (patch) | |
tree | e6d6bdc32e2f4930225800ce50887eb76af75d6c /testapp | |
parent | befad018f2e59389e92eaa109c6968bea30d06f9 (diff) | |
parent | 0e6c82690650c61049ae8641a2801f0fcbc9c25c (diff) | |
download | online_test-ec33daea9185bb783c5dcd4f8daddc135b25a0fa.tar.gz online_test-ec33daea9185bb783c5dcd4f8daddc135b25a0fa.tar.bz2 online_test-ec33daea9185bb783c5dcd4f8daddc135b25a0fa.zip |
Merge pull request #33 from prathamesh920/initial_fixtures
Added initial fixture.
Diffstat (limited to 'testapp')
-rw-r--r-- | testapp/docs/sample_questions.py | 24 | ||||
-rw-r--r-- | testapp/exam/management/commands/add_group.py | 33 |
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') |