Browse Source

[YoutubeDL] Fix typo in string negation implementation and add more tests (closes #18961)

Sergey M․ 6 years ago
parent
commit
e118a8794f
2 changed files with 28 additions and 4 deletions
  1. 27 3
      test/test_YoutubeDL.py
  2. 1 1
      youtube_dl/YoutubeDL.py

+ 27 - 3
test/test_YoutubeDL.py

@@ -242,6 +242,7 @@ class TestFormatSelection(unittest.TestCase):
     def test_format_selection_string_ops(self):
     def test_format_selection_string_ops(self):
         formats = [
         formats = [
             {'format_id': 'abc-cba', 'ext': 'mp4', 'url': TEST_URL},
             {'format_id': 'abc-cba', 'ext': 'mp4', 'url': TEST_URL},
+            {'format_id': 'zxc-cxz', 'ext': 'webm', 'url': TEST_URL},
         ]
         ]
         info_dict = _make_result(formats)
         info_dict = _make_result(formats)
 
 
@@ -253,6 +254,11 @@ class TestFormatSelection(unittest.TestCase):
 
 
         # does not equal (!=)
         # does not equal (!=)
         ydl = YDL({'format': '[format_id!=abc-cba]'})
         ydl = YDL({'format': '[format_id!=abc-cba]'})
+        ydl.process_ie_result(info_dict.copy())
+        downloaded = ydl.downloaded_info_dicts[0]
+        self.assertEqual(downloaded['format_id'], 'zxc-cxz')
+
+        ydl = YDL({'format': '[format_id!=abc-cba][format_id!=zxc-cxz]'})
         self.assertRaises(ExtractorError, ydl.process_ie_result, info_dict.copy())
         self.assertRaises(ExtractorError, ydl.process_ie_result, info_dict.copy())
 
 
         # starts with (^=)
         # starts with (^=)
@@ -262,7 +268,12 @@ class TestFormatSelection(unittest.TestCase):
         self.assertEqual(downloaded['format_id'], 'abc-cba')
         self.assertEqual(downloaded['format_id'], 'abc-cba')
 
 
         # does not start with (!^=)
         # does not start with (!^=)
-        ydl = YDL({'format': '[format_id!^=abc-cba]'})
+        ydl = YDL({'format': '[format_id!^=abc]'})
+        ydl.process_ie_result(info_dict.copy())
+        downloaded = ydl.downloaded_info_dicts[0]
+        self.assertEqual(downloaded['format_id'], 'zxc-cxz')
+
+        ydl = YDL({'format': '[format_id!^=abc][format_id!^=zxc]'})
         self.assertRaises(ExtractorError, ydl.process_ie_result, info_dict.copy())
         self.assertRaises(ExtractorError, ydl.process_ie_result, info_dict.copy())
 
 
         # ends with ($=)
         # ends with ($=)
@@ -272,16 +283,29 @@ class TestFormatSelection(unittest.TestCase):
         self.assertEqual(downloaded['format_id'], 'abc-cba')
         self.assertEqual(downloaded['format_id'], 'abc-cba')
 
 
         # does not end with (!$=)
         # does not end with (!$=)
-        ydl = YDL({'format': '[format_id!$=abc-cba]'})
+        ydl = YDL({'format': '[format_id!$=cba]'})
+        ydl.process_ie_result(info_dict.copy())
+        downloaded = ydl.downloaded_info_dicts[0]
+        self.assertEqual(downloaded['format_id'], 'zxc-cxz')
+
+        ydl = YDL({'format': '[format_id!$=cba][format_id!$=cxz]'})
         self.assertRaises(ExtractorError, ydl.process_ie_result, info_dict.copy())
         self.assertRaises(ExtractorError, ydl.process_ie_result, info_dict.copy())
 
 
         # contains (*=)
         # contains (*=)
-        ydl = YDL({'format': '[format_id*=-]'})
+        ydl = YDL({'format': '[format_id*=bc-cb]'})
         ydl.process_ie_result(info_dict.copy())
         ydl.process_ie_result(info_dict.copy())
         downloaded = ydl.downloaded_info_dicts[0]
         downloaded = ydl.downloaded_info_dicts[0]
         self.assertEqual(downloaded['format_id'], 'abc-cba')
         self.assertEqual(downloaded['format_id'], 'abc-cba')
 
 
         # does not contain (!*=)
         # does not contain (!*=)
+        ydl = YDL({'format': '[format_id!*=bc-cb]'})
+        ydl.process_ie_result(info_dict.copy())
+        downloaded = ydl.downloaded_info_dicts[0]
+        self.assertEqual(downloaded['format_id'], 'zxc-cxz')
+
+        ydl = YDL({'format': '[format_id!*=abc][format_id!*=zxc]'})
+        self.assertRaises(ExtractorError, ydl.process_ie_result, info_dict.copy())
+
         ydl = YDL({'format': '[format_id!*=-]'})
         ydl = YDL({'format': '[format_id!*=-]'})
         self.assertRaises(ExtractorError, ydl.process_ie_result, info_dict.copy())
         self.assertRaises(ExtractorError, ydl.process_ie_result, info_dict.copy())
 
 

+ 1 - 1
youtube_dl/YoutubeDL.py

@@ -1078,7 +1078,7 @@ class YoutubeDL(object):
                 comparison_value = m.group('value')
                 comparison_value = m.group('value')
                 str_op = STR_OPERATORS[m.group('op')]
                 str_op = STR_OPERATORS[m.group('op')]
                 if m.group('negation'):
                 if m.group('negation'):
-                    op = lambda attr, value: not str_op
+                    op = lambda attr, value: not str_op(attr, value)
                 else:
                 else:
                     op = str_op
                     op = str_op