You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

55 lines
1.7 KiB

  1. #!/usr/bin/env python
  2. import os
  3. import socket
  4. import sys
  5. import unittest
  6. # Allow direct execution
  7. sys.path.append(os.path.dirname(os.path.dirname(os.path.abspath(__file__))))
  8. import youtube_dl.FileDownloader
  9. import youtube_dl.InfoExtractors
  10. from youtube_dl.utils import *
  11. PARAMETERS_FILE = os.path.join(os.path.dirname(os.path.abspath(__file__)), "parameters.json")
  12. # General configuration (from __init__, not very elegant...)
  13. jar = compat_cookiejar.CookieJar()
  14. cookie_processor = compat_urllib_request.HTTPCookieProcessor(jar)
  15. proxy_handler = compat_urllib_request.ProxyHandler()
  16. opener = compat_urllib_request.build_opener(proxy_handler, cookie_processor, YoutubeDLHandler())
  17. compat_urllib_request.install_opener(opener)
  18. socket.setdefaulttimeout(300) # 5 minutes should be enough (famous last words)
  19. class FileDownloader(youtube_dl.FileDownloader):
  20. def __init__(self, *args, **kwargs):
  21. youtube_dl.FileDownloader.__init__(self, *args, **kwargs)
  22. self.to_stderr = self.to_screen
  23. with io.open(PARAMETERS_FILE, encoding='utf-8') as pf:
  24. params = json.load(pf)
  25. params['writeinfojson'] = True
  26. params['skip_download'] = True
  27. TEST_ID = 'BaW_jenozKc'
  28. INFO_JSON_FILE = TEST_ID + '.mp4.info.json'
  29. class TestInfoJSON(unittest.TestCase):
  30. def setUp(self):
  31. # Clear old files
  32. self.tearDown()
  33. def test_info_json(self):
  34. ie = youtube_dl.InfoExtractors.YoutubeIE()
  35. fd = FileDownloader(params)
  36. fd.add_info_extractor(ie)
  37. fd.download([TEST_ID])
  38. self.assertTrue(os.path.exists(INFO_JSON_FILE))
  39. def tearDown(self):
  40. if os.path.exists(INFO_JSON_FILE):
  41. os.remove(INFO_JSON_FILE)
  42. if __name__ == '__main__':
  43. unittest.main()