[ceskatelevize] Fix video availability check and add geo unrestricted test
This commit is contained in:
parent
f00fc78674
commit
7d78f0cc48
@ -16,7 +16,8 @@ from ..utils import (
|
|||||||
class CeskaTelevizeIE(InfoExtractor):
|
class CeskaTelevizeIE(InfoExtractor):
|
||||||
_VALID_URL = r'https?://www\.ceskatelevize\.cz/(porady|ivysilani)/(.+/)?(?P<id>[^?#]+)'
|
_VALID_URL = r'https?://www\.ceskatelevize\.cz/(porady|ivysilani)/(.+/)?(?P<id>[^?#]+)'
|
||||||
|
|
||||||
_TESTS = [{
|
_TESTS = [
|
||||||
|
{
|
||||||
'url': 'http://www.ceskatelevize.cz/ivysilani/10532695142-prvni-republika/213512120230004-spanelska-chripka',
|
'url': 'http://www.ceskatelevize.cz/ivysilani/10532695142-prvni-republika/213512120230004-spanelska-chripka',
|
||||||
'info_dict': {
|
'info_dict': {
|
||||||
'id': '213512120230004',
|
'id': '213512120230004',
|
||||||
@ -28,7 +29,8 @@ class CeskaTelevizeIE(InfoExtractor):
|
|||||||
'skip_download': True, # requires rtmpdump
|
'skip_download': True, # requires rtmpdump
|
||||||
},
|
},
|
||||||
'skip': 'Works only from Czech Republic.',
|
'skip': 'Works only from Czech Republic.',
|
||||||
}, {
|
},
|
||||||
|
{
|
||||||
'url': 'http://www.ceskatelevize.cz/ivysilani/1030584952-tsatsiki-maminka-a-policajt',
|
'url': 'http://www.ceskatelevize.cz/ivysilani/1030584952-tsatsiki-maminka-a-policajt',
|
||||||
'info_dict': {
|
'info_dict': {
|
||||||
'id': '20138143440',
|
'id': '20138143440',
|
||||||
@ -40,7 +42,20 @@ class CeskaTelevizeIE(InfoExtractor):
|
|||||||
'skip_download': True, # requires rtmpdump
|
'skip_download': True, # requires rtmpdump
|
||||||
},
|
},
|
||||||
'skip': 'Works only from Czech Republic.',
|
'skip': 'Works only from Czech Republic.',
|
||||||
}]
|
},
|
||||||
|
{
|
||||||
|
'url': 'http://www.ceskatelevize.cz/ivysilani/10532695142-prvni-republika/bonus/14716-zpevacka-z-duparny-bobina',
|
||||||
|
'info_dict': {
|
||||||
|
'id': '14716',
|
||||||
|
'ext': 'flv',
|
||||||
|
'title': 'První republika: Zpěvačka z Dupárny Bobina',
|
||||||
|
'duration': 90,
|
||||||
|
},
|
||||||
|
'params': {
|
||||||
|
'skip_download': True, # requires rtmpdump
|
||||||
|
},
|
||||||
|
},
|
||||||
|
]
|
||||||
|
|
||||||
def _real_extract(self, url):
|
def _real_extract(self, url):
|
||||||
url = url.replace('/porady/', '/ivysilani/').replace('/video/', '')
|
url = url.replace('/porady/', '/ivysilani/').replace('/video/', '')
|
||||||
@ -50,9 +65,9 @@ class CeskaTelevizeIE(InfoExtractor):
|
|||||||
|
|
||||||
webpage = self._download_webpage(url, video_id)
|
webpage = self._download_webpage(url, video_id)
|
||||||
|
|
||||||
if '<p class="title">Chyba konfigurace prohlížeče.</p>' not in webpage:
|
NOT_AVAILABLE_STRING = 'This content is not available at your territory due to limited copyright.'
|
||||||
msg = self._html_search_regex(r'<p class="title">(.+?)</p>', webpage, 'error-message')
|
if '%s</p>' % NOT_AVAILABLE_STRING in webpage:
|
||||||
raise ExtractorError(msg.replace('<br />', ' '))
|
raise ExtractorError(NOT_AVAILABLE_STRING, expected=True)
|
||||||
|
|
||||||
typ = self._html_search_regex(r'getPlaylistUrl\(\[\{"type":"(.+?)","id":".+?"\}\],', webpage, 'type')
|
typ = self._html_search_regex(r'getPlaylistUrl\(\[\{"type":"(.+?)","id":".+?"\}\],', webpage, 'type')
|
||||||
episode_id = self._html_search_regex(r'getPlaylistUrl\(\[\{"type":".+?","id":"(.+?)"\}\],', webpage, 'episode_id')
|
episode_id = self._html_search_regex(r'getPlaylistUrl\(\[\{"type":".+?","id":"(.+?)"\}\],', webpage, 'episode_id')
|
||||||
|
Loading…
Reference in New Issue
Block a user