Skip to content

Commit

Permalink
feat: upgrading simple api to drf compatible.
Browse files Browse the repository at this point in the history
  • Loading branch information
awais786 committed Aug 7, 2024
1 parent 7077e7a commit 0734ae9
Show file tree
Hide file tree
Showing 2 changed files with 87 additions and 49 deletions.
134 changes: 85 additions & 49 deletions lms/djangoapps/instructor/tests/test_api.py
Original file line number Diff line number Diff line change
Expand Up @@ -353,7 +353,7 @@ def test_endpoints_accept_get(self, data):


@patch('lms.djangoapps.bulk_email.models.html_to_text', Mock(return_value='Mocking CourseEmail.text_message', autospec=True)) # lint-amnesty, pylint: disable=line-too-long
class TestInstructorAPIDenyLevels(SharedModuleStoreTestCase, LoginEnrollmentTestCase):
class TestInstructorAPIDenyLevels(SiteMixin,SharedModuleStoreTestCase, LoginEnrollmentTestCase):
"""
Ensure that users cannot access endpoints they shouldn't be able to.
"""
Expand Down Expand Up @@ -414,49 +414,49 @@ def setUp(self):

# Endpoints that only Staff or Instructors can access
self.staff_level_endpoints = [
('students_update_enrollment',
{'identifiers': '[email protected]', 'action': 'enroll'}),
('get_grading_config', {}),
('get_students_features', {}),
('get_student_progress_url', {'unique_student_identifier': self.user.username}),
('update_forum_role_membership',
{'unique_student_identifier': self.user.email, 'rolename': 'Moderator', 'action': 'allow'}),
('list_forum_members', {'rolename': FORUM_ROLE_COMMUNITY_TA}),
('send_email', {'send_to': '["staff"]', 'subject': 'test', 'message': 'asdf'}),
('list_instructor_tasks', {}),
('instructor_api_v1:list_instructor_tasks', {}),
('list_background_email_tasks', {}),
('instructor_api_v1:list_report_downloads', {}),
('calculate_grades_csv', {}),
('get_students_features', {}),
# ('students_update_enrollment',
# {'identifiers': '[email protected]', 'action': 'enroll'}),
# ('get_grading_config', {}),
# ('get_students_features', {}),
# ('get_student_progress_url', {'unique_student_identifier': self.user.username}),
# ('update_forum_role_membership',
# {'unique_student_identifier': self.user.email, 'rolename': 'Moderator', 'action': 'allow'}),
# ('list_forum_members', {'rolename': FORUM_ROLE_COMMUNITY_TA}),
# # ('send_email', {'send_to': '["staff"]', 'subject': 'test', 'message': 'asdf'}),
# ('list_instructor_tasks', {}),
# ('instructor_api_v1:list_instructor_tasks', {}),
# ('list_background_email_tasks', {}),
# ('instructor_api_v1:list_report_downloads', {}),
# ('calculate_grades_csv', {}),
# ('get_students_features', {}),
('get_students_who_may_enroll', {}),
('get_proctored_exam_results', {}),
('get_problem_responses', {}),
('instructor_api_v1:generate_problem_responses', {"problem_locations": [str(self.problem.location)]}),
('export_ora2_data', {}),
('export_ora2_submission_files', {}),
('export_ora2_summary', {}),
('rescore_problem',
{'problem_to_reset': self.problem_urlname, 'unique_student_identifier': self.user.email}),
('override_problem_score',
{'problem_to_reset': self.problem_urlname, 'unique_student_identifier': self.user.email, 'score': 0}),
('reset_student_attempts',
{'problem_to_reset': self.problem_urlname, 'unique_student_identifier': self.user.email}),
(
'reset_student_attempts',
{
'problem_to_reset': self.problem_urlname,
'unique_student_identifier': self.user.email,
'delete_module': True
}
),
# ('get_proctored_exam_results', {}),
# ('get_problem_responses', {}),
# ('instructor_api_v1:generate_problem_responses', {"problem_locations": [str(self.problem.location)]}),
# ('export_ora2_data', {}),
# ('export_ora2_submission_files', {}),
# ('export_ora2_summary', {}),
# ('rescore_problem',
# {'problem_to_reset': self.problem_urlname, 'unique_student_identifier': self.user.email}),
# ('override_problem_score',
# {'problem_to_reset': self.problem_urlname, 'unique_student_identifier': self.user.email, 'score': 0}),
# ('reset_student_attempts',
# {'problem_to_reset': self.problem_urlname, 'unique_student_identifier': self.user.email}),
# (
# 'reset_student_attempts',
# {
# 'problem_to_reset': self.problem_urlname,
# 'unique_student_identifier': self.user.email,
# 'delete_module': True
# }
# ),
]
# Endpoints that only Instructors can access
self.instructor_level_endpoints = [
('bulk_beta_modify_access', {'identifiers': '[email protected]', 'action': 'add'}),
('modify_access', {'unique_student_identifier': self.user.email, 'rolename': 'beta', 'action': 'allow'}),
('list_course_role_members', {'rolename': 'beta'}),
('rescore_problem', {'problem_to_reset': self.problem_urlname, 'all_students': True}),
# ('bulk_beta_modify_access', {'identifiers': '[email protected]', 'action': 'add'}),
# ('modify_access', {'unique_student_identifier': self.user.email, 'rolename': 'beta', 'action': 'allow'}),
# ('list_course_role_members', {'rolename': 'beta'}),
# ('rescore_problem', {'problem_to_reset': self.problem_urlname, 'all_students': True}),
('reset_student_attempts', {'problem_to_reset': self.problem_urlname, 'all_students': True}),
]

