diff options
Diffstat (limited to 'test')
| -rw-r--r-- | test/helper.py | 3 | ||||
| -rw-r--r-- | test/test_InfoExtractor.py | 10 | ||||
| -rw-r--r-- | test/test_utils.py | 8 | ||||
| -rw-r--r-- | test/test_youtube_lists.py | 2 | 
4 files changed, 22 insertions, 1 deletions
diff --git a/test/helper.py b/test/helper.py index f2d878212..b8e22c5cb 100644 --- a/test/helper.py +++ b/test/helper.py @@ -143,6 +143,9 @@ def expect_value(self, got, expected, field):              expect_value(self, item_got, item_expected, field)      else:          if isinstance(expected, compat_str) and expected.startswith('md5:'): +            self.assertTrue( +                isinstance(got, compat_str), +                'Expected field %s to be a unicode object, but got value %r of type %r' % (field, got, type(got)))              got = 'md5:' + md5(got)          elif isinstance(expected, compat_str) and expected.startswith('mincount:'):              self.assertTrue( diff --git a/test/test_InfoExtractor.py b/test/test_InfoExtractor.py index 938466a80..6404ac89f 100644 --- a/test/test_InfoExtractor.py +++ b/test/test_InfoExtractor.py @@ -11,6 +11,7 @@ sys.path.insert(0, os.path.dirname(os.path.dirname(os.path.abspath(__file__))))  from test.helper import FakeYDL  from youtube_dl.extractor.common import InfoExtractor  from youtube_dl.extractor import YoutubeIE, get_info_extractor +from youtube_dl.utils import encode_data_uri, strip_jsonp, ExtractorError  class TestIE(InfoExtractor): @@ -66,5 +67,14 @@ class TestInfoExtractor(unittest.TestCase):          self.assertEqual(ie._html_search_meta('e', html), '5')          self.assertEqual(ie._html_search_meta('f', html), '6') +    def test_download_json(self): +        uri = encode_data_uri(b'{"foo": "blah"}', 'application/json') +        self.assertEqual(self.ie._download_json(uri, None), {'foo': 'blah'}) +        uri = encode_data_uri(b'callback({"foo": "blah"})', 'application/javascript') +        self.assertEqual(self.ie._download_json(uri, None, transform_source=strip_jsonp), {'foo': 'blah'}) +        uri = encode_data_uri(b'{"foo": invalid}', 'application/json') +        self.assertRaises(ExtractorError, self.ie._download_json, uri, None) +        self.assertEqual(self.ie._download_json(uri, None, fatal=False), None) +  if __name__ == '__main__':      unittest.main() diff --git a/test/test_utils.py b/test/test_utils.py index e0323a5c6..e16a6761b 100644 --- a/test/test_utils.py +++ b/test/test_utils.py @@ -20,6 +20,7 @@ from youtube_dl.utils import (      args_to_str,      encode_base_n,      clean_html, +    date_from_str,      DateRange,      detect_exe_version,      determine_ext, @@ -234,6 +235,13 @@ class TestUtil(unittest.TestCase):          self.assertEqual(unescapeHTML('é'), 'é')          self.assertEqual(unescapeHTML('�'), '�') +    def test_date_from_str(self): +        self.assertEqual(date_from_str('yesterday'), date_from_str('now-1day')) +        self.assertEqual(date_from_str('now+7day'), date_from_str('now+1week')) +        self.assertEqual(date_from_str('now+14day'), date_from_str('now+2week')) +        self.assertEqual(date_from_str('now+365day'), date_from_str('now+1year')) +        self.assertEqual(date_from_str('now+30day'), date_from_str('now+1month')) +      def test_daterange(self):          _20century = DateRange("19000101", "20000101")          self.assertFalse("17890714" in _20century) diff --git a/test/test_youtube_lists.py b/test/test_youtube_lists.py index 47df0f348..af1c45421 100644 --- a/test/test_youtube_lists.py +++ b/test/test_youtube_lists.py @@ -44,7 +44,7 @@ class TestYoutubeLists(unittest.TestCase):          ie = YoutubePlaylistIE(dl)          result = ie.extract('https://www.youtube.com/watch?v=W01L70IGBgE&index=2&list=RDOQpdSVF_k_w')          entries = result['entries'] -        self.assertTrue(len(entries) >= 20) +        self.assertTrue(len(entries) >= 50)          original_video = entries[0]          self.assertEqual(original_video['id'], 'OQpdSVF_k_w')  | 
