Commit 6f3e73f9 by muhammadarslan

Fix external video imports into an existing course

parent 74cd7fc3
......@@ -57,6 +57,7 @@ class VideoImageAdmin(admin.ModelAdmin):
class CourseVideoAdmin(admin.ModelAdmin):
list_display = ('course_id', 'get_video_id', 'is_hidden')
search_fields = ('id', 'course_id', 'video__status', 'video__edx_video_id')
def get_video_id(self, obj):
return obj.video.edx_video_id
......
......@@ -3,13 +3,11 @@
"""
The internal API for VAL.
"""
import os
import logging
from enum import Enum
from uuid import uuid4
from django.core.exceptions import ObjectDoesNotExist, ValidationError
from django.core.files import File
from django.core.files.base import ContentFile
from fs import open_fs
from fs.errors import ResourceNotFound
......@@ -36,6 +34,7 @@ from edxval.models import (
Video,
VideoImage,
VideoTranscript,
EXTERNAL_VIDEO_STATUS,
ThirdPartyTranscriptCredentialsState,
)
from edxval.serializers import TranscriptPreferenceSerializer, TranscriptSerializer, VideoSerializer
......@@ -122,7 +121,7 @@ def create_external_video(display_name):
"""
return create_video({
'edx_video_id': generate_video_id(),
'status': 'external',
'status': EXTERNAL_VIDEO_STATUS,
'client_video_id': display_name,
'duration': 0,
'encoded_videos': [],
......@@ -982,7 +981,11 @@ def import_from_xml(xml, edx_video_id, resource_fs, static_dir, external_transcr
edx_video_id,
course_id,
)
if course_id:
# We don't want to link an existing video to course if its an external video.
# External videos do not have any playback profiles associated, these are just to track video
# transcripts for those video components who do not use edx hosted videos for playback.
if course_id and video.status != EXTERNAL_VIDEO_STATUS:
course_video, __ = CourseVideo.get_or_create_with_validation(video=video, course_id=course_id)
image_file_name = xml.get('image', '').strip()
......
......@@ -33,6 +33,7 @@ logger = logging.getLogger(__name__) # pylint: disable=C0103
URL_REGEX = r'^[a-zA-Z0-9\-_]*$'
LIST_MAX_ITEMS = 3
EXTERNAL_VIDEO_STATUS = 'external'
class ModelFactoryWithValidation(object):
......
......@@ -7,7 +7,8 @@ from edxval.models import (
TranscriptProviderType,
Cielo24Fidelity,
Cielo24Turnaround,
ThreePlayTurnaround
ThreePlayTurnaround,
EXTERNAL_VIDEO_STATUS
)
from edxval.utils import TranscriptFormat
......@@ -136,6 +137,12 @@ VIDEO_DICT_DIFFERENT_ID_FISH = dict(
edx_video_id="medium-soaker",
status="test",
)
EXTERNAL_VIDEO_DICT_FISH = dict(
client_video_id="External Video",
duration=0.0,
edx_video_id="external-video",
status=EXTERNAL_VIDEO_STATUS,
)
ENCODED_VIDEO_DICT_FISH_MOBILE = dict(
url="https://www.swordsingers.com",
file_size=9000,
......
......@@ -1431,6 +1431,26 @@ class ImportTest(TestCase):
xml = self.make_import_xml(video_dict=constants.VIDEO_DICT_FISH)
self.assert_invalid_import(xml, "x" * 300)
def test_external_video_not_imported(self):
"""
Verify that external videos are not imported into a course.
"""
# Setup an external Video.
Video.objects.create(**constants.EXTERNAL_VIDEO_DICT_FISH)
xml = self.make_import_xml(video_dict=constants.EXTERNAL_VIDEO_DICT_FISH)
api.import_from_xml(
xml,
constants.EXTERNAL_VIDEO_DICT_FISH['edx_video_id'],
self.file_system,
constants.EXPORT_IMPORT_STATIC_DIR,
course_id='test_course_id'
)
# Assert that the existing video is not imported into the course.
self.assertFalse(CourseVideo.objects.filter(
course_id='test_course_id',
video__edx_video_id=constants.EXTERNAL_VIDEO_DICT_FISH['edx_video_id']
).exists())
def test_external_no_video_transcript(self):
"""
Verify that transcript import for external video working as expected when there is no transcript.
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment