mirror of
				https://github.com/yt-dlp/yt-dlp.git
				synced 2025-10-30 22:25:19 +00:00 
			
		
		
		
	Extend #980 with --max-quality support
This commit is contained in:
		| @@ -34,10 +34,10 @@ def try_rm(filename): | |||||||
|  |  | ||||||
|  |  | ||||||
| class FakeYDL(YoutubeDL): | class FakeYDL(YoutubeDL): | ||||||
|     def __init__(self): |     def __init__(self, override=None): | ||||||
|         # Different instances of the downloader can't share the same dictionary |         # Different instances of the downloader can't share the same dictionary | ||||||
|         # some test set the "sublang" parameter, which would break the md5 checks. |         # 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) |         super(FakeYDL, self).__init__(params) | ||||||
|         self.result = [] |         self.result = [] | ||||||
|          |          | ||||||
|   | |||||||
| @@ -10,13 +10,17 @@ from test.helper import FakeYDL | |||||||
|  |  | ||||||
|  |  | ||||||
| class YDL(FakeYDL): | class YDL(FakeYDL): | ||||||
|     def __init__(self): |     def __init__(self, *args, **kwargs): | ||||||
|         super(YDL, self).__init__() |         super(YDL, self).__init__(*args, **kwargs) | ||||||
|         self.downloaded_info_dicts = [] |         self.downloaded_info_dicts = [] | ||||||
|  |         self.msgs = [] | ||||||
|  |  | ||||||
|     def process_info(self, info_dict): |     def process_info(self, info_dict): | ||||||
|         self.downloaded_info_dicts.append(info_dict) |         self.downloaded_info_dicts.append(info_dict) | ||||||
|  |  | ||||||
|  |     def to_screen(self, msg): | ||||||
|  |         self.msgs.append(msg) | ||||||
|  |  | ||||||
|  |  | ||||||
| class TestFormatSelection(unittest.TestCase): | class TestFormatSelection(unittest.TestCase): | ||||||
|     def test_prefer_free_formats(self): |     def test_prefer_free_formats(self): | ||||||
| @@ -56,5 +60,40 @@ class TestFormatSelection(unittest.TestCase): | |||||||
|         downloaded = ydl.downloaded_info_dicts[0] |         downloaded = ydl.downloaded_info_dicts[0] | ||||||
|         self.assertEqual(downloaded[u'ext'], u'flv') |         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__': | if __name__ == '__main__': | ||||||
|     unittest.main() |     unittest.main() | ||||||
|   | |||||||
| @@ -488,7 +488,9 @@ class YoutubeDL(object): | |||||||
|  |  | ||||||
|         format_limit = self.params.get('format_limit', None) |         format_limit = self.params.get('format_limit', None) | ||||||
|         if format_limit: |         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'): |         if self.params.get('prefer_free_formats'): | ||||||
|             def _free_formats_key(f): |             def _free_formats_key(f): | ||||||
|                 try: |                 try: | ||||||
|   | |||||||
| @@ -947,6 +947,15 @@ def shell_quote(args): | |||||||
|     return ' '.join(map(pipes.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): | def smuggle_url(url, data): | ||||||
|     """ Pass additional data in a URL for internal use. """ |     """ Pass additional data in a URL for internal use. """ | ||||||
|  |  | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 Philipp Hagemeister
					Philipp Hagemeister