Expand All @@ -469,6 +469,8 @@ def _access_endpoint(self, endpoint, args, status_code, msg, content_type=MULTIP
status_code: expected HTTP status code response
msg: message to display if assertion fails.
"""
import pdb;
pdb.set_trace()
url = reverse(endpoint, kwargs={'course_id': str(self.course.id)})
# if endpoint in INSTRUCTOR_GET_ENDPOINTS:
# response = self.client.get(url, args)
Expand Down Expand Up @@ -498,13 +500,15 @@ def test_student_level(self):
"Student should not be allowed to access endpoint " + endpoint
)

for endpoint, args in self.instructor_level_endpoints:
self._access_endpoint(
endpoint,
args,
403,
"Student should not be allowed to access endpoint " + endpoint
)
from common.djangoapps.util.db import outer_atomic
with outer_atomic():
for endpoint, args in self.instructor_level_endpoints:
self._access_endpoint(
endpoint,
args,
403,
"Student should not be allowed to access endpoint " + endpoint
)

def _access_problem_responses_endpoint(self, endpoint, msg):
"""
Expand Down Expand Up @@ -570,13 +574,40 @@ def test_instructor_level(self):
"""
Ensure that an instructor member can access all endpoints.
"""


test_subject = '\u1234 test subject'
test_message = '\u6824 test message'

self.full_test_message = {
'send_to': '["myself", "staff"]',
'subject': test_subject,
'message': test_message,
}

org_email = '[email protected]'
org_template = 'fake_org_email_template'
CourseEmailTemplate.objects.create(name=org_template, plain_template='test')
self.site_configuration.site_values.update({
'course_email_from_addr': {self.course.id.org: org_email},
'course_email_template_name': {self.course.id.org: org_template}
})
self.site_configuration.save()

inst = InstructorFactory(course_key=self.course.id)
CourseEnrollment.enroll(inst, self.course.id)

CourseFinanceAdminRole(self.course.id).add_users(inst)
CourseDataResearcherRole(self.course.id).add_users(inst)
self.client.login(username=inst.username, password=self.TEST_PASSWORD)

# self.user.is_staff = True
# self.user.save()

UserPreference.objects.create(user=inst, key="preview-site-theme", value="test-theme")
UserPreference.objects.create(user=inst, key="pref-lang", value="en")
UserPreference.objects.create(user=self.user, key="preview-site-theme", value="test-theme")
UserPreference.objects.create(user=self.user, key="pref-lang", value="en")

for endpoint, args in self.staff_level_endpoints:
expected_status = 200

Expand All @@ -597,6 +628,8 @@ def test_instructor_level(self):
"Instructor should be allowed to access endpoint " + endpoint
)

import pdb;
pdb.set_trace()
for endpoint, args in self.instructor_level_endpoints:
expected_status = 200
self._access_endpoint(
Expand Down Expand Up @@ -2475,7 +2508,7 @@ def test_autoenroll_on_forum_role_add(self):


@ddt.ddt
class TestInstructorAPILevelsDataDump(SharedModuleStoreTestCase, LoginEnrollmentTestCase):
class TestInstructorAPILevelsDataDump(SiteMixin, SharedModuleStoreTestCase, LoginEnrollmentTestCase):
"""
Test endpoints that show data without side effects.
"""
Expand Down Expand Up @@ -2676,6 +2709,9 @@ def test_get_students_who_may_enroll(self):
status message when users request a CSV file of students who
may enroll in a course.
"""
site_email = self.site_configuration.site_values.get('course_email_from_addr')
site_template = self.site_configuration.site_values.get('course_email_template_name')
CourseEmailTemplate.objects.create(name=site_template)
self.instructor.is_staff = True
self.instructor.save()
UserPreference.objects.create(user=self.instructor, key="preview-site-theme", value="test-theme")
Expand Down
2 changes: 2 additions & 0 deletions openedx/core/djangoapps/user_api/models.py
Original file line number Diff line number Diff line change
Expand Up @@ -82,6 +82,8 @@ def get_value(cls, user, preference_key, default=None):
The user preference value, or default if one is not set.
"""
try:
import pdb;
pdb.set_trace()
user_preference = cls.objects.get(user=user, key=preference_key)
return user_preference.value
except cls.DoesNotExist:
Expand Down

0 comments on commit 0734ae9

Please sign in to comment.