0
0
Fork 0
mirror of https://github.com/yt-dlp/yt-dlp.git synced 2024-11-18 01:35:12 +00:00
yt-dlp/test/helper.py

73 lines
1.9 KiB
Python
Raw Normal View History

2013-10-06 03:47:17 +00:00
import errno
2013-06-26 22:09:05 +00:00
import io
import hashlib
2013-06-26 22:09:05 +00:00
import json
import os.path
import re
import types
2013-06-26 22:09:05 +00:00
2013-06-27 19:15:16 +00:00
import youtube_dl.extractor
from youtube_dl import YoutubeDL
2013-06-26 22:09:05 +00:00
def global_setup():
youtube_dl._setup_opener(timeout=10)
def get_params(override=None):
PARAMETERS_FILE = os.path.join(os.path.dirname(os.path.abspath(__file__)),
"parameters.json")
with io.open(PARAMETERS_FILE, encoding='utf-8') as pf:
parameters = json.load(pf)
if override:
parameters.update(override)
return parameters
2013-06-26 22:09:05 +00:00
2013-10-06 03:47:17 +00:00
def try_rm(filename):
""" Remove a file if it exists """
try:
os.remove(filename)
except OSError as ose:
if ose.errno != errno.ENOENT:
raise
2013-06-26 22:09:05 +00:00
class FakeYDL(YoutubeDL):
2013-10-17 22:46:35 +00:00
def __init__(self, override=None):
2013-06-26 22:09:05 +00:00
# Different instances of the downloader can't share the same dictionary
# some test set the "sublang" parameter, which would break the md5 checks.
2013-10-17 22:46:35 +00:00
params = get_params(override=override)
2013-10-06 03:47:17 +00:00
super(FakeYDL, self).__init__(params)
self.result = []
def to_screen(self, s, skip_eol=None):
2013-06-26 22:09:05 +00:00
print(s)
2013-10-06 03:47:17 +00:00
2013-06-26 22:09:05 +00:00
def trouble(self, s, tb=None):
raise Exception(s)
2013-10-06 03:47:17 +00:00
2013-06-26 22:09:05 +00:00
def download(self, x):
2013-06-27 19:15:16 +00:00
self.result.append(x)
2013-10-06 03:47:17 +00:00
def expect_warning(self, regex):
# Silence an expected warning matching a regex
old_report_warning = self.report_warning
def report_warning(self, message):
if re.match(regex, message): return
old_report_warning(message)
self.report_warning = types.MethodType(report_warning, self)
2013-06-27 19:15:16 +00:00
def get_testcases():
for ie in youtube_dl.extractor.gen_extractors():
t = getattr(ie, '_TEST', None)
if t:
t['name'] = type(ie).__name__[:-len('IE')]
yield t
for t in getattr(ie, '_TESTS', []):
t['name'] = type(ie).__name__[:-len('IE')]
yield t
md5 = lambda s: hashlib.md5(s.encode('utf-8')).hexdigest()