Extend #980 with --max-quality support
authorPhilipp Hagemeister <phihag@phihag.de>
Thu, 17 Oct 2013 22:46:35 +0000 (00:46 +0200)
committerPhilipp Hagemeister <phihag@phihag.de>
Thu, 17 Oct 2013 22:46:35 +0000 (00:46 +0200)
test/helper.py
test/test_YoutubeDL.py
youtube_dl/YoutubeDL.py
youtube_dl/utils.py

index 79a0ede48989a4124d9992bc49e1b5ebbb7e6921..777119ea5fa6fe7b43ae5efe53e9c7685be347b8 100644 (file)
@@ -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 = []
         
index ee210ed238ad8344bda5c24d512d23ad7be7613b..ba6dc05bc3c5549783d7e93c3226484da2f0602a 100644 (file)
@@ -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()
index f22a8bd0e044b9c10ecad56187a15a310a4c1d7d..fd98321f17b814557c0a77ecdc79fc1dd12f495e 100644 (file)
@@ -488,7 +488,9 @@ class YoutubeDL(object):
 
         format_limit = self.params.get('format_limit', None)
         if format_limit:
-            formats = [f for f in formats if f['format_id'] <= format_limit]
+            formats = list(takewhile_inclusive(
+                lambda f: f['format_id'] != format_limit, formats
+            ))
         if self.params.get('prefer_free_formats'):
             def _free_formats_key(f):
                 try:
index 833f981f24ca7b9dc2b2fd6cd79a40fe83afd019..bfb8f6bcd971dad03d5236c8e607b59ff81c667a 100644 (file)
@@ -947,6 +947,15 @@ def shell_quote(args):
     return ' '.join(map(pipes.quote, args))
 
 
+def takewhile_inclusive(pred, seq):
+    """ Like itertools.takewhile, but include the latest evaluated element
+        (the first element so that Not pred(e)) """
+    for e in seq:
+        yield e
+        if not pred(e):
+            return
+
+
 def smuggle_url(url, data):
     """ Pass additional data in a URL for internal use. """