aboutsummaryrefslogtreecommitdiffstats
path: root/test
diff options
context:
space:
mode:
authorPhilipp Hagemeister <phihag@phihag.de>2013-10-18 00:46:35 +0200
committerPhilipp Hagemeister <phihag@phihag.de>2013-10-18 00:46:35 +0200
commitf4d96df0f1e978d580197fafb8dacade4b611ef3 (patch)
tree71652f6406597fbcb975bb0a6d69bd2d0ac4633e /test
parent5d254f776a4d306961b6d22d8f7615844ef64390 (diff)
downloadyoutube-dl-f4d96df0f1e978d580197fafb8dacade4b611ef3.zip
youtube-dl-f4d96df0f1e978d580197fafb8dacade4b611ef3.tar.gz
youtube-dl-f4d96df0f1e978d580197fafb8dacade4b611ef3.tar.bz2
Extend #980 with --max-quality support
Diffstat (limited to 'test')
-rw-r--r--test/helper.py4
-rw-r--r--test/test_YoutubeDL.py43
2 files changed, 43 insertions, 4 deletions
diff --git a/test/helper.py b/test/helper.py
index 79a0ede..777119e 100644
--- a/test/helper.py
+++ b/test/helper.py
@@ -34,10 +34,10 @@ def try_rm(filename):
class FakeYDL(YoutubeDL):
- def __init__(self):
+ def __init__(self, override=None):
# Different instances of the downloader can't share the same dictionary
# some test set the "sublang" parameter, which would break the md5 checks.
- params = get_params()
+ params = get_params(override=override)
super(FakeYDL, self).__init__(params)
self.result = []
diff --git a/test/test_YoutubeDL.py b/test/test_YoutubeDL.py
index ee210ed..ba6dc05 100644
--- a/test/test_YoutubeDL.py
+++ b/test/test_YoutubeDL.py
@@ -10,13 +10,17 @@ from test.helper import FakeYDL
class YDL(FakeYDL):
- def __init__(self):
- super(YDL, self).__init__()
+ def __init__(self, *args, **kwargs):
+ super(YDL, self).__init__(*args, **kwargs)
self.downloaded_info_dicts = []
+ self.msgs = []
def process_info(self, info_dict):
self.downloaded_info_dicts.append(info_dict)
+ def to_screen(self, msg):
+ self.msgs.append(msg)
+
class TestFormatSelection(unittest.TestCase):
def test_prefer_free_formats(self):
@@ -56,5 +60,40 @@ class TestFormatSelection(unittest.TestCase):
downloaded = ydl.downloaded_info_dicts[0]
self.assertEqual(downloaded[u'ext'], u'flv')
+ def test_format_limit(self):
+ formats = [
+ {u'format_id': u'meh'},
+ {u'format_id': u'good'},
+ {u'format_id': u'great'},
+ {u'format_id': u'excellent'},
+ ]
+ info_dict = {
+ u'formats': formats, u'extractor': u'test', 'id': 'testvid'}
+
+ ydl = YDL()
+ ydl.process_ie_result(info_dict)
+ downloaded = ydl.downloaded_info_dicts[0]
+ self.assertEqual(downloaded[u'format_id'], u'excellent')
+
+ ydl = YDL({'format_limit': 'good'})
+ assert ydl.params['format_limit'] == 'good'
+ ydl.process_ie_result(info_dict)
+ downloaded = ydl.downloaded_info_dicts[0]
+ self.assertEqual(downloaded[u'format_id'], u'good')
+
+ ydl = YDL({'format_limit': 'great', 'format': 'all'})
+ ydl.process_ie_result(info_dict)
+ self.assertEqual(ydl.downloaded_info_dicts[0][u'format_id'], u'meh')
+ self.assertEqual(ydl.downloaded_info_dicts[1][u'format_id'], u'good')
+ self.assertEqual(ydl.downloaded_info_dicts[2][u'format_id'], u'great')
+ self.assertTrue('3' in ydl.msgs[0])
+
+ ydl = YDL()
+ ydl.params['format_limit'] = 'excellent'
+ ydl.process_ie_result(info_dict)
+ downloaded = ydl.downloaded_info_dicts[0]
+ self.assertEqual(downloaded[u'format_id'], u'excellent')
+
+
if __name__ == '__main__':
unittest.main()