From d8a162ce5484dcdcb47ab0f01cc55ab4495bcc06 Mon Sep 17 00:00:00 2001 From: prathamesh Date: Wed, 9 Jul 2014 00:04:05 +0530 Subject: Added initial fixture. Creates moderator group. Adds four questions. "./bin/django loaddata fixture_name" will load the data. --- testapp/exam/fixtures/initial_fixture.json | 91 ++++++++++++++++++++++++++++++ 1 file changed, 91 insertions(+) create mode 100644 testapp/exam/fixtures/initial_fixture.json (limited to 'testapp/exam') diff --git a/testapp/exam/fixtures/initial_fixture.json b/testapp/exam/fixtures/initial_fixture.json new file mode 100644 index 0000000..da3cf18 --- /dev/null +++ b/testapp/exam/fixtures/initial_fixture.json @@ -0,0 +1,91 @@ +[ + { + "fields": { + "active": true, + "description": "\nWrite a function called fact which takes a single integer argument\n(say n) and returns the factorial of the number. \nFor example:
\nfact(3) -> 6\n", + "options": "", + "points": 2.0, + "summary": "Factorial", + "test": "\nassert fact(0) == 1\nassert fact(5) == 120\n", + "type": "python" + }, + "model": "exam.question", + "pk": 1 + }, + { + "fields": { + "active": true, + "description": "Create a simple function called sqr which takes a single \nargument and returns the square of the argument. For example:
\nsqr(3) -> 9.", + "options": "", + "points": 1.0, + "summary": "Simple function", + "test": "\nimport math\nassert sqr(3) == 9\nassert abs(sqr(math.sqrt(2)) - 2.0) < 1e-14 \n ", + "type": "python" + }, + "model": "exam.question", + "pk": 2 + }, + { + "fields": { + "active": true, + "description": "Write a shell script which takes two arguments on the\ncommand line and prints the sum of the two on the output.", + "options": "", + "points": 2.0, + "summary": "Bash addition", + "test": "docs/sample.sh\ndocs/sample.args\n", + "type": "bash" + }, + "model": "exam.question", + "pk": 3 + }, + { + "fields": { + "active": true, + "description": "What is the largest integer value that can be represented\nin Python?", + "options": "No Limit\n2**32\n2**32 - 1\nNone of the above\n", + "points": 0.5, + "summary": "Size of integer in Python", + "test": "No Limit", + "type": "mcq" + }, + "model": "exam.question", + "pk": 4 + }, + { + "fields": { + "active": true, + "description": "Basic Python Quiz 1", + "duration": 10, + "start_date": "2012-03-29" + }, + "model": "exam.quiz", + "pk": 1 + }, + { + "fields": { + "name": "moderator", + "permissions": [ + 31, + 37, + 43, + 32, + 38, + 44, + 33, + 39, + 45, + 34, + 40, + 46, + 35, + 41, + 47, + 36, + 42, + 48 + ] + }, + "model": "auth.group", + "pk": 1 + } +] -- cgit From 75ab9c232e10046e618f40f717cc7df54c6eca34 Mon Sep 17 00:00:00 2001 From: prathamesh Date: Fri, 11 Jul 2014 14:43:55 +0530 Subject: Made modifications. initial_fixture only to add moderator group. sample_question file modified to add language and snippet. --- testapp/exam/fixtures/initial_fixture.json | 62 ------------------------------ 1 file changed, 62 deletions(-) (limited to 'testapp/exam') diff --git a/testapp/exam/fixtures/initial_fixture.json b/testapp/exam/fixtures/initial_fixture.json index da3cf18..e1b49b7 100644 --- a/testapp/exam/fixtures/initial_fixture.json +++ b/testapp/exam/fixtures/initial_fixture.json @@ -1,66 +1,4 @@ [ - { - "fields": { - "active": true, - "description": "\nWrite a function called fact which takes a single integer argument\n(say n) and returns the factorial of the number. \nFor example:
\nfact(3) -> 6\n", - "options": "", - "points": 2.0, - "summary": "Factorial", - "test": "\nassert fact(0) == 1\nassert fact(5) == 120\n", - "type": "python" - }, - "model": "exam.question", - "pk": 1 - }, - { - "fields": { - "active": true, - "description": "Create a simple function called sqr which takes a single \nargument and returns the square of the argument. For example:
\nsqr(3) -> 9.", - "options": "", - "points": 1.0, - "summary": "Simple function", - "test": "\nimport math\nassert sqr(3) == 9\nassert abs(sqr(math.sqrt(2)) - 2.0) < 1e-14 \n ", - "type": "python" - }, - "model": "exam.question", - "pk": 2 - }, - { - "fields": { - "active": true, - "description": "Write a shell script which takes two arguments on the\ncommand line and prints the sum of the two on the output.", - "options": "", - "points": 2.0, - "summary": "Bash addition", - "test": "docs/sample.sh\ndocs/sample.args\n", - "type": "bash" - }, - "model": "exam.question", - "pk": 3 - }, - { - "fields": { - "active": true, - "description": "What is the largest integer value that can be represented\nin Python?", - "options": "No Limit\n2**32\n2**32 - 1\nNone of the above\n", - "points": 0.5, - "summary": "Size of integer in Python", - "test": "No Limit", - "type": "mcq" - }, - "model": "exam.question", - "pk": 4 - }, - { - "fields": { - "active": true, - "description": "Basic Python Quiz 1", - "duration": 10, - "start_date": "2012-03-29" - }, - "model": "exam.quiz", - "pk": 1 - }, { "fields": { "name": "moderator", -- cgit From 8abd57cf58a432ff173ad757d8a9c707013f96b9 Mon Sep 17 00:00:00 2001 From: prathamesh Date: Wed, 23 Jul 2014 16:48:42 +0530 Subject: Command 'add_group' created for adding the moderator group --- testapp/exam/fixtures/initial_fixture.json | 29 ----------------------- testapp/exam/management/commands/add_group.py | 33 +++++++++++++++++++++++++++ 2 files changed, 33 insertions(+), 29 deletions(-) delete mode 100644 testapp/exam/fixtures/initial_fixture.json create mode 100644 testapp/exam/management/commands/add_group.py (limited to 'testapp/exam') diff --git a/testapp/exam/fixtures/initial_fixture.json b/testapp/exam/fixtures/initial_fixture.json deleted file mode 100644 index e1b49b7..0000000 --- a/testapp/exam/fixtures/initial_fixture.json +++ /dev/null @@ -1,29 +0,0 @@ -[ - { - "fields": { - "name": "moderator", - "permissions": [ - 31, - 37, - 43, - 32, - 38, - 44, - 33, - 39, - 45, - 34, - 40, - 46, - 35, - 41, - 47, - 36, - 42, - 48 - ] - }, - "model": "auth.group", - "pk": 1 - } -] diff --git a/testapp/exam/management/commands/add_group.py b/testapp/exam/management/commands/add_group.py new file mode 100644 index 0000000..e6ac888 --- /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') -- cgit From 0e6c82690650c61049ae8641a2801f0fcbc9c25c Mon Sep 17 00:00:00 2001 From: prathamesh Date: Thu, 24 Jul 2014 11:59:03 +0530 Subject: Removed space --- testapp/exam/management/commands/add_group.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) (limited to 'testapp/exam') diff --git a/testapp/exam/management/commands/add_group.py b/testapp/exam/management/commands/add_group.py index e6ac888..76cc655 100644 --- a/testapp/exam/management/commands/add_group.py +++ b/testapp/exam/management/commands/add_group.py @@ -3,8 +3,8 @@ 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 -- cgit