Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
E
edx-platform
Overview
Overview
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
edx
edx-platform
Commits
a6f697cc
Commit
a6f697cc
authored
Jun 20, 2013
by
Felix Sun
Browse files
Options
Browse Files
Download
Plain Diff
Merge pull request #222 from edx/felix/prefsscopefix3
Fixed the preferences scope of xblock.
parents
501830c9
c00721bb
Hide whitespace changes
Inline
Side-by-side
Showing
5 changed files
with
11 additions
and
3 deletions
+11
-3
AUTHORS
+1
-0
CHANGELOG.rst
+2
-0
lms/djangoapps/courseware/model_data.py
+1
-1
lms/djangoapps/courseware/tests/factories.py
+1
-1
lms/djangoapps/courseware/tests/test_model_data.py
+6
-1
No files found.
AUTHORS
View file @
a6f697cc
...
@@ -77,3 +77,4 @@ Slater Victoroff <slater.r.victoroff@gmail.com>
...
@@ -77,3 +77,4 @@ Slater Victoroff <slater.r.victoroff@gmail.com>
Peter Fogg <peter.p.fogg@gmail.com>
Peter Fogg <peter.p.fogg@gmail.com>
Bethany LaPenta <lapentab@mit.edu>
Bethany LaPenta <lapentab@mit.edu>
Renzo Lucioni <renzolucioni@gmail.com>
Renzo Lucioni <renzolucioni@gmail.com>
Felix Sun <felixsun@mit.edu>
CHANGELOG.rst
View file @
a6f697cc
...
@@ -27,6 +27,8 @@ students' number of attempts to zero. Provides a list of background
...
@@ -27,6 +27,8 @@ students' number of attempts to zero. Provides a list of background
tasks that are currently running for the course, and an option to
tasks that are currently running for the course, and an option to
see a history of background tasks for a given problem.
see a history of background tasks for a given problem.
LMS: Fixed the preferences scope for storing data in xmodules.
LMS: Forums. Added handling for case where discussion module can get `None` as
LMS: Forums. Added handling for case where discussion module can get `None` as
value of lms.start in `lms/djangoapps/django_comment_client/utils.py`
value of lms.start in `lms/djangoapps/django_comment_client/utils.py`
...
...
lms/djangoapps/courseware/model_data.py
View file @
a6f697cc
...
@@ -163,7 +163,7 @@ class ModelDataCache(object):
...
@@ -163,7 +163,7 @@ class ModelDataCache(object):
return
self
.
_chunked_query
(
return
self
.
_chunked_query
(
XModuleStudentPrefsField
,
XModuleStudentPrefsField
,
'module_type__in'
,
'module_type__in'
,
set
(
descriptor
.
location
.
category
for
descriptor
in
self
.
descriptors
),
set
(
descriptor
.
module_class
.
__name__
for
descriptor
in
self
.
descriptors
),
student
=
self
.
user
.
pk
,
student
=
self
.
user
.
pk
,
field_name__in
=
set
(
field
.
name
for
field
in
fields
),
field_name__in
=
set
(
field
.
name
for
field
in
fields
),
)
)
...
...
lms/djangoapps/courseware/tests/factories.py
View file @
a6f697cc
...
@@ -75,7 +75,7 @@ class StudentPrefsFactory(DjangoModelFactory):
...
@@ -75,7 +75,7 @@ class StudentPrefsFactory(DjangoModelFactory):
field_name
=
'existing_field'
field_name
=
'existing_field'
value
=
json
.
dumps
(
'old_value'
)
value
=
json
.
dumps
(
'old_value'
)
student
=
SubFactory
(
UserFactory
)
student
=
SubFactory
(
UserFactory
)
module_type
=
'
problem
'
module_type
=
'
MockProblemModule
'
class
StudentInfoFactory
(
DjangoModelFactory
):
class
StudentInfoFactory
(
DjangoModelFactory
):
...
...
lms/djangoapps/courseware/tests/test_model_data.py
View file @
a6f697cc
...
@@ -29,6 +29,7 @@ def mock_descriptor(fields=[], lms_fields=[]):
...
@@ -29,6 +29,7 @@ def mock_descriptor(fields=[], lms_fields=[]):
descriptor
.
location
=
location
(
'def_id'
)
descriptor
.
location
=
location
(
'def_id'
)
descriptor
.
module_class
.
fields
=
fields
descriptor
.
module_class
.
fields
=
fields
descriptor
.
module_class
.
lms
.
fields
=
lms_fields
descriptor
.
module_class
.
lms
.
fields
=
lms_fields
descriptor
.
module_class
.
__name__
=
'MockProblemModule'
return
descriptor
return
descriptor
location
=
partial
(
Location
,
'i4x'
,
'edX'
,
'test_course'
,
'problem'
)
location
=
partial
(
Location
,
'i4x'
,
'edX'
,
'test_course'
,
'problem'
)
...
@@ -37,7 +38,7 @@ course_id = 'edX/test_course/test'
...
@@ -37,7 +38,7 @@ course_id = 'edX/test_course/test'
content_key
=
partial
(
LmsKeyValueStore
.
Key
,
Scope
.
content
,
None
,
location
(
'def_id'
))
content_key
=
partial
(
LmsKeyValueStore
.
Key
,
Scope
.
content
,
None
,
location
(
'def_id'
))
settings_key
=
partial
(
LmsKeyValueStore
.
Key
,
Scope
.
settings
,
None
,
location
(
'def_id'
))
settings_key
=
partial
(
LmsKeyValueStore
.
Key
,
Scope
.
settings
,
None
,
location
(
'def_id'
))
user_state_key
=
partial
(
LmsKeyValueStore
.
Key
,
Scope
.
user_state
,
'user'
,
location
(
'def_id'
))
user_state_key
=
partial
(
LmsKeyValueStore
.
Key
,
Scope
.
user_state
,
'user'
,
location
(
'def_id'
))
prefs_key
=
partial
(
LmsKeyValueStore
.
Key
,
Scope
.
preferences
,
'user'
,
'
problem
'
)
prefs_key
=
partial
(
LmsKeyValueStore
.
Key
,
Scope
.
preferences
,
'user'
,
'
MockProblemModule
'
)
user_info_key
=
partial
(
LmsKeyValueStore
.
Key
,
Scope
.
user_info
,
'user'
,
None
)
user_info_key
=
partial
(
LmsKeyValueStore
.
Key
,
Scope
.
user_info
,
'user'
,
None
)
...
@@ -190,6 +191,10 @@ class StorageTestBase(object):
...
@@ -190,6 +191,10 @@ class StorageTestBase(object):
self
.
mdc
=
ModelDataCache
([
mock_descriptor
([
mock_field
(
self
.
scope
,
'existing_field'
)])],
course_id
,
self
.
user
)
self
.
mdc
=
ModelDataCache
([
mock_descriptor
([
mock_field
(
self
.
scope
,
'existing_field'
)])],
course_id
,
self
.
user
)
self
.
kvs
=
LmsKeyValueStore
(
self
.
desc_md
,
self
.
mdc
)
self
.
kvs
=
LmsKeyValueStore
(
self
.
desc_md
,
self
.
mdc
)
def
test_set_and_get_existing_field
(
self
):
self
.
kvs
.
set
(
self
.
key_factory
(
'existing_field'
),
'test_value'
)
self
.
assertEquals
(
'test_value'
,
self
.
kvs
.
get
(
self
.
key_factory
(
'existing_field'
)))
def
test_get_existing_field
(
self
):
def
test_get_existing_field
(
self
):
"Test that getting an existing field in an existing Storage Field works"
"Test that getting an existing field in an existing Storage Field works"
self
.
assertEquals
(
'old_value'
,
self
.
kvs
.
get
(
self
.
key_factory
(
'existing_field'
)))
self
.
assertEquals
(
'old_value'
,
self
.
kvs
.
get
(
self
.
key_factory
(
'existing_field'
)))
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment