Make course ids and usage ids opaque to LMS and Studio [partial commit]
This commit updates common/djangoapps. These keys are now objects with a limited interface, and the particular internal representation is managed by the data storage layer (the modulestore). For the LMS, there should be no outward-facing changes to the system. The keys are, for now, a change to internal representation only. For Studio, the new serialized form of the keys is used in urls, to allow for further migration in the future. Co-Author: Andy Armstrong <andya@edx.org> Co-Author: Christina Roberts <christina@edx.org> Co-Author: David Baumgold <db@edx.org> Co-Author: Diana Huang <dkh@edx.org> Co-Author: Don Mitchell <dmitchell@edx.org> Co-Author: Julia Hansbrough <julia@edx.org> Co-Author: Nimisha Asthagiri <nasthagiri@edx.org> Co-Author: Sarina Canelake <sarina@edx.org> [LMS-2370]
This commit is contained in:
@@ -22,8 +22,8 @@ class EmbargoCourseFormTest(ModuleStoreTestCase):
|
||||
|
||||
def setUp(self):
|
||||
self.course = CourseFactory.create()
|
||||
self.true_form_data = {'course_id': self.course.id, 'embargoed': True}
|
||||
self.false_form_data = {'course_id': self.course.id, 'embargoed': False}
|
||||
self.true_form_data = {'course_id': self.course.id.to_deprecated_string(), 'embargoed': True}
|
||||
self.false_form_data = {'course_id': self.course.id.to_deprecated_string(), 'embargoed': False}
|
||||
|
||||
def test_embargo_course(self):
|
||||
self.assertFalse(EmbargoedCourse.is_embargoed(self.course.id))
|
||||
@@ -62,7 +62,7 @@ class EmbargoCourseFormTest(ModuleStoreTestCase):
|
||||
|
||||
def test_form_typo(self):
|
||||
# Munge course id
|
||||
bad_id = self.course.id + '_typo'
|
||||
bad_id = self.course.id.to_deprecated_string() + '_typo'
|
||||
|
||||
form_data = {'course_id': bad_id, 'embargoed': True}
|
||||
form = EmbargoedCourseForm(data=form_data)
|
||||
@@ -79,7 +79,7 @@ class EmbargoCourseFormTest(ModuleStoreTestCase):
|
||||
|
||||
def test_invalid_location(self):
|
||||
# Munge course id
|
||||
bad_id = self.course.id.split('/')[-1]
|
||||
bad_id = self.course.id.to_deprecated_string().split('/')[-1]
|
||||
|
||||
form_data = {'course_id': bad_id, 'embargoed': True}
|
||||
form = EmbargoedCourseForm(data=form_data)
|
||||
|
||||
@@ -32,8 +32,8 @@ class EmbargoMiddlewareTests(TestCase):
|
||||
self.embargo_course.save()
|
||||
self.regular_course = CourseFactory.create(org="Regular")
|
||||
self.regular_course.save()
|
||||
self.embargoed_page = '/courses/' + self.embargo_course.id + '/info'
|
||||
self.regular_page = '/courses/' + self.regular_course.id + '/info'
|
||||
self.embargoed_page = '/courses/' + self.embargo_course.id.to_deprecated_string() + '/info'
|
||||
self.regular_page = '/courses/' + self.regular_course.id.to_deprecated_string() + '/info'
|
||||
EmbargoedCourse(course_id=self.embargo_course.id, embargoed=True).save()
|
||||
EmbargoedState(
|
||||
embargoed_countries="cu, ir, Sy, SD",
|
||||
|
||||
@@ -1,13 +1,14 @@
|
||||
"""Test of models for embargo middleware app"""
|
||||
from django.test import TestCase
|
||||
|
||||
from xmodule.modulestore.locations import SlashSeparatedCourseKey
|
||||
from embargo.models import EmbargoedCourse, EmbargoedState, IPFilter
|
||||
|
||||
|
||||
class EmbargoModelsTest(TestCase):
|
||||
"""Test each of the 3 models in embargo.models"""
|
||||
def test_course_embargo(self):
|
||||
course_id = 'abc/123/doremi'
|
||||
course_id = SlashSeparatedCourseKey('abc', '123', 'doremi')
|
||||
# Test that course is not authorized by default
|
||||
self.assertFalse(EmbargoedCourse.is_embargoed(course_id))
|
||||
|
||||
|
||||
Reference in New Issue
Block a user