summaryrefslogtreecommitdiff
path: root/yaksh/test_views.py
diff options
context:
space:
mode:
authoradityacp2017-12-14 16:50:46 +0530
committeradityacp2017-12-14 16:50:46 +0530
commitb44db042059e69df4c4a948d6dff73604c7abf83 (patch)
treefee6cb0a3d634c1d1fab3b4a3e84f5e31ca928ba /yaksh/test_views.py
parent1063ea69f8ee39e5ba249b24700256383abb61ac (diff)
downloadonline_test-b44db042059e69df4c4a948d6dff73604c7abf83.tar.gz
online_test-b44db042059e69df4c4a948d6dff73604c7abf83.tar.bz2
online_test-b44db042059e69df4c4a948d6dff73604c7abf83.zip
Change in test_views and views
- Add new tests for views - Pep8 changes in views
Diffstat (limited to 'yaksh/test_views.py')
-rw-r--r--yaksh/test_views.py98
1 files changed, 98 insertions, 0 deletions
diff --git a/yaksh/test_views.py b/yaksh/test_views.py
index 45d3314..d65fe8e 100644
--- a/yaksh/test_views.py
+++ b/yaksh/test_views.py
@@ -1574,6 +1574,7 @@ class TestCourses(TestCase):
self.user2_course = Course.objects.create(name="Java Course",
enrollment="Enroll Request", creator=self.user2)
+ self.user2_course.learning_module.add(self.learning_module)
def tearDown(self):
self.client.logout()
@@ -1733,6 +1734,61 @@ class TestCourses(TestCase):
self.assertEqual(response.context['learning_modules'][0],
self.learning_module)
+ def test_duplicate_course(self):
+ """ Test To clone/duplicate course """
+
+ # Student Login
+ self.client.login(
+ username=self.student.username,
+ password=self.student_plaintext_pass
+ )
+
+ response = self.client.get(
+ reverse('yaksh:duplicate_course',
+ kwargs={"course_id": self.user2_course.id}),
+ follow=True
+ )
+ self.assertEqual(response.status_code, 404)
+
+ # Teacher Login
+ self.client.login(
+ username=self.teacher.username,
+ password=self.teacher_plaintext_pass
+ )
+
+ # Denies teacher not added in the course
+ response = self.client.get(
+ reverse('yaksh:duplicate_course',
+ kwargs={"course_id": self.user2_course.id}),
+ follow=True
+ )
+ err_msg = "You do not have permissions"
+ self.assertEqual(response.status_code, 200)
+ self.assertTemplateUsed(response, "yaksh/complete.html")
+ self.assertIn(err_msg, response.context['message'])
+
+ # Moderator/Course creator login
+ self.client.login(
+ username=self.user2.username,
+ password=self.user2_plaintext_pass
+ )
+
+ # Allows creator to duplicate the course
+ response = self.client.get(
+ reverse('yaksh:duplicate_course',
+ kwargs={"course_id": self.user2_course.id}),
+ follow=True
+ )
+
+ self.assertEqual(response.status_code, 200)
+ courses = Course.objects.filter(
+ creator=self.user2).order_by("id")
+ self.assertEqual(courses.count(), 2)
+ self.assertEqual(courses.last().creator, self.user2)
+ self.assertEqual(courses.last().name, "Copy Of Java Course")
+ self.assertEqual(courses.last().get_learning_modules()[0].id,
+ self.user2_course.get_learning_modules()[0].id)
+
class TestAddCourse(TestCase):
def setUp(self):
@@ -2298,6 +2354,27 @@ class TestCourseDetail(TestCase):
self.assertEqual(get_response.context['course'], self.user1_course)
self.assertEqual(get_response.context['state'], 'mail')
+ def test_download_users_template(self):
+ """ Test to check download users template """
+ self.client.login(
+ username=self.student.username,
+ password=self.student_plaintext_pass
+ )
+
+ # Denies student to download users upload template
+ response = self.client.get(reverse('yaksh:download_sample_csv'))
+ self.assertEqual(response.status_code, 404)
+
+ # Moderator Login
+ self.client.login(
+ username=self.user1.username,
+ password=self.user1_plaintext_pass
+ )
+ response = self.client.get(reverse('yaksh:download_sample_csv'))
+ self.assertEqual(response.status_code, 200)
+ self.assertEqual(response.get('Content-Disposition'),
+ 'attachment; filename="sample_user_upload"')
+
class TestEnrollRequest(TestCase):
def setUp(self):
@@ -3583,6 +3660,27 @@ class TestShowQuestions(TestCase):
self.assertTemplateUsed(response, 'yaksh/ajax_question_filter.html')
self.assertEqual(response.context['questions'][0], self.question1)
+ def test_download_question_yaml_template(self):
+ """ Test to check download question yaml template """
+ self.client.login(
+ username=self.student.username,
+ password=self.student_plaintext_pass
+ )
+
+ # Denies student to download question yaml template
+ response = self.client.get(reverse('yaksh:download_yaml_template'))
+ self.assertEqual(response.status_code, 404)
+
+ # Moderator Login
+ self.client.login(
+ username=self.user.username,
+ password=self.user_plaintext_pass
+ )
+ response = self.client.get(reverse('yaksh:download_yaml_template'))
+ self.assertEqual(response.status_code, 200)
+ self.assertEqual(response.get('Content-Disposition'),
+ 'attachment; filename="questions_dump.yaml"')
+
class TestShowStatistics(TestCase):
def setUp(self):