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
dca05a60
Commit
dca05a60
authored
Mar 06, 2015
by
David Baumgold
Browse files
Options
Browse Files
Download
Plain Diff
Merge branch 'release'
parents
d1af8f35
84938839
Expand all
Hide whitespace changes
Inline
Side-by-side
Showing
18 changed files
with
169 additions
and
213 deletions
+169
-213
cms/djangoapps/contentstore/views/tests/test_videos.py
+14
-0
cms/djangoapps/contentstore/views/videos.py
+2
-2
common/test/acceptance/pages/lms/discussion.py
+2
-4
common/test/acceptance/tests/discussion/helpers.py
+1
-23
common/test/acceptance/tests/discussion/test_cohorts.py
+6
-3
common/test/acceptance/tests/discussion/test_discussion.py
+47
-21
lms/djangoapps/certificates/queue.py
+1
-1
lms/djangoapps/certificates/tests/test_queue.py
+36
-3
lms/djangoapps/django_comment_client/base/tests.py
+3
-3
lms/djangoapps/django_comment_client/base/views.py
+4
-4
lms/djangoapps/django_comment_client/forum/tests.py
+0
-0
lms/djangoapps/django_comment_client/forum/views.py
+17
-30
lms/djangoapps/django_comment_client/tests/test_utils.py
+0
-0
lms/djangoapps/django_comment_client/tests/utils.py
+10
-95
lms/djangoapps/django_comment_client/utils.py
+16
-21
lms/envs/common.py
+3
-0
lms/envs/test.py
+1
-0
lms/urls.py
+6
-3
No files found.
cms/djangoapps/contentstore/views/tests/test_videos.py
View file @
dca05a60
...
@@ -97,6 +97,20 @@ class VideoUploadTestMixin(object):
...
@@ -97,6 +97,20 @@ class VideoUploadTestMixin(object):
]
]
},
},
]
]
# Ensure every status string is tested
self
.
previous_uploads
+=
[
{
"edx_video_id"
:
"status_test_{}"
.
format
(
status
),
"client_video_id"
:
"status_test.mp4"
,
"duration"
:
3.14
,
"status"
:
status
,
"encoded_videos"
:
[],
}
for
status
in
(
StatusDisplayStrings
.
_STATUS_MAP
.
keys
()
+
# pylint:disable=protected-access
[
"non_existent_status"
]
)
]
for
profile
in
self
.
profiles
:
for
profile
in
self
.
profiles
:
create_profile
(
profile
)
create_profile
(
profile
)
for
video
in
self
.
previous_uploads
:
for
video
in
self
.
previous_uploads
:
...
...
cms/djangoapps/contentstore/views/videos.py
View file @
dca05a60
...
@@ -48,10 +48,10 @@ class StatusDisplayStrings(object):
...
@@ -48,10 +48,10 @@ class StatusDisplayStrings(object):
# Translators: This is the status for a video that the servers have successfully processed
# Translators: This is the status for a video that the servers have successfully processed
_COMPLETE
=
ugettext_noop
(
"Complete"
)
_COMPLETE
=
ugettext_noop
(
"Complete"
)
# Translators: This is the status for a video that the servers have failed to process
# Translators: This is the status for a video that the servers have failed to process
_FAILED
=
ugettext_noop
(
"Failed"
)
,
_FAILED
=
ugettext_noop
(
"Failed"
)
# Translators: This is the status for a video for which an invalid
# Translators: This is the status for a video for which an invalid
# processing token was provided in the course settings
# processing token was provided in the course settings
_INVALID_TOKEN
=
ugettext_noop
(
"Invalid Token"
)
,
_INVALID_TOKEN
=
ugettext_noop
(
"Invalid Token"
)
# Translators: This is the status for a video that is in an unknown state
# Translators: This is the status for a video that is in an unknown state
_UNKNOWN
=
ugettext_noop
(
"Unknown"
)
_UNKNOWN
=
ugettext_noop
(
"Unknown"
)
...
...
common/test/acceptance/pages/lms/discussion.py
View file @
dca05a60
...
@@ -311,15 +311,13 @@ class DiscussionSortPreferencePage(CoursePage):
...
@@ -311,15 +311,13 @@ class DiscussionSortPreferencePage(CoursePage):
class
DiscussionTabSingleThreadPage
(
CoursePage
):
class
DiscussionTabSingleThreadPage
(
CoursePage
):
def
__init__
(
self
,
browser
,
course_id
,
discussion_id
,
thread_id
):
def
__init__
(
self
,
browser
,
course_id
,
thread_id
):
super
(
DiscussionTabSingleThreadPage
,
self
)
.
__init__
(
browser
,
course_id
)
super
(
DiscussionTabSingleThreadPage
,
self
)
.
__init__
(
browser
,
course_id
)
self
.
thread_page
=
DiscussionThreadPage
(
self
.
thread_page
=
DiscussionThreadPage
(
browser
,
browser
,
"body.discussion .discussion-article[data-id='{thread_id}']"
.
format
(
thread_id
=
thread_id
)
"body.discussion .discussion-article[data-id='{thread_id}']"
.
format
(
thread_id
=
thread_id
)
)
)
self
.
url_path
=
"discussion/forum/{discussion_id}/threads/{thread_id}"
.
format
(
self
.
url_path
=
"discussion/forum/dummy/threads/"
+
thread_id
discussion_id
=
discussion_id
,
thread_id
=
thread_id
)
def
is_browser_on_page
(
self
):
def
is_browser_on_page
(
self
):
return
self
.
thread_page
.
is_browser_on_page
()
return
self
.
thread_page
.
is_browser_on_page
()
...
...
common/test/acceptance/tests/discussion/helpers.py
View file @
dca05a60
...
@@ -5,15 +5,12 @@ Helper functions and classes for discussion tests.
...
@@ -5,15 +5,12 @@ Helper functions and classes for discussion tests.
from
uuid
import
uuid4
from
uuid
import
uuid4
import
json
import
json
from
...fixtures
import
LMS_BASE_URL
from
...fixtures.course
import
CourseFixture
from
...fixtures.discussion
import
(
from
...fixtures.discussion
import
(
SingleThreadViewFixture
,
SingleThreadViewFixture
,
Thread
,
Thread
,
Response
,
Response
,
)
)
from
...pages.lms.discussion
import
DiscussionTabSingleThreadPage
from
...fixtures
import
LMS_BASE_URL
from
...tests.helpers
import
UniqueCourseTest
class
BaseDiscussionMixin
(
object
):
class
BaseDiscussionMixin
(
object
):
...
@@ -86,22 +83,3 @@ class CohortTestMixin(object):
...
@@ -86,22 +83,3 @@ class CohortTestMixin(object):
data
=
{
"users"
:
username
}
data
=
{
"users"
:
username
}
response
=
course_fixture
.
session
.
post
(
url
,
data
=
data
,
headers
=
course_fixture
.
headers
)
response
=
course_fixture
.
session
.
post
(
url
,
data
=
data
,
headers
=
course_fixture
.
headers
)
self
.
assertTrue
(
response
.
ok
,
"Failed to add user to cohort"
)
self
.
assertTrue
(
response
.
ok
,
"Failed to add user to cohort"
)
class
BaseDiscussionTestCase
(
UniqueCourseTest
):
def
setUp
(
self
):
super
(
BaseDiscussionTestCase
,
self
)
.
setUp
()
self
.
discussion_id
=
"test_discussion_{}"
.
format
(
uuid4
()
.
hex
)
self
.
course_fixture
=
CourseFixture
(
**
self
.
course_info
)
self
.
course_fixture
.
add_advanced_settings
(
{
'discussion_topics'
:
{
'value'
:
{
'Test Discussion Topic'
:
{
'id'
:
self
.
discussion_id
}}}}
)
self
.
course_fixture
.
install
()
def
create_single_thread_page
(
self
,
thread_id
):
"""
Sets up a `DiscussionTabSingleThreadPage` for a given
`thread_id`.
"""
return
DiscussionTabSingleThreadPage
(
self
.
browser
,
self
.
course_id
,
self
.
discussion_id
,
thread_id
)
common/test/acceptance/tests/discussion/test_cohorts.py
View file @
dca05a60
...
@@ -3,7 +3,7 @@ Tests related to the cohorting feature.
...
@@ -3,7 +3,7 @@ Tests related to the cohorting feature.
"""
"""
from
uuid
import
uuid4
from
uuid
import
uuid4
from
.helpers
import
BaseDiscussionMixin
,
BaseDiscussionTestCase
from
.helpers
import
BaseDiscussionMixin
from
.helpers
import
CohortTestMixin
from
.helpers
import
CohortTestMixin
from
..helpers
import
UniqueCourseTest
from
..helpers
import
UniqueCourseTest
from
...pages.lms.auto_auth
import
AutoAuthPage
from
...pages.lms.auto_auth
import
AutoAuthPage
...
@@ -57,17 +57,20 @@ class CohortedDiscussionTestMixin(BaseDiscussionMixin, CohortTestMixin):
...
@@ -57,17 +57,20 @@ class CohortedDiscussionTestMixin(BaseDiscussionMixin, CohortTestMixin):
self
.
assertEquals
(
self
.
thread_page
.
get_group_visibility_label
(),
"This post is visible to everyone."
)
self
.
assertEquals
(
self
.
thread_page
.
get_group_visibility_label
(),
"This post is visible to everyone."
)
class
DiscussionTabSingleThreadTest
(
BaseDiscussionTestCase
):
class
DiscussionTabSingleThreadTest
(
UniqueCourseTest
):
"""
"""
Tests for the discussion page displaying a single thread.
Tests for the discussion page displaying a single thread.
"""
"""
def
setUp
(
self
):
def
setUp
(
self
):
super
(
DiscussionTabSingleThreadTest
,
self
)
.
setUp
()
super
(
DiscussionTabSingleThreadTest
,
self
)
.
setUp
()
self
.
discussion_id
=
"test_discussion_{}"
.
format
(
uuid4
()
.
hex
)
# Create a course to register for
self
.
course_fixture
=
CourseFixture
(
**
self
.
course_info
)
.
install
()
self
.
setup_cohorts
()
self
.
setup_cohorts
()
AutoAuthPage
(
self
.
browser
,
course_id
=
self
.
course_id
)
.
visit
()
AutoAuthPage
(
self
.
browser
,
course_id
=
self
.
course_id
)
.
visit
()
def
setup_thread_page
(
self
,
thread_id
):
def
setup_thread_page
(
self
,
thread_id
):
self
.
thread_page
=
DiscussionTabSingleThreadPage
(
self
.
browser
,
self
.
course_id
,
self
.
discussion_id
,
thread_id
)
# pylint: disable=attribute-defined-outside-init
self
.
thread_page
=
DiscussionTabSingleThreadPage
(
self
.
browser
,
self
.
course_id
,
thread_id
)
# pylint: disable=attribute-defined-outside-init
self
.
thread_page
.
visit
()
self
.
thread_page
.
visit
()
# pylint: disable=unused-argument
# pylint: disable=unused-argument
...
...
common/test/acceptance/tests/discussion/test_discussion.py
View file @
dca05a60
This diff is collapsed.
Click to expand it.
lms/djangoapps/certificates/queue.py
View file @
dca05a60
...
@@ -416,7 +416,7 @@ class XQueueCertInterface(object):
...
@@ -416,7 +416,7 @@ class XQueueCertInterface(object):
error_reason
=
unicode
(
exc
)
error_reason
=
unicode
(
exc
)
)
)
def
_send_to_xqueue
(
self
,
contents
,
key
,
task_identifier
=
None
,
callback_url_path
=
'update_certificate'
):
def
_send_to_xqueue
(
self
,
contents
,
key
,
task_identifier
=
None
,
callback_url_path
=
'
/
update_certificate'
):
"""Create a new task on the XQueue.
"""Create a new task on the XQueue.
Arguments:
Arguments:
...
...
lms/djangoapps/certificates/tests/test_queue.py
View file @
dca05a60
...
@@ -2,12 +2,16 @@
...
@@ -2,12 +2,16 @@
"""Tests for the XQueue certificates interface. """
"""Tests for the XQueue certificates interface. """
from
contextlib
import
contextmanager
from
contextlib
import
contextmanager
import
json
import
json
from
mock
import
patch
from
mock
import
patch
,
Mock
from
django.test
import
TestCase
from
django.test
import
TestCase
from
django.test.utils
import
override_settings
from
django.test.utils
import
override_settings
from
opaque_keys.edx.locator
import
CourseLocator
from
opaque_keys.edx.locator
import
CourseLocator
from
xmodule.modulestore.tests.django_utils
import
ModuleStoreTestCase
from
student.tests.factories
import
UserFactory
,
CourseEnrollmentFactory
from
xmodule.modulestore.tests.factories
import
CourseFactory
# It is really unfortunate that we are using the XQueue client
# It is really unfortunate that we are using the XQueue client
# code from the capa library. In the future, we should move this
# code from the capa library. In the future, we should move this
...
@@ -21,7 +25,36 @@ from certificates.models import ExampleCertificateSet, ExampleCertificate
...
@@ -21,7 +25,36 @@ from certificates.models import ExampleCertificateSet, ExampleCertificate
@override_settings
(
CERT_QUEUE
=
'certificates'
)
@override_settings
(
CERT_QUEUE
=
'certificates'
)
class
XQueueCertInterfaceTest
(
TestCase
):
class
XQueueCertInterfaceAddCertificateTest
(
ModuleStoreTestCase
):
"""Test the "add to queue" operation of the XQueue interface. """
def
setUp
(
self
):
super
(
XQueueCertInterfaceAddCertificateTest
,
self
)
.
setUp
()
self
.
user
=
UserFactory
.
create
()
self
.
course
=
CourseFactory
.
create
()
self
.
enrollment
=
CourseEnrollmentFactory
(
user
=
self
.
user
,
course_id
=
self
.
course
.
id
,
is_active
=
True
,
mode
=
"honor"
,
)
self
.
xqueue
=
XQueueCertInterface
()
def
test_add_cert_callback_url
(
self
):
with
patch
(
'courseware.grades.grade'
,
Mock
(
return_value
=
{
'grade'
:
'Pass'
,
'percent'
:
0.75
})):
with
patch
.
object
(
XQueueInterface
,
'send_to_queue'
)
as
mock_send
:
mock_send
.
return_value
=
(
0
,
None
)
self
.
xqueue
.
add_cert
(
self
.
user
,
self
.
course
.
id
)
# Verify that the task was sent to the queue with the correct callback URL
self
.
assertTrue
(
mock_send
.
called
)
__
,
kwargs
=
mock_send
.
call_args_list
[
0
]
actual_header
=
json
.
loads
(
kwargs
[
'header'
])
self
.
assertIn
(
'https://edx.org/update_certificate?key='
,
actual_header
[
'lms_callback_url'
])
@override_settings
(
CERT_QUEUE
=
'certificates'
)
class
XQueueCertInterfaceExampleCertificateTest
(
TestCase
):
"""Tests for the XQueue interface for certificate generation. """
"""Tests for the XQueue interface for certificate generation. """
COURSE_KEY
=
CourseLocator
(
org
=
'test'
,
course
=
'test'
,
run
=
'test'
)
COURSE_KEY
=
CourseLocator
(
org
=
'test'
,
course
=
'test'
,
run
=
'test'
)
...
@@ -31,7 +64,7 @@ class XQueueCertInterfaceTest(TestCase):
...
@@ -31,7 +64,7 @@ class XQueueCertInterfaceTest(TestCase):
ERROR_MSG
=
'Kaboom!'
ERROR_MSG
=
'Kaboom!'
def
setUp
(
self
):
def
setUp
(
self
):
super
(
XQueueCertInterfaceTest
,
self
)
.
setUp
()
super
(
XQueueCertInterface
ExampleCertificate
Test
,
self
)
.
setUp
()
self
.
xqueue
=
XQueueCertInterface
()
self
.
xqueue
=
XQueueCertInterface
()
def
test_add_example_cert
(
self
):
def
test_add_example_cert
(
self
):
...
...
lms/djangoapps/django_comment_client/base/tests.py
View file @
dca05a60
...
@@ -14,7 +14,7 @@ from lms.lib.comment_client import Thread
...
@@ -14,7 +14,7 @@ from lms.lib.comment_client import Thread
from
xmodule.modulestore.tests.django_utils
import
TEST_DATA_MOCK_MODULESTORE
from
xmodule.modulestore.tests.django_utils
import
TEST_DATA_MOCK_MODULESTORE
from
django_comment_client.base
import
views
from
django_comment_client.base
import
views
from
django_comment_client.tests.group_id
import
CohortedTopicGroupIdTestMixin
,
NonCohortedTopicGroupIdTestMixin
,
GroupIdAssertionMixin
from
django_comment_client.tests.group_id
import
CohortedTopicGroupIdTestMixin
,
NonCohortedTopicGroupIdTestMixin
,
GroupIdAssertionMixin
from
django_comment_client.tests.utils
import
CohortedTestCase
from
django_comment_client.tests.utils
import
Cohorted
Content
TestCase
from
django_comment_client.tests.unicode
import
UnicodeTestMixin
from
django_comment_client.tests.unicode
import
UnicodeTestMixin
from
django_comment_common.models
import
Role
from
django_comment_common.models
import
Role
from
django_comment_common.utils
import
seed_permissions_roles
from
django_comment_common.utils
import
seed_permissions_roles
...
@@ -42,7 +42,7 @@ class MockRequestSetupMixin(object):
...
@@ -42,7 +42,7 @@ class MockRequestSetupMixin(object):
@patch
(
'lms.lib.comment_client.utils.requests.request'
)
@patch
(
'lms.lib.comment_client.utils.requests.request'
)
class
CreateThreadGroupIdTestCase
(
class
CreateThreadGroupIdTestCase
(
MockRequestSetupMixin
,
MockRequestSetupMixin
,
CohortedTestCase
,
Cohorted
Content
TestCase
,
CohortedTopicGroupIdTestMixin
,
CohortedTopicGroupIdTestMixin
,
NonCohortedTopicGroupIdTestMixin
NonCohortedTopicGroupIdTestMixin
):
):
...
@@ -77,7 +77,7 @@ class CreateThreadGroupIdTestCase(
...
@@ -77,7 +77,7 @@ class CreateThreadGroupIdTestCase(
@patch
(
'lms.lib.comment_client.utils.requests.request'
)
@patch
(
'lms.lib.comment_client.utils.requests.request'
)
class
ThreadActionGroupIdTestCase
(
class
ThreadActionGroupIdTestCase
(
MockRequestSetupMixin
,
MockRequestSetupMixin
,
CohortedTestCase
,
Cohorted
Content
TestCase
,
GroupIdAssertionMixin
GroupIdAssertionMixin
):
):
def
call_view
(
def
call_view
(
...
...
lms/djangoapps/django_comment_client/base/views.py
View file @
dca05a60
...
@@ -74,7 +74,7 @@ def track_forum_event(request, event_name, course, obj, data, id_map=None):
...
@@ -74,7 +74,7 @@ def track_forum_event(request, event_name, course, obj, data, id_map=None):
user
=
request
.
user
user
=
request
.
user
data
[
'id'
]
=
obj
.
id
data
[
'id'
]
=
obj
.
id
if
id_map
is
None
:
if
id_map
is
None
:
id_map
=
get_discussion_id_map
(
course
,
user
)
id_map
=
get_discussion_id_map
(
course
)
commentable_id
=
data
[
'commentable_id'
]
commentable_id
=
data
[
'commentable_id'
]
if
commentable_id
in
id_map
:
if
commentable_id
in
id_map
:
...
@@ -173,9 +173,9 @@ def create_thread(request, course_id, commentable_id):
...
@@ -173,9 +173,9 @@ def create_thread(request, course_id, commentable_id):
# Calls to id map are expensive, but we need this more than once.
# Calls to id map are expensive, but we need this more than once.
# Prefetch it.
# Prefetch it.
id_map
=
get_discussion_id_map
(
course
,
request
.
user
)
id_map
=
get_discussion_id_map
(
course
)
add_courseware_context
([
data
],
course
,
request
.
user
,
id_map
=
id_map
)
add_courseware_context
([
data
],
course
,
id_map
=
id_map
)
track_forum_event
(
request
,
'edx.forum.thread.created'
,
track_forum_event
(
request
,
'edx.forum.thread.created'
,
course
,
thread
,
event_data
,
id_map
=
id_map
)
course
,
thread
,
event_data
,
id_map
=
id_map
)
...
@@ -208,7 +208,7 @@ def update_thread(request, course_id, thread_id):
...
@@ -208,7 +208,7 @@ def update_thread(request, course_id, thread_id):
thread
.
thread_type
=
request
.
POST
[
"thread_type"
]
thread
.
thread_type
=
request
.
POST
[
"thread_type"
]
if
"commentable_id"
in
request
.
POST
:
if
"commentable_id"
in
request
.
POST
:
course
=
get_course_with_access
(
request
.
user
,
'load'
,
course_key
)
course
=
get_course_with_access
(
request
.
user
,
'load'
,
course_key
)
commentable_ids
=
get_discussion_categories_ids
(
course
,
request
.
user
)
commentable_ids
=
get_discussion_categories_ids
(
course
)
if
request
.
POST
.
get
(
"commentable_id"
)
in
commentable_ids
:
if
request
.
POST
.
get
(
"commentable_id"
)
in
commentable_ids
:
thread
.
commentable_id
=
request
.
POST
[
"commentable_id"
]
thread
.
commentable_id
=
request
.
POST
[
"commentable_id"
]
else
:
else
:
...
...
lms/djangoapps/django_comment_client/forum/tests.py
View file @
dca05a60
This diff is collapsed.
Click to expand it.
lms/djangoapps/django_comment_client/forum/views.py
View file @
dca05a60
...
@@ -52,7 +52,7 @@ def _attr_safe_json(obj):
...
@@ -52,7 +52,7 @@ def _attr_safe_json(obj):
@newrelic.agent.function_trace
()
@newrelic.agent.function_trace
()
def
make_course_settings
(
course
,
user
):
def
make_course_settings
(
course
):
"""
"""
Generate a JSON-serializable model for course settings, which will be used to initialize a
Generate a JSON-serializable model for course settings, which will be used to initialize a
DiscussionCourseSettings object on the client.
DiscussionCourseSettings object on the client.
...
@@ -63,14 +63,14 @@ def make_course_settings(course, user):
...
@@ -63,14 +63,14 @@ def make_course_settings(course, user):
'allow_anonymous'
:
course
.
allow_anonymous
,
'allow_anonymous'
:
course
.
allow_anonymous
,
'allow_anonymous_to_peers'
:
course
.
allow_anonymous_to_peers
,
'allow_anonymous_to_peers'
:
course
.
allow_anonymous_to_peers
,
'cohorts'
:
[{
"id"
:
str
(
g
.
id
),
"name"
:
g
.
name
}
for
g
in
get_course_cohorts
(
course
)],
'cohorts'
:
[{
"id"
:
str
(
g
.
id
),
"name"
:
g
.
name
}
for
g
in
get_course_cohorts
(
course
)],
'category_map'
:
utils
.
get_discussion_category_map
(
course
,
user
)
'category_map'
:
utils
.
get_discussion_category_map
(
course
)
}
}
return
obj
return
obj
@newrelic.agent.function_trace
()
@newrelic.agent.function_trace
()
def
get_threads
(
request
,
course
,
discussion_id
=
None
,
per_page
=
THREADS_PER_PAGE
):
def
get_threads
(
request
,
course
_key
,
discussion_id
=
None
,
per_page
=
THREADS_PER_PAGE
):
"""
"""
This may raise an appropriate subclass of cc.utils.CommentClientError
This may raise an appropriate subclass of cc.utils.CommentClientError
if something goes wrong, or ValueError if the group_id is invalid.
if something goes wrong, or ValueError if the group_id is invalid.
...
@@ -81,19 +81,12 @@ def get_threads(request, course, discussion_id=None, per_page=THREADS_PER_PAGE):
...
@@ -81,19 +81,12 @@ def get_threads(request, course, discussion_id=None, per_page=THREADS_PER_PAGE):
'sort_key'
:
'date'
,
'sort_key'
:
'date'
,
'sort_order'
:
'desc'
,
'sort_order'
:
'desc'
,
'text'
:
''
,
'text'
:
''
,
'course_id'
:
unicode
(
course
.
id
),
'commentable_id'
:
discussion_id
,
'course_id'
:
course_key
.
to_deprecated_string
(),
'user_id'
:
request
.
user
.
id
,
'user_id'
:
request
.
user
.
id
,
'group_id'
:
get_group_id_for_comments_service
(
request
,
course
.
id
,
discussion_id
),
# may raise ValueError
'group_id'
:
get_group_id_for_comments_service
(
request
,
course
_key
,
discussion_id
),
# may raise ValueError
}
}
if
discussion_id
is
not
None
:
default_query_params
[
'commentable_id'
]
=
discussion_id
else
:
default_query_params
[
'commentable_ids'
]
=
','
.
join
(
course
.
top_level_discussion_topic_ids
+
utils
.
get_discussion_id_map
(
course
,
request
.
user
)
.
keys
()
)
if
not
request
.
GET
.
get
(
'sort_key'
):
if
not
request
.
GET
.
get
(
'sort_key'
):
# If the user did not select a sort key, use their last used sort key
# If the user did not select a sort key, use their last used sort key
cc_user
=
cc
.
User
.
from_django_user
(
request
.
user
)
cc_user
=
cc
.
User
.
from_django_user
(
request
.
user
)
...
@@ -170,7 +163,7 @@ def inline_discussion(request, course_key, discussion_id):
...
@@ -170,7 +163,7 @@ def inline_discussion(request, course_key, discussion_id):
user_info
=
cc_user
.
to_dict
()
user_info
=
cc_user
.
to_dict
()
try
:
try
:
threads
,
query_params
=
get_threads
(
request
,
course
,
discussion_id
,
per_page
=
INLINE_THREADS_PER_PAGE
)
threads
,
query_params
=
get_threads
(
request
,
course
_key
,
discussion_id
,
per_page
=
INLINE_THREADS_PER_PAGE
)
except
ValueError
:
except
ValueError
:
return
HttpResponseBadRequest
(
"Invalid group_id"
)
return
HttpResponseBadRequest
(
"Invalid group_id"
)
...
@@ -179,7 +172,7 @@ def inline_discussion(request, course_key, discussion_id):
...
@@ -179,7 +172,7 @@ def inline_discussion(request, course_key, discussion_id):
is_staff
=
cached_has_permission
(
request
.
user
,
'openclose_thread'
,
course
.
id
)
is_staff
=
cached_has_permission
(
request
.
user
,
'openclose_thread'
,
course
.
id
)
threads
=
[
utils
.
prepare_content
(
thread
,
course_key
,
is_staff
)
for
thread
in
threads
]
threads
=
[
utils
.
prepare_content
(
thread
,
course_key
,
is_staff
)
for
thread
in
threads
]
with
newrelic
.
agent
.
FunctionTrace
(
nr_transaction
,
"add_courseware_context"
):
with
newrelic
.
agent
.
FunctionTrace
(
nr_transaction
,
"add_courseware_context"
):
add_courseware_context
(
threads
,
course
,
request
.
user
)
add_courseware_context
(
threads
,
course
)
return
utils
.
JsonResponse
({
return
utils
.
JsonResponse
({
'is_commentable_cohorted'
:
is_commentable_cohorted
(
course_key
,
discussion_id
),
'is_commentable_cohorted'
:
is_commentable_cohorted
(
course_key
,
discussion_id
),
'discussion_data'
:
threads
,
'discussion_data'
:
threads
,
...
@@ -188,7 +181,7 @@ def inline_discussion(request, course_key, discussion_id):
...
@@ -188,7 +181,7 @@ def inline_discussion(request, course_key, discussion_id):
'page'
:
query_params
[
'page'
],
'page'
:
query_params
[
'page'
],
'num_pages'
:
query_params
[
'num_pages'
],
'num_pages'
:
query_params
[
'num_pages'
],
'roles'
:
utils
.
get_role_ids
(
course_key
),
'roles'
:
utils
.
get_role_ids
(
course_key
),
'course_settings'
:
make_course_settings
(
course
,
request
.
user
)
'course_settings'
:
make_course_settings
(
course
)
})
})
...
@@ -201,13 +194,13 @@ def forum_form_discussion(request, course_key):
...
@@ -201,13 +194,13 @@ def forum_form_discussion(request, course_key):
nr_transaction
=
newrelic
.
agent
.
current_transaction
()
nr_transaction
=
newrelic
.
agent
.
current_transaction
()
course
=
get_course_with_access
(
request
.
user
,
'load_forum'
,
course_key
,
check_if_enrolled
=
True
)
course
=
get_course_with_access
(
request
.
user
,
'load_forum'
,
course_key
,
check_if_enrolled
=
True
)
course_settings
=
make_course_settings
(
course
,
request
.
user
)
course_settings
=
make_course_settings
(
course
)
user
=
cc
.
User
.
from_django_user
(
request
.
user
)
user
=
cc
.
User
.
from_django_user
(
request
.
user
)
user_info
=
user
.
to_dict
()
user_info
=
user
.
to_dict
()
try
:
try
:
unsafethreads
,
query_params
=
get_threads
(
request
,
course
)
# This might process a search query
unsafethreads
,
query_params
=
get_threads
(
request
,
course
_key
)
# This might process a search query
is_staff
=
cached_has_permission
(
request
.
user
,
'openclose_thread'
,
course
.
id
)
is_staff
=
cached_has_permission
(
request
.
user
,
'openclose_thread'
,
course
.
id
)
threads
=
[
utils
.
prepare_content
(
thread
,
course_key
,
is_staff
)
for
thread
in
unsafethreads
]
threads
=
[
utils
.
prepare_content
(
thread
,
course_key
,
is_staff
)
for
thread
in
unsafethreads
]
except
cc
.
utils
.
CommentClientMaintenanceError
:
except
cc
.
utils
.
CommentClientMaintenanceError
:
...
@@ -220,7 +213,7 @@ def forum_form_discussion(request, course_key):
...
@@ -220,7 +213,7 @@ def forum_form_discussion(request, course_key):
annotated_content_info
=
utils
.
get_metadata_for_threads
(
course_key
,
threads
,
request
.
user
,
user_info
)
annotated_content_info
=
utils
.
get_metadata_for_threads
(
course_key
,
threads
,
request
.
user
,
user_info
)
with
newrelic
.
agent
.
FunctionTrace
(
nr_transaction
,
"add_courseware_context"
):
with
newrelic
.
agent
.
FunctionTrace
(
nr_transaction
,
"add_courseware_context"
):
add_courseware_context
(
threads
,
course
,
request
.
user
)
add_courseware_context
(
threads
,
course
)
if
request
.
is_ajax
():
if
request
.
is_ajax
():
return
utils
.
JsonResponse
({
return
utils
.
JsonResponse
({
...
@@ -265,21 +258,15 @@ def single_thread(request, course_key, discussion_id, thread_id):
...
@@ -265,21 +258,15 @@ def single_thread(request, course_key, discussion_id, thread_id):
"""
"""
Renders a response to display a single discussion thread.
Renders a response to display a single discussion thread.
"""
"""
nr_transaction
=
newrelic
.
agent
.
current_transaction
()
nr_transaction
=
newrelic
.
agent
.
current_transaction
()
course
=
get_course_with_access
(
request
.
user
,
'load_forum'
,
course_key
)
course
=
get_course_with_access
(
request
.
user
,
'load_forum'
,
course_key
)
course_settings
=
make_course_settings
(
course
,
request
.
user
)
course_settings
=
make_course_settings
(
course
)
cc_user
=
cc
.
User
.
from_django_user
(
request
.
user
)
cc_user
=
cc
.
User
.
from_django_user
(
request
.
user
)
user_info
=
cc_user
.
to_dict
()
user_info
=
cc_user
.
to_dict
()
is_moderator
=
cached_has_permission
(
request
.
user
,
"see_all_cohorts"
,
course_key
)
is_moderator
=
cached_has_permission
(
request
.
user
,
"see_all_cohorts"
,
course_key
)
# Verify that the student has access to this thread if belongs to a discussion module
accessible_discussion_ids
=
[
module
.
discussion_id
for
module
in
utils
.
get_accessible_discussion_modules
(
course
,
request
.
user
)
]
if
discussion_id
not
in
set
(
course
.
top_level_discussion_topic_ids
+
accessible_discussion_ids
):
raise
Http404
# Currently, the front end always loads responses via AJAX, even for this
# Currently, the front end always loads responses via AJAX, even for this
# page; it would be a nice optimization to avoid that extra round trip to
# page; it would be a nice optimization to avoid that extra round trip to
# the comments service.
# the comments service.
...
@@ -307,7 +294,7 @@ def single_thread(request, course_key, discussion_id, thread_id):
...
@@ -307,7 +294,7 @@ def single_thread(request, course_key, discussion_id, thread_id):
annotated_content_info
=
utils
.
get_annotated_content_infos
(
course_key
,
thread
,
request
.
user
,
user_info
=
user_info
)
annotated_content_info
=
utils
.
get_annotated_content_infos
(
course_key
,
thread
,
request
.
user
,
user_info
=
user_info
)
content
=
utils
.
prepare_content
(
thread
.
to_dict
(),
course_key
,
is_staff
)
content
=
utils
.
prepare_content
(
thread
.
to_dict
(),
course_key
,
is_staff
)
with
newrelic
.
agent
.
FunctionTrace
(
nr_transaction
,
"add_courseware_context"
):
with
newrelic
.
agent
.
FunctionTrace
(
nr_transaction
,
"add_courseware_context"
):
add_courseware_context
([
content
],
course
,
request
.
user
)
add_courseware_context
([
content
],
course
)
return
utils
.
JsonResponse
({
return
utils
.
JsonResponse
({
'content'
:
content
,
'content'
:
content
,
'annotated_content_info'
:
annotated_content_info
,
'annotated_content_info'
:
annotated_content_info
,
...
@@ -315,13 +302,13 @@ def single_thread(request, course_key, discussion_id, thread_id):
...
@@ -315,13 +302,13 @@ def single_thread(request, course_key, discussion_id, thread_id):
else
:
else
:
try
:
try
:
threads
,
query_params
=
get_threads
(
request
,
course
)
threads
,
query_params
=
get_threads
(
request
,
course
_key
)
except
ValueError
:
except
ValueError
:
return
HttpResponseBadRequest
(
"Invalid group_id"
)
return
HttpResponseBadRequest
(
"Invalid group_id"
)
threads
.
append
(
thread
.
to_dict
())
threads
.
append
(
thread
.
to_dict
())
with
newrelic
.
agent
.
FunctionTrace
(
nr_transaction
,
"add_courseware_context"
):
with
newrelic
.
agent
.
FunctionTrace
(
nr_transaction
,
"add_courseware_context"
):
add_courseware_context
(
threads
,
course
,
request
.
user
)
add_courseware_context
(
threads
,
course
)
for
thread
in
threads
:
for
thread
in
threads
:
# patch for backward compatibility with comments service
# patch for backward compatibility with comments service
...
...
lms/djangoapps/django_comment_client/tests/test_utils.py
View file @
dca05a60
This diff is collapsed.
Click to expand it.
lms/djangoapps/django_comment_client/tests/utils.py
View file @
dca05a60
"""
Utilities for tests within the django_comment_client module.
"""
from
datetime
import
datetime
from
django.test.utils
import
override_settings
from
mock
import
patch
from
mock
import
patch
from
pytz
import
UTC
from
openedx.core.djangoapps.course_groups.models
import
CourseUserGroupPartitionGroup
from
openedx.core.djangoapps.course_groups.models
import
CourseUserGroup
from
openedx.core.djangoapps.course_groups.tests.helpers
import
CohortFactory
from
django_comment_common.models
import
Role
from
django_comment_common.models
import
Role
from
django_comment_common.utils
import
seed_permissions_roles
from
django_comment_common.utils
import
seed_permissions_roles
from
student.tests.factories
import
CourseEnrollmentFactory
,
UserFactory
from
student.tests.factories
import
CourseEnrollmentFactory
,
UserFactory
from
xmodule.modulestore.tests.factories
import
CourseFactory
,
ItemFactory
from
xmodule.modulestore.tests.factories
import
CourseFactory
from
xmodule.modulestore.tests.django_utils
import
ModuleStoreTestCase
from
xmodule.modulestore.tests.django_utils
import
ModuleStoreTestCase
from
xmodule.partitions.partitions
import
UserPartition
,
Group
class
CohortedTestCase
(
ModuleStoreTestCase
):
class
Cohorted
Content
TestCase
(
ModuleStoreTestCase
):
"""
"""
Sets up a course with a student, a moderator and their cohorts.
Sets up a course with a student, a moderator and their cohorts.
"""
"""
@patch.dict
(
"django.conf.settings.FEATURES"
,
{
"ENABLE_DISCUSSION_SERVICE"
:
True
})
@patch.dict
(
"django.conf.settings.FEATURES"
,
{
"ENABLE_DISCUSSION_SERVICE"
:
True
})
def
setUp
(
self
):
def
setUp
(
self
):
super
(
CohortedTestCase
,
self
)
.
setUp
()
super
(
Cohorted
Content
TestCase
,
self
)
.
setUp
()
self
.
course
=
CourseFactory
.
create
(
self
.
course
=
CourseFactory
.
create
(
discussion_topics
=
{
discussion_topics
=
{
...
@@ -34,13 +26,15 @@ class CohortedTestCase(ModuleStoreTestCase):
...
@@ -34,13 +26,15 @@ class CohortedTestCase(ModuleStoreTestCase):
"cohorted_discussions"
:
[
"cohorted_topic"
]
"cohorted_discussions"
:
[
"cohorted_topic"
]
}
}
)
)
self
.
student_cohort
=
Co
hortFactory
.
create
(
self
.
student_cohort
=
Co
urseUserGroup
.
objects
.
create
(
name
=
"student_cohort"
,
name
=
"student_cohort"
,
course_id
=
self
.
course
.
id
course_id
=
self
.
course
.
id
,
group_type
=
CourseUserGroup
.
COHORT
)
)
self
.
moderator_cohort
=
Co
hortFactory
.
create
(
self
.
moderator_cohort
=
Co
urseUserGroup
.
objects
.
create
(
name
=
"moderator_cohort"
,
name
=
"moderator_cohort"
,
course_id
=
self
.
course
.
id
course_id
=
self
.
course
.
id
,
group_type
=
CourseUserGroup
.
COHORT
)
)
seed_permissions_roles
(
self
.
course
.
id
)
seed_permissions_roles
(
self
.
course
.
id
)
...
@@ -51,82 +45,3 @@ class CohortedTestCase(ModuleStoreTestCase):
...
@@ -51,82 +45,3 @@ class CohortedTestCase(ModuleStoreTestCase):
self
.
moderator
.
roles
.
add
(
Role
.
objects
.
get
(
name
=
"Moderator"
,
course_id
=
self
.
course
.
id
))
self
.
moderator
.
roles
.
add
(
Role
.
objects
.
get
(
name
=
"Moderator"
,
course_id
=
self
.
course
.
id
))
self
.
student_cohort
.
users
.
add
(
self
.
student
)
self
.
student_cohort
.
users
.
add
(
self
.
student
)
self
.
moderator_cohort
.
users
.
add
(
self
.
moderator
)
self
.
moderator_cohort
.
users
.
add
(
self
.
moderator
)
class
ContentGroupTestCase
(
ModuleStoreTestCase
):
"""
Sets up discussion modules visible to content groups 'Alpha' and
'Beta', as well as a module visible to all students. Creates a
staff user, users with access to Alpha/Beta (by way of cohorts),
and a non-cohorted user with no special access.
"""
def
setUp
(
self
):
super
(
ContentGroupTestCase
,
self
)
.
setUp
()
self
.
course
=
CourseFactory
.
create
(
org
=
'org'
,
number
=
'number'
,
run
=
'run'
,
# This test needs to use a course that has already started --
# discussion topics only show up if the course has already started,
# and the default start date for courses is Jan 1, 2030.
start
=
datetime
(
2012
,
2
,
3
,
tzinfo
=
UTC
),
user_partitions
=
[
UserPartition
(
0
,
'Content Group Configuration'
,
''
,
[
Group
(
1
,
'Alpha'
),
Group
(
2
,
'Beta'
)],
scheme_id
=
'cohort'
)
],
cohort_config
=
{
'cohorted'
:
True
},
discussion_topics
=
{}
)
self
.
staff_user
=
UserFactory
.
create
(
is_staff
=
True
)
self
.
alpha_user
=
UserFactory
.
create
()
self
.
beta_user
=
UserFactory
.
create
()
self
.
non_cohorted_user
=
UserFactory
.
create
()
for
user
in
[
self
.
staff_user
,
self
.
alpha_user
,
self
.
beta_user
,
self
.
non_cohorted_user
]:
CourseEnrollmentFactory
.
create
(
user
=
user
,
course_id
=
self
.
course
.
id
)
alpha_cohort
=
CohortFactory
(
course_id
=
self
.
course
.
id
,
name
=
'Cohort Alpha'
,
users
=
[
self
.
alpha_user
]
)
beta_cohort
=
CohortFactory
(
course_id
=
self
.
course
.
id
,
name
=
'Cohort Beta'
,
users
=
[
self
.
beta_user
]
)
CourseUserGroupPartitionGroup
.
objects
.
create
(
course_user_group
=
alpha_cohort
,
partition_id
=
self
.
course
.
user_partitions
[
0
]
.
id
,
group_id
=
self
.
course
.
user_partitions
[
0
]
.
groups
[
0
]
.
id
)
CourseUserGroupPartitionGroup
.
objects
.
create
(
course_user_group
=
beta_cohort
,
partition_id
=
self
.
course
.
user_partitions
[
0
]
.
id
,
group_id
=
self
.
course
.
user_partitions
[
0
]
.
groups
[
1
]
.
id
)
self
.
alpha_module
=
ItemFactory
.
create
(
parent_location
=
self
.
course
.
location
,
category
=
'discussion'
,
discussion_id
=
'alpha_group_discussion'
,
discussion_target
=
'Visible to Alpha'
,
group_access
=
{
self
.
course
.
user_partitions
[
0
]
.
id
:
[
self
.
course
.
user_partitions
[
0
]
.
groups
[
0
]
.
id
]}
)
self
.
beta_module
=
ItemFactory
.
create
(
parent_location
=
self
.
course
.
location
,
category
=
'discussion'
,
discussion_id
=
'beta_group_discussion'
,
discussion_target
=
'Visible to Beta'
,
group_access
=
{
self
.
course
.
user_partitions
[
0
]
.
id
:
[
self
.
course
.
user_partitions
[
0
]
.
groups
[
1
]
.
id
]}
)
self
.
global_module
=
ItemFactory
.
create
(
parent_location
=
self
.
course
.
location
,
category
=
'discussion'
,
discussion_id
=
'global_group_discussion'
,
discussion_target
=
'Visible to Everyone'
)
self
.
course
=
self
.
store
.
get_item
(
self
.
course
.
location
)
lms/djangoapps/django_comment_client/utils.py
View file @
dca05a60
...
@@ -17,7 +17,7 @@ from xmodule.modulestore.django import modulestore
...
@@ -17,7 +17,7 @@ from xmodule.modulestore.django import modulestore
from
django_comment_common.models
import
Role
,
FORUM_ROLE_STUDENT
from
django_comment_common.models
import
Role
,
FORUM_ROLE_STUDENT
from
django_comment_client.permissions
import
check_permissions_by_view
,
cached_has_permission
from
django_comment_client.permissions
import
check_permissions_by_view
,
cached_has_permission
from
edxmako
import
lookup_template
from
edxmako
import
lookup_template
from
courseware.access
import
has_access
from
openedx.core.djangoapps.course_groups.cohorts
import
get_cohort_by_id
,
get_cohort_id
,
is_commentable_cohorted
,
\
from
openedx.core.djangoapps.course_groups.cohorts
import
get_cohort_by_id
,
get_cohort_id
,
is_commentable_cohorted
,
\
is_course_cohorted
is_course_cohorted
from
openedx.core.djangoapps.course_groups.models
import
CourseUserGroup
from
openedx.core.djangoapps.course_groups.models
import
CourseUserGroup
...
@@ -59,11 +59,9 @@ def has_forum_access(uname, course_id, rolename):
...
@@ -59,11 +59,9 @@ def has_forum_access(uname, course_id, rolename):
return
role
.
users
.
filter
(
username
=
uname
)
.
exists
()
return
role
.
users
.
filter
(
username
=
uname
)
.
exists
()
# pylint: disable=invalid-name
def
_get_discussion_modules
(
course
):
def
get_accessible_discussion_modules
(
course
,
user
):
"""
"""
Get all discussion modules within a course which are accessible to
Return a list of all valid discussion modules in this course.
the user.
"""
"""
all_modules
=
modulestore
()
.
get_items
(
course
.
id
,
qualifiers
=
{
'category'
:
'discussion'
})
all_modules
=
modulestore
()
.
get_items
(
course
.
id
,
qualifiers
=
{
'category'
:
'discussion'
})
...
@@ -74,23 +72,20 @@ def get_accessible_discussion_modules(course, user):
...
@@ -74,23 +72,20 @@ def get_accessible_discussion_modules(course, user):
return
False
return
False
return
True
return
True
return
[
return
filter
(
has_required_keys
,
all_modules
)
module
for
module
in
all_modules
if
has_required_keys
(
module
)
and
has_access
(
user
,
'load'
,
module
,
course
.
id
)
]
def
get_discussion_id_map
(
course
,
user
):
def
get_discussion_id_map
(
course
):
"""
"""
Get metadata about discussion modules visible to the user in a course
.
Transform the list of this course's discussion modules into a dictionary of metadata keyed by discussion_id
.
"""
"""
def
get_entry
(
module
):
def
get_entry
(
module
):
# pylint: disable=missing-docstring
discussion_id
=
module
.
discussion_id
discussion_id
=
module
.
discussion_id
title
=
module
.
discussion_target
title
=
module
.
discussion_target
last_category
=
module
.
discussion_category
.
split
(
"/"
)[
-
1
]
.
strip
()
last_category
=
module
.
discussion_category
.
split
(
"/"
)[
-
1
]
.
strip
()
return
(
discussion_id
,
{
"location"
:
module
.
location
,
"title"
:
last_category
+
" / "
+
title
})
return
(
discussion_id
,
{
"location"
:
module
.
location
,
"title"
:
last_category
+
" / "
+
title
})
return
dict
(
map
(
get_entry
,
get_accessible_discussion_modules
(
course
,
user
)))
return
dict
(
map
(
get_entry
,
_get_discussion_modules
(
course
)))
def
_filter_unstarted_categories
(
category_map
):
def
_filter_unstarted_categories
(
category_map
):
...
@@ -143,14 +138,14 @@ def _sort_map_entries(category_map, sort_alpha):
...
@@ -143,14 +138,14 @@ def _sort_map_entries(category_map, sort_alpha):
category_map
[
"children"
]
=
[
x
[
0
]
for
x
in
sorted
(
things
,
key
=
lambda
x
:
x
[
1
][
"sort_key"
])]
category_map
[
"children"
]
=
[
x
[
0
]
for
x
in
sorted
(
things
,
key
=
lambda
x
:
x
[
1
][
"sort_key"
])]
def
get_discussion_category_map
(
course
,
user
):
def
get_discussion_category_map
(
course
):
"""
"""
Get a mapping of categories and subcategories that are visible to
Transform the list of this course's discussion modules into a recursive dictionary structure. This is used
t
he user within a course
.
t
o render the discussion category map in the discussion tab sidebar
.
"""
"""
unexpanded_category_map
=
defaultdict
(
list
)
unexpanded_category_map
=
defaultdict
(
list
)
modules
=
get_accessible_discussion_modules
(
course
,
user
)
modules
=
_get_discussion_modules
(
course
)
is_course_cohorted
=
course
.
is_cohorted
is_course_cohorted
=
course
.
is_cohorted
cohorted_discussion_ids
=
course
.
cohorted_discussions
cohorted_discussion_ids
=
course
.
cohorted_discussions
...
@@ -223,12 +218,12 @@ def get_discussion_category_map(course, user):
...
@@ -223,12 +218,12 @@ def get_discussion_category_map(course, user):
return
_filter_unstarted_categories
(
category_map
)
return
_filter_unstarted_categories
(
category_map
)
def
get_discussion_categories_ids
(
course
,
user
):
def
get_discussion_categories_ids
(
course
):
"""
"""
Returns a list of available ids of categories for the course.
Returns a list of available ids of categories for the course.
"""
"""
ids
=
[]
ids
=
[]
queue
=
[
get_discussion_category_map
(
course
,
user
)]
queue
=
[
get_discussion_category_map
(
course
)]
while
queue
:
while
queue
:
category_map
=
queue
.
pop
()
category_map
=
queue
.
pop
()
for
child
in
category_map
[
"children"
]:
for
child
in
category_map
[
"children"
]:
...
@@ -387,12 +382,12 @@ def extend_content(content):
...
@@ -387,12 +382,12 @@ def extend_content(content):
return
merge_dict
(
content
,
content_info
)
return
merge_dict
(
content
,
content_info
)
def
add_courseware_context
(
content_list
,
course
,
user
,
id_map
=
None
):
def
add_courseware_context
(
content_list
,
course
,
id_map
=
None
):
"""
"""
Decorates `content_list` with courseware metadata.
Decorates `content_list` with courseware metadata.
"""
"""
if
id_map
is
None
:
if
id_map
is
None
:
id_map
=
get_discussion_id_map
(
course
,
user
)
id_map
=
get_discussion_id_map
(
course
)
for
content
in
content_list
:
for
content
in
content_list
:
commentable_id
=
content
[
'commentable_id'
]
commentable_id
=
content
[
'commentable_id'
]
...
...
lms/envs/common.py
View file @
dca05a60
...
@@ -303,6 +303,9 @@ FEATURES = {
...
@@ -303,6 +303,9 @@ FEATURES = {
# Set to True to change the course sorting behavior by their start dates, latest first.
# Set to True to change the course sorting behavior by their start dates, latest first.
'ENABLE_COURSE_SORTING_BY_START_DATE'
:
False
,
'ENABLE_COURSE_SORTING_BY_START_DATE'
:
False
,
# Flag to enable new user account APIs.
'ENABLE_USER_REST_API'
:
False
,
# Expose Mobile REST API. Note that if you use this, you must also set
# Expose Mobile REST API. Note that if you use this, you must also set
# ENABLE_OAUTH2_PROVIDER to True
# ENABLE_OAUTH2_PROVIDER to True
'ENABLE_MOBILE_REST_API'
:
False
,
'ENABLE_MOBILE_REST_API'
:
False
,
...
...
lms/envs/test.py
View file @
dca05a60
...
@@ -265,6 +265,7 @@ FEATURES['ENABLE_OAUTH2_PROVIDER'] = True
...
@@ -265,6 +265,7 @@ FEATURES['ENABLE_OAUTH2_PROVIDER'] = True
FEATURES
[
'ENABLE_MOBILE_REST_API'
]
=
True
FEATURES
[
'ENABLE_MOBILE_REST_API'
]
=
True
FEATURES
[
'ENABLE_MOBILE_SOCIAL_FACEBOOK_FEATURES'
]
=
True
FEATURES
[
'ENABLE_MOBILE_SOCIAL_FACEBOOK_FEATURES'
]
=
True
FEATURES
[
'ENABLE_VIDEO_ABSTRACTION_LAYER_API'
]
=
True
FEATURES
[
'ENABLE_VIDEO_ABSTRACTION_LAYER_API'
]
=
True
FEATURES
[
'ENABLE_USER_REST_API'
]
=
True
###################### Payment ##############################3
###################### Payment ##############################3
# Enable fake payment processing page
# Enable fake payment processing page
...
...
lms/urls.py
View file @
dca05a60
...
@@ -60,10 +60,8 @@ urlpatterns = (
...
@@ -60,10 +60,8 @@ urlpatterns = (
url
(
r'^heartbeat$'
,
include
(
'heartbeat.urls'
)),
url
(
r'^heartbeat$'
,
include
(
'heartbeat.urls'
)),
url
(
r'^api/user/'
,
include
(
'openedx.core.djangoapps.user_api.urls'
)),
# Note: these are older versions of the User API that will eventually be
# Note: these are older versions of the User API that will eventually be
# subsumed by api/user.
# subsumed by api/user
listed below
.
url
(
r'^user_api/'
,
include
(
'openedx.core.djangoapps.user_api.legacy_urls'
)),
url
(
r'^user_api/'
,
include
(
'openedx.core.djangoapps.user_api.legacy_urls'
)),
url
(
r'^notifier_api/'
,
include
(
'notifier_api.urls'
)),
url
(
r'^notifier_api/'
,
include
(
'notifier_api.urls'
)),
...
@@ -88,6 +86,11 @@ urlpatterns = (
...
@@ -88,6 +86,11 @@ urlpatterns = (
url
(
r'^api/course_structure/'
,
include
(
'course_structure_api.urls'
,
namespace
=
'course_structure_api'
)),
url
(
r'^api/course_structure/'
,
include
(
'course_structure_api.urls'
,
namespace
=
'course_structure_api'
)),
)
)
if
settings
.
FEATURES
[
"ENABLE_USER_REST_API"
]:
urlpatterns
+=
(
url
(
r'^api/user/'
,
include
(
'openedx.core.djangoapps.user_api.urls'
)),
)
if
settings
.
FEATURES
[
"ENABLE_COMBINED_LOGIN_REGISTRATION"
]:
if
settings
.
FEATURES
[
"ENABLE_COMBINED_LOGIN_REGISTRATION"
]:
# Backwards compatibility with old URL structure, but serve the new views
# Backwards compatibility with old URL structure, but serve the new views
urlpatterns
+=
(
urlpatterns
+=
(
...
...
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