class EnrollmentsServiceTests(ModuleStoreTestCase): """ Tests for Enrollments Service """ def setUp(self): super().setUp() self.service = EnrollmentsService() self.course = CourseFactory.create() self.course_modes = [ CourseMode.HONOR, CourseMode.VERIFIED, CourseMode.AUDIT ] for x in range(3): CourseModeFactory.create(mode_slug=self.course_modes[x], course_id=self.course.id) user = UserFactory(username='******'.format(x)) CourseEnrollment.enroll(user, self.course.id, mode=self.course_modes[x]) def test_get_active_enrollments_by_course(self): """ Test that it returns a list of active enrollments """ enrollments = self.service.get_active_enrollments_by_course( self.course.id) assert len(enrollments) == 3 # At minimum, the function should return the user and mode tied to each enrollment for x in range(3): assert enrollments[x].user.username == 'user{}'.format(x) assert enrollments[x].mode == self.course_modes[x] def test_get_active_enrollments_by_course_ignore_inactive(self): """ Test that inactive enrollments are ignored """ inactive_enrollment = CourseEnrollment.objects.get( course_id=self.course.id, user__username='******') inactive_enrollment.is_active = False inactive_enrollment.save() enrollments = self.service.get_active_enrollments_by_course( self.course.id) assert len(enrollments) == 2 def test_get_active_enrollments_no_enrollments(self): """ Test that an empty list is returned if a course has no enrollments """ new_course = CourseFactory() enrollments = self.service.get_active_enrollments_by_course( new_course.id) # pylint: disable=no-member assert len(enrollments) == 0
class EnrollmentsServicePerformanceTests(ModuleStoreTestCase): """ Tests for Enrollments Service performance """ def setUp(self): super().setUp() self.service = EnrollmentsService() self.course = CourseFactory.create(enable_proctored_exams=True) self.course_modes = [ CourseMode.AUDIT, CourseMode.EXECUTIVE_EDUCATION, CourseMode.HONOR, CourseMode.MASTERS, CourseMode.PROFESSIONAL, CourseMode.VERIFIED, ] for index in range(len(self.course_modes)): CourseModeFactory.create(mode_slug=self.course_modes[index], course_id=self.course.id) def create_and_enroll_users(self, num_users): num_course_modes = len(self.course_modes) for index in range(num_users): user = UserFactory(username='******'.format(index)) CourseEnrollment.enroll(user, self.course.id, mode=self.course_modes[index % num_course_modes]) @ddt.data(10, 25, 50) def test_get_enrollments_can_take_proctored_exams_num_queries( self, num_users): self.create_and_enroll_users(num_users) with self.assertNumQueries(1): enrollments = self.service.get_enrollments_can_take_proctored_exams( str(self.course.id)) # force execution of the QuerySet so that queries are exectued repr(enrollments) @ddt.data(10, 25, 50) def test_get_enrollments_can_take_proctored_exams_num_queries_text_search( self, num_users): self.create_and_enroll_users(num_users) with self.assertNumQueries(1): enrollments = self.service.get_enrollments_can_take_proctored_exams( str(self.course.id), text_search='edX') # force execution of the QuerySet so that queries are exectued repr(enrollments)
def setUp(self): super().setUp() self.service = EnrollmentsService() self.course = CourseFactory.create() self.course_modes = [ CourseMode.HONOR, CourseMode.VERIFIED, CourseMode.AUDIT ] for x in range(3): CourseModeFactory.create(mode_slug=self.course_modes[x], course_id=self.course.id) user = UserFactory(username='******'.format(x)) CourseEnrollment.enroll(user, self.course.id, mode=self.course_modes[x])
def setUp(self): super().setUp() self.service = EnrollmentsService() self.course = CourseOverviewFactory.create(enable_proctored_exams=True) self.course_modes = [ CourseMode.AUDIT, CourseMode.EXECUTIVE_EDUCATION, CourseMode.HONOR, CourseMode.MASTERS, CourseMode.PROFESSIONAL, CourseMode.VERIFIED, ] for index in range(len(self.course_modes)): CourseModeFactory.create(mode_slug=self.course_modes[index], course_id=self.course.id)
def setUp(self): super().setUp() self.service = EnrollmentsService() self.course_modes = [ CourseMode.AUDIT, CourseMode.EXECUTIVE_EDUCATION, CourseMode.HONOR, CourseMode.MASTERS, CourseMode.PROFESSIONAL, CourseMode.VERIFIED ] self.course = CourseFactory.create(enable_proctored_exams=True) for index in range(len(self.course_modes)): course_mode = self.course_modes[index] course_id = self.course.id CourseModeFactory.create(mode_slug=course_mode, course_id=course_id) user = UserFactory(username='******'.format(index), email='LEARNER{}@example.com'.format(index)) CourseEnrollment.enroll(user, course_id, mode=course_mode)
class EnrollmentsServiceTests(ModuleStoreTestCase): """ Tests for Enrollments Service """ def setUp(self): super().setUp() self.service = EnrollmentsService() self.course_modes = [ CourseMode.AUDIT, CourseMode.EXECUTIVE_EDUCATION, CourseMode.HONOR, CourseMode.MASTERS, CourseMode.PROFESSIONAL, CourseMode.VERIFIED ] self.course = CourseOverviewFactory.create(enable_proctored_exams=True) for index in range(len(self.course_modes)): course_mode = self.course_modes[index] course_id = self.course.id CourseModeFactory.create(mode_slug=course_mode, course_id=course_id) user = UserFactory( username=f'user{index}', email=f'LEARNER{index}@example.com' ) CourseEnrollment.enroll(user, course_id, mode=course_mode) def enrollment_to_dict(self, enrollment): return {'username': enrollment.username, 'mode': enrollment.mode} def test_get_enrollments_can_take_proctored_exams_by_course(self): """ Test that it returns a list of active enrollments """ enrollments = self.service.get_enrollments_can_take_proctored_exams(str(self.course.id)) expected_values = [ {'username': '******', 'mode': 'executive-education'}, {'username': '******', 'mode': 'masters'}, {'username': '******', 'mode': 'professional'}, {'username': '******', 'mode': 'verified'} ] self.assertQuerysetEqual(enrollments, expected_values, self.enrollment_to_dict) def test_get_enrollments_can_take_proctored_exams_by_course_ignore_inactive(self): """ Test that inactive enrollments are ignored """ inactive_enrollment = CourseEnrollment.objects.get(course_id=self.course.id, user__username='******') inactive_enrollment.is_active = False inactive_enrollment.save() enrollments = self.service.get_enrollments_can_take_proctored_exams(str(self.course.id)) assert len(enrollments) == 3 def test_get_enrollments_can_take_proctored_exams_no_enrollments(self): """ Test that an empty list is returned if a course has no enrollments """ course = CourseOverviewFactory.create(enable_proctored_exams=True) enrollments = self.service.get_enrollments_can_take_proctored_exams(str(course.id)) # pylint: disable=no-member assert not enrollments.exists() def test_get_enrollments_can_take_proctored_exams_allow_honor(self): self.course.proctoring_provider = 'test' self.course.save() mock_proctoring_backend = { 'test': { 'allow_honor_mode': True } } with self.settings(PROCTORING_BACKENDS=mock_proctoring_backend): enrollments = self.service.get_enrollments_can_take_proctored_exams(str(self.course.id)) expected_values = [ {'username': '******', 'mode': 'executive-education'}, {'username': '******', 'mode': 'honor'}, {'username': '******', 'mode': 'masters'}, {'username': '******', 'mode': 'professional'}, {'username': '******', 'mode': 'verified'} ] self.assertQuerysetEqual(enrollments, expected_values, self.enrollment_to_dict) def test_get_enrollments_can_take_proctored_exams_not_enable_proctored_exams(self): self.course.enable_proctored_exams = False self.course.save() enrollments = self.service.get_enrollments_can_take_proctored_exams(str(self.course.id)) assert enrollments is None def test_get_enrollments_can_take_proctored_exams_no_course(self): enrollments = self.service.get_enrollments_can_take_proctored_exams('org.0/course_0/Run_100') assert enrollments is None @ddt.data('ser', 'uSeR', 'leaRNer', 'LEARNER', '@example.com') def test_text_search_partial_return_all(self, text_search): enrollments = self.service.get_enrollments_can_take_proctored_exams( str(self.course.id), text_search=text_search ) expected_values = [ {'username': '******', 'mode': 'executive-education'}, {'username': '******', 'mode': 'masters'}, {'username': '******', 'mode': 'professional'}, {'username': '******', 'mode': 'verified'} ] self.assertQuerysetEqual(enrollments, expected_values, self.enrollment_to_dict) def test_text_search_partial_return_some(self): enrollments = self.service.get_enrollments_can_take_proctored_exams( str(self.course.id), text_search='3' ) expected_values = [ {'username': '******', 'mode': 'masters'} ] self.assertQuerysetEqual(enrollments, expected_values, self.enrollment_to_dict) @ddt.data('user1', 'USER1', '*****@*****.**', '*****@*****.**') def test_text_search_exact_return_one(self, text_search): enrollments = self.service.get_enrollments_can_take_proctored_exams( str(self.course.id), text_search=text_search ) expected_values = [ {'username': '******', 'mode': 'executive-education'} ] self.assertQuerysetEqual(enrollments, expected_values, self.enrollment_to_dict) def test_text_search_return_none(self): enrollments = self.service.get_enrollments_can_take_proctored_exams( str(self.course.id), text_search='abc' ) assert not enrollments.exists()