337e0c62f8
Closes #352
The approach in [1] is faulty as can be seen in the test cases
1. bff857a8af
57 lines
1.8 KiB
Python
57 lines
1.8 KiB
Python
#!/usr/bin/env python
|
|
|
|
from __future__ import unicode_literals
|
|
|
|
# Allow direct execution
|
|
import os
|
|
import sys
|
|
import unittest
|
|
sys.path.insert(0, os.path.dirname(os.path.dirname(os.path.abspath(__file__))))
|
|
|
|
from yt_dlp.postprocessor import (
|
|
FFmpegThumbnailsConvertorPP,
|
|
MetadataFromFieldPP,
|
|
MetadataFromTitlePP,
|
|
)
|
|
|
|
|
|
class TestMetadataFromField(unittest.TestCase):
|
|
def test_format_to_regex(self):
|
|
pp = MetadataFromFieldPP(None, ['title:%(title)s - %(artist)s'])
|
|
self.assertEqual(pp._data[0]['regex'], r'(?P<title>.+)\ \-\ (?P<artist>.+)')
|
|
|
|
def test_field_to_outtmpl(self):
|
|
pp = MetadataFromFieldPP(None, ['title:%(title)s : %(artist)s'])
|
|
self.assertEqual(pp._data[0]['tmpl'], '%(title)s')
|
|
|
|
def test_in_out_seperation(self):
|
|
pp = MetadataFromFieldPP(None, ['%(title)s \\: %(artist)s:%(title)s : %(artist)s'])
|
|
self.assertEqual(pp._data[0]['in'], '%(title)s : %(artist)s')
|
|
self.assertEqual(pp._data[0]['out'], '%(title)s : %(artist)s')
|
|
|
|
|
|
class TestMetadataFromTitle(unittest.TestCase):
|
|
def test_format_to_regex(self):
|
|
pp = MetadataFromTitlePP(None, '%(title)s - %(artist)s')
|
|
self.assertEqual(pp._titleregex, r'(?P<title>.+)\ \-\ (?P<artist>.+)')
|
|
|
|
|
|
class TestConvertThumbnail(unittest.TestCase):
|
|
def test_escaping(self):
|
|
pp = FFmpegThumbnailsConvertorPP()
|
|
if not pp.available:
|
|
print('Skipping: ffmpeg not found')
|
|
return
|
|
|
|
file = 'test/testdata/thumbnails/foo %d bar/foo_%d.{}'
|
|
tests = (('webp', 'png'), ('png', 'jpg'))
|
|
|
|
for inp, out in tests:
|
|
out_file = file.format(out)
|
|
if os.path.exists(out_file):
|
|
os.remove(out_file)
|
|
pp.convert_thumbnail(file.format(inp), out)
|
|
assert os.path.exists(out_file)
|
|
|
|
for _, out in tests:
|
|
os.remove(file.format(out))
|