202 lines
7.1 KiB
Python
202 lines
7.1 KiB
Python
"""
|
|
Test instructor.access
|
|
"""
|
|
|
|
|
|
import pytest
|
|
|
|
from common.djangoapps.student.roles import CourseBetaTesterRole, CourseCcxCoachRole, CourseStaffRole
|
|
from common.djangoapps.student.tests.factories import UserFactory
|
|
from lms.djangoapps.instructor.access import (
|
|
allow_access,
|
|
list_with_level,
|
|
is_beta_tester,
|
|
revoke_access,
|
|
update_forum_role
|
|
)
|
|
from openedx.core.djangoapps.ace_common.tests.mixins import EmailTemplateTagMixin
|
|
from openedx.core.djangoapps.django_comment_common.models import FORUM_ROLE_MODERATOR, Role
|
|
from xmodule.modulestore.tests.django_utils import SharedModuleStoreTestCase # lint-amnesty, pylint: disable=wrong-import-order
|
|
from xmodule.modulestore.tests.factories import CourseFactory # lint-amnesty, pylint: disable=wrong-import-order
|
|
|
|
|
|
class TestInstructorAccessList(SharedModuleStoreTestCase):
|
|
""" Test access listings. """
|
|
@classmethod
|
|
def setUpClass(cls):
|
|
super().setUpClass()
|
|
cls.course = CourseFactory.create()
|
|
|
|
def setUp(self):
|
|
super().setUp()
|
|
self.instructors = [UserFactory.create() for _ in range(4)]
|
|
for user in self.instructors:
|
|
allow_access(self.course, user, 'instructor')
|
|
self.beta_testers = [UserFactory.create() for _ in range(4)]
|
|
for user in self.beta_testers:
|
|
allow_access(self.course, user, 'beta')
|
|
|
|
def test_list_instructors(self):
|
|
instructors = list_with_level(self.course.id, 'instructor')
|
|
instructors_alternative = list_with_level(self.course.id, 'instructor')
|
|
assert set(instructors) == set(self.instructors)
|
|
assert set(instructors_alternative) == set(self.instructors)
|
|
|
|
def test_list_beta(self):
|
|
beta_testers = list_with_level(self.course.id, 'beta')
|
|
beta_testers_alternative = list_with_level(self.course.id, 'beta')
|
|
assert set(beta_testers) == set(self.beta_testers)
|
|
assert set(beta_testers_alternative) == set(self.beta_testers)
|
|
|
|
def test_is_beta(self):
|
|
beta_tester = self.beta_testers[0]
|
|
user = UserFactory.create()
|
|
assert is_beta_tester(beta_tester, self.course.id)
|
|
assert not is_beta_tester(user, self.course.id)
|
|
|
|
|
|
class TestInstructorAccessAllow(EmailTemplateTagMixin, SharedModuleStoreTestCase):
|
|
""" Test access allow. """
|
|
@classmethod
|
|
def setUpClass(cls):
|
|
super().setUpClass()
|
|
cls.course = CourseFactory.create()
|
|
|
|
def setUp(self):
|
|
super().setUp()
|
|
|
|
self.course = CourseFactory.create()
|
|
|
|
def test_allow(self):
|
|
user = UserFactory()
|
|
allow_access(self.course, user, 'staff')
|
|
assert CourseStaffRole(self.course.id).has_user(user)
|
|
|
|
def test_allow_twice(self):
|
|
user = UserFactory()
|
|
allow_access(self.course, user, 'staff')
|
|
allow_access(self.course, user, 'staff')
|
|
assert CourseStaffRole(self.course.id).has_user(user)
|
|
|
|
def test_allow_ccx_coach(self):
|
|
user = UserFactory()
|
|
allow_access(self.course, user, 'ccx_coach')
|
|
assert CourseCcxCoachRole(self.course.id).has_user(user)
|
|
|
|
def test_allow_beta(self):
|
|
""" Test allow beta against list beta. """
|
|
user = UserFactory()
|
|
allow_access(self.course, user, 'beta')
|
|
assert CourseBetaTesterRole(self.course.id).has_user(user)
|
|
|
|
def test_allow_badlevel(self):
|
|
user = UserFactory()
|
|
with pytest.raises(ValueError):
|
|
allow_access(self.course, user, 'robot-not-a-level')
|
|
|
|
def test_allow_noneuser(self):
|
|
user = None
|
|
with pytest.raises(Exception):
|
|
allow_access(self.course, user, 'staff')
|
|
|
|
|
|
class TestInstructorAccessRevoke(SharedModuleStoreTestCase):
|
|
""" Test access revoke. """
|
|
@classmethod
|
|
def setUpClass(cls):
|
|
super().setUpClass()
|
|
cls.course = CourseFactory.create()
|
|
|
|
def setUp(self):
|
|
super().setUp()
|
|
self.staff = [UserFactory.create() for _ in range(4)]
|
|
for user in self.staff:
|
|
allow_access(self.course, user, 'staff')
|
|
self.beta_testers = [UserFactory.create() for _ in range(4)]
|
|
for user in self.beta_testers:
|
|
allow_access(self.course, user, 'beta')
|
|
|
|
def test_revoke(self):
|
|
user = self.staff[0]
|
|
revoke_access(self.course, user, 'staff')
|
|
assert not CourseStaffRole(self.course.id).has_user(user)
|
|
|
|
def test_revoke_twice(self):
|
|
user = self.staff[0]
|
|
revoke_access(self.course, user, 'staff')
|
|
assert not CourseStaffRole(self.course.id).has_user(user)
|
|
|
|
def test_revoke_beta(self):
|
|
user = self.beta_testers[0]
|
|
revoke_access(self.course, user, 'beta')
|
|
assert not CourseBetaTesterRole(self.course.id).has_user(user)
|
|
|
|
def test_revoke_badrolename(self):
|
|
user = UserFactory()
|
|
with pytest.raises(ValueError):
|
|
revoke_access(self.course, user, 'robot-not-a-level')
|
|
|
|
|
|
class TestInstructorAccessForum(SharedModuleStoreTestCase):
|
|
"""
|
|
Test forum access control.
|
|
"""
|
|
@classmethod
|
|
def setUpClass(cls):
|
|
super().setUpClass()
|
|
cls.course = CourseFactory.create()
|
|
|
|
def setUp(self):
|
|
super().setUp()
|
|
self.mod_role = Role.objects.create(
|
|
course_id=self.course.id,
|
|
name=FORUM_ROLE_MODERATOR
|
|
)
|
|
self.moderators = [UserFactory.create() for _ in range(4)]
|
|
for user in self.moderators:
|
|
self.mod_role.users.add(user)
|
|
|
|
def test_allow(self):
|
|
user = UserFactory.create()
|
|
update_forum_role(self.course.id, user, FORUM_ROLE_MODERATOR, 'allow')
|
|
assert user in self.mod_role.users.all()
|
|
|
|
def test_allow_twice(self):
|
|
user = UserFactory.create()
|
|
update_forum_role(self.course.id, user, FORUM_ROLE_MODERATOR, 'allow')
|
|
assert user in self.mod_role.users.all()
|
|
update_forum_role(self.course.id, user, FORUM_ROLE_MODERATOR, 'allow')
|
|
assert user in self.mod_role.users.all()
|
|
|
|
def test_allow_badrole(self):
|
|
user = UserFactory.create()
|
|
with pytest.raises(Role.DoesNotExist):
|
|
update_forum_role(self.course.id, user, 'robot-not-a-real-role', 'allow')
|
|
|
|
def test_revoke(self):
|
|
user = self.moderators[0]
|
|
update_forum_role(self.course.id, user, FORUM_ROLE_MODERATOR, 'revoke')
|
|
assert user not in self.mod_role.users.all()
|
|
|
|
def test_revoke_twice(self):
|
|
user = self.moderators[0]
|
|
update_forum_role(self.course.id, user, FORUM_ROLE_MODERATOR, 'revoke')
|
|
assert user not in self.mod_role.users.all()
|
|
update_forum_role(self.course.id, user, FORUM_ROLE_MODERATOR, 'revoke')
|
|
assert user not in self.mod_role.users.all()
|
|
|
|
def test_revoke_notallowed(self):
|
|
user = UserFactory()
|
|
update_forum_role(self.course.id, user, FORUM_ROLE_MODERATOR, 'revoke')
|
|
assert user not in self.mod_role.users.all()
|
|
|
|
def test_revoke_badrole(self):
|
|
user = self.moderators[0]
|
|
with pytest.raises(Role.DoesNotExist):
|
|
update_forum_role(self.course.id, user, 'robot-not-a-real-role', 'allow')
|
|
|
|
def test_bad_mode(self):
|
|
user = UserFactory()
|
|
with pytest.raises(ValueError):
|
|
update_forum_role(self.course.id, user, FORUM_ROLE_MODERATOR, 'robot-not-a-mode')
|