summaryrefslogtreecommitdiff
path: root/yaksh/models.py
diff options
context:
space:
mode:
authorPrabhu Ramachandran2017-05-05 17:45:41 +0530
committerGitHub2017-05-05 17:45:41 +0530
commit4cd448769c6cc230b7a33a1848cc45873b578468 (patch)
tree1bd9f9b020f988558b22cf406523ac2082558c7e /yaksh/models.py
parente56c50bb99a8694e8f1c8533df3f04e4613bcb08 (diff)
parente9d5de3d83d925921365f5574ce787a24abbd90c (diff)
downloadonline_test-4cd448769c6cc230b7a33a1848cc45873b578468.tar.gz
online_test-4cd448769c6cc230b7a33a1848cc45873b578468.tar.bz2
online_test-4cd448769c6cc230b7a33a1848cc45873b578468.zip
Merge pull request #288 from ankitjavalkar/course-clone
Add a negative test case to check attributes are duplicated
Diffstat (limited to 'yaksh/models.py')
-rw-r--r--yaksh/models.py20
1 files changed, 10 insertions, 10 deletions
diff --git a/yaksh/models.py b/yaksh/models.py
index ad64f2a..565bb23 100644
--- a/yaksh/models.py
+++ b/yaksh/models.py
@@ -151,21 +151,21 @@ class Course(models.Model):
objects = CourseManager()
+ def _create_duplicate_instance(self, creator, course_name=None):
+ new_course = self
+ new_course.id = None
+ new_course.name = course_name if course_name else self.name
+ new_course.creator = creator
+ new_course.save()
+ return new_course
+
def create_duplicate_course(self, user):
quizzes = self.quiz_set.all()
prerequisite_map = []
duplicate_quiz_map = {}
- new_course = Course.objects.create(creator=user,
- name="Copy Of {0}".format(self.name),
- enrollment=self.enrollment,
- active=self.active,
- is_trial=self.is_trial,
- instructions=self.instructions,
- start_enroll_time=self.start_enroll_time,
- end_enroll_time=self.end_enroll_time
- )
- new_course.teachers.add(*self.teachers.all())
+ new_course_name = "Copy Of {0}".format(self.name)
+ new_course = self._create_duplicate_instance(user, new_course_name)
for q in quizzes:
new_quiz = q._create_duplicate_quiz(new_course)