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