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
caf5d539
Commit
caf5d539
authored
Nov 17, 2014
by
Nimisha Asthagiri
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
MA-141 Support webm encoding for VAL-enabled videos
parent
673d4fbc
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
42 additions
and
27 deletions
+42
-27
common/lib/xmodule/xmodule/video_module/video_module.py
+15
-9
lms/djangoapps/courseware/tests/test_video_mongo.py
+27
-18
No files found.
common/lib/xmodule/xmodule/video_module/video_module.py
View file @
caf5d539
...
@@ -184,20 +184,26 @@ class VideoModule(VideoFields, VideoTranscriptsMixin, VideoStudentViewHandlers,
...
@@ -184,20 +184,26 @@ class VideoModule(VideoFields, VideoTranscriptsMixin, VideoStudentViewHandlers,
# stream.
# stream.
if
self
.
edx_video_id
and
edxval_api
:
if
self
.
edx_video_id
and
edxval_api
:
try
:
try
:
val_
video_urls
=
edxval_api
.
get_urls_for_profiles
(
val_
profiles
=
[
"youtube"
,
"desktop_webm"
,
"desktop_mp4"
]
self
.
edx_video_id
,
[
"desktop_mp4"
,
"youtube"
]
val_video_urls
=
edxval_api
.
get_urls_for_profiles
(
self
.
edx_video_id
,
val_profiles
)
)
# VAL will always give us the keys for the profiles we asked for, but
# VAL will always give us the keys for the profiles we asked for, but
# if it doesn't have an encoded video entry for that Video + Profile, the
# if it doesn't have an encoded video entry for that Video + Profile, the
# value will map to `None`
# value will map to `None`
if
val_video_urls
[
"desktop_mp4"
]:
if
self
.
download_video
:
# add the non-youtube urls to the list of alternative sources
download_video_link
=
val_video_urls
[
"desktop_mp4"
]
# use the last non-None non-youtube url as the link to download the video
# add the desktop_mp4 profile to the list of alternative sources
for
url
in
[
val_video_urls
[
p
]
for
p
in
val_profiles
if
p
!=
"youtube"
]:
if
val_video_urls
[
"desktop_mp4"
]
not
in
sources
:
if
url
:
sources
.
append
(
val_video_urls
[
"desktop_mp4"
])
if
url
not
in
sources
:
sources
.
append
(
url
)
if
self
.
download_video
:
download_video_link
=
url
# set the youtube url
if
val_video_urls
[
"youtube"
]:
if
val_video_urls
[
"youtube"
]:
youtube_streams
=
"1.00:{}"
.
format
(
val_video_urls
[
"youtube"
])
youtube_streams
=
"1.00:{}"
.
format
(
val_video_urls
[
"youtube"
])
except
edxval_api
.
ValInternalError
:
except
edxval_api
.
ValInternalError
:
# VAL raises this exception if it can't find data for the edx video ID. This can happen if the
# VAL raises this exception if it can't find data for the edx video ID. This can happen if the
# course data is ported to a machine that does not have the VAL data. So for now, pass on this
# course data is ported to a machine that does not have the VAL data. So for now, pass on this
...
...
lms/djangoapps/courseware/tests/test_video_mongo.py
View file @
caf5d539
...
@@ -512,28 +512,33 @@ class TestGetHtmlMethod(BaseTestXmodule):
...
@@ -512,28 +512,33 @@ class TestGetHtmlMethod(BaseTestXmodule):
)
)
def
test_get_html_with_existing_edx_video_id
(
self
):
def
test_get_html_with_existing_edx_video_id
(
self
):
result
=
create_profile
(
# create test profiles and their encodings
dict
(
encoded_videos
=
[]
profile_name
=
"desktop_mp4"
,
for
profile
,
extension
in
[(
"desktop_webm"
,
"webm"
),
(
"desktop_mp4"
,
"mp4"
)]:
extension
=
"mp4"
,
result
=
create_profile
(
width
=
200
,
dict
(
height
=
2001
profile_name
=
profile
,
extension
=
extension
,
width
=
200
,
height
=
2001
)
)
)
)
self
.
assertEqual
(
result
,
profile
)
self
.
assertEqual
(
result
,
"desktop_mp4"
)
encoded_videos
.
append
(
dict
(
url
=
u"http://fake-video.edx.org/thundercats.{}"
.
format
(
extension
),
file_size
=
9000
,
bitrate
=
42
,
profile
=
profile
,
)
)
result
=
create_video
(
result
=
create_video
(
dict
(
dict
(
client_video_id
=
"Thunder Cats"
,
client_video_id
=
"Thunder Cats"
,
duration
=
111
,
duration
=
111
,
edx_video_id
=
"thundercats"
,
edx_video_id
=
"thundercats"
,
encoded_videos
=
[
encoded_videos
=
encoded_videos
dict
(
url
=
u"http://fake-video.edx.org/thundercats.mp4"
,
file_size
=
9000
,
bitrate
=
42
,
profile
=
"desktop_mp4"
,
)
]
)
)
)
)
self
.
assertEqual
(
result
,
"thundercats"
)
self
.
assertEqual
(
result
,
"thundercats"
)
...
@@ -549,6 +554,7 @@ class TestGetHtmlMethod(BaseTestXmodule):
...
@@ -549,6 +554,7 @@ class TestGetHtmlMethod(BaseTestXmodule):
{sources}
{sources}
</video>
</video>
"""
"""
data
=
{
data
=
{
'download_video'
:
'true'
,
'download_video'
:
'true'
,
'source'
:
'example_source.mp4'
,
'source'
:
'example_source.mp4'
,
...
@@ -559,8 +565,11 @@ class TestGetHtmlMethod(BaseTestXmodule):
...
@@ -559,8 +565,11 @@ class TestGetHtmlMethod(BaseTestXmodule):
'edx_video_id'
:
"thundercats"
,
'edx_video_id'
:
"thundercats"
,
'result'
:
{
'result'
:
{
'download_video_link'
:
u'http://fake-video.edx.org/thundercats.mp4'
,
'download_video_link'
:
u'http://fake-video.edx.org/thundercats.mp4'
,
# make sure the desktop_mp4 url is included as part of the alternative sources.
# make sure the urls for the various encodings are included as part of the alternative sources.
'sources'
:
json
.
dumps
([
u'example.mp4'
,
u'example.webm'
,
u"http://fake-video.edx.org/thundercats.mp4"
]),
'sources'
:
json
.
dumps
(
[
u'example.mp4'
,
u'example.webm'
]
+
[
video
[
'url'
]
for
video
in
encoded_videos
]
),
}
}
}
}
...
...
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