1
0
mirror of https://github.com/ytdl-org/youtube-dl.git synced 2025-01-07 18:18:49 +00:00

[vodpl] Make more robust and add another test (closes #12122)

This commit is contained in:
Sergey M․ 2017-02-15 00:52:31 +07:00
parent 22ce9ad2bd
commit 6092ccd058
No known key found for this signature in database
GPG Key ID: 2C393E0F18A9236D

View File

@ -2,35 +2,31 @@
from __future__ import unicode_literals from __future__ import unicode_literals
from .onet import OnetBaseIE from .onet import OnetBaseIE
from ..utils import clean_html
class VODPlIE(OnetBaseIE): class VODPlIE(OnetBaseIE):
_VALID_URL = r'https?://vod\.pl/(?:.*/)?(?P<id>[0-9a-zA-Z]+)' _VALID_URL = r'https?://vod\.pl/(?:[^/]+/)+(?P<id>[0-9a-zA-Z]+)'
_TEST = { _TESTS = [{
'url': 'https://vod.pl/filmy/chlopaki-nie-placza/3ep3jns', 'url': 'https://vod.pl/filmy/chlopaki-nie-placza/3ep3jns',
'md5': 'a7dc3b2f7faa2421aefb0ecaabf7ec74', 'md5': 'a7dc3b2f7faa2421aefb0ecaabf7ec74',
'info_dict': { 'info_dict': {
'id': '3ep3jns', 'id': '3ep3jns',
'ext': 'mp4', 'ext': 'mp4',
'title': 'Chłopaki nie płaczą', 'title': 'Chłopaki nie płaczą',
'description': 'Kuba Brenner aby pomóc swojemu nieśmiałemu przyjacielowi Oskarowi wynajmuje w agencji towarzyskiej dwie panie. Po upojnej nocy okazuje się, że chłopcy nie byli przygotowani finansowo. "Opiekun artystyczny" dziewczyn zabiera w ramach rekompensaty drogocenną rzeźbę należącą do wujka Oskara. Kłopoty chłopców zaczynają się, gdy Kuba udaje się do agencji aby wykupić figurkę i trafia w sam środek mafijnej transakcji... Idiotyczny przypadek sprawia, że w klubie dochodzi do strzelaniny podczas której Grucha i Bolec zostają ranni, ginie również walizka z pieniędzmi... Podejrzenie pada na Kubę.', 'description': 'md5:f5f03b84712e55f5ac9f0a3f94445224',
'timestamp': 1463415154, 'timestamp': 1463415154,
'duration': 5765, 'duration': 5765,
'upload_date': '20160516', 'upload_date': '20160516',
}, },
} }, {
'url': 'https://vod.pl/seriale/belfer-na-planie-praca-kamery-online/2c10heh',
'only_matching': True,
}]
def _real_extract(self, url): def _real_extract(self, url):
video_id = self._match_id(url) video_id = self._match_id(url)
webpage = self._download_webpage(url, video_id) webpage = self._download_webpage(url, video_id)
mvp_id = self._search_mvp_id(webpage) info_dict = self._extract_from_id(self._search_mvp_id(webpage), webpage)
info_dict['id'] = video_id
info_dict = self._extract_from_id(mvp_id, webpage)
info_dict.update({
'id': video_id,
'description': clean_html(info_dict['description']).strip().replace('\r', '\n')
})
return info_dict return info_dict