test_download.py 4.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125
  1. #!/usr/bin/env python2
  2. import unittest
  3. import hashlib
  4. import os
  5. import json
  6. from youtube_dl.FileDownloader import FileDownloader
  7. from youtube_dl.InfoExtractors import YoutubeIE, DailymotionIE
  8. from youtube_dl.InfoExtractors import MetacafeIE, PhotobucketIE
  9. from youtube_dl.InfoExtractors import FacebookIE, BlipTVIE
  10. from youtube_dl.InfoExtractors import VimeoIE, XVideosIE
  11. class DownloadTest(unittest.TestCase):
  12. PARAMETERS_FILE = "test/parameters.json"
  13. #calculated with md5sum:
  14. #md5sum (GNU coreutils) 8.19
  15. YOUTUBE_MD5 = "ab62e120445e8f68e8c8fddb7bd3ed76"
  16. YOUTUBE_URL = "http://www.youtube.com/watch?v=BaW_jenozKc"
  17. YOUTUBE_FILE = "BaW_jenozKc.mp4"
  18. DAILYMOTION_MD5 = "d363a50e9eb4f22ce90d08d15695bb47"
  19. DAILYMOTION_URL = "http://www.dailymotion.com/video/x33vw9_tutoriel-de-youtubeur-dl-des-video_tech"
  20. DAILYMOTION_FILE = "x33vw9.mp4"
  21. METACAFE_SIZE = 5754305
  22. METACAFE_URL = "http://www.metacafe.com/watch/yt-_aUehQsCQtM/the_electric_company_short_i_pbs_kids_go/"
  23. METACAFE_FILE = "_aUehQsCQtM.flv"
  24. BLIP_MD5 = "93c24d2f4e0782af13b8a7606ea97ba7"
  25. BLIP_URL = "http://blip.tv/cbr/cbr-exclusive-gotham-city-imposters-bats-vs-jokerz-short-3-5796352"
  26. BLIP_FILE = "5779306.m4v"
  27. VIMEO_MD5 = ""
  28. VIMEO_URL = "http://vimeo.com/3156959"
  29. VIMEO_FILE = "3156959.mp4"
  30. XVIDEO_MD5 = ""
  31. XVIDEO_URL = ""
  32. XVIDEO_FILE = ""
  33. def test_youtube(self):
  34. #let's download a file from youtube
  35. with open(DownloadTest.PARAMETERS_FILE) as f:
  36. fd = FileDownloader(json.load(f))
  37. fd.add_info_extractor(YoutubeIE())
  38. fd.download([DownloadTest.YOUTUBE_URL])
  39. print(os.path.abspath(DownloadTest.YOUTUBE_FILE))
  40. self.assertTrue(os.path.exists(DownloadTest.YOUTUBE_FILE))
  41. md5_down_file = md5_for_file(DownloadTest.YOUTUBE_FILE)
  42. self.assertEqual(md5_down_file, DownloadTest.YOUTUBE_MD5)
  43. def test_dailymotion(self):
  44. with open(DownloadTest.PARAMETERS_FILE) as f:
  45. fd = FileDownloader(json.load(f))
  46. fd.add_info_extractor(DailymotionIE())
  47. fd.download([DownloadTest.DAILYMOTION_URL])
  48. self.assertTrue(os.path.exists(DownloadTest.DAILYMOTION_FILE))
  49. md5_down_file = md5_for_file(DownloadTest.DAILYMOTION_FILE)
  50. self.assertEqual(md5_down_file, DownloadTest.DAILYMOTION_MD5)
  51. def test_metacafe(self):
  52. #this emulate a skip,to be 2.6 compatible
  53. with open(DownloadTest.PARAMETERS_FILE) as f:
  54. fd = FileDownloader(json.load(f))
  55. print fd
  56. fd.add_info_extractor(MetacafeIE())
  57. fd.add_info_extractor(YoutubeIE())
  58. fd.download([DownloadTest.METACAFE_URL])
  59. self.assertTrue(os.path.exists(DownloadTest.METACAFE_FILE))
  60. self.assertEqual(os.path.getsize(DownloadTest.METACAFE_FILE), DownloadTest.METACAFE_SIZE)
  61. def test_blip(self):
  62. with open(DownloadTest.PARAMETERS_FILE) as f:
  63. fd = FileDownloader(json.load(f))
  64. fd.add_info_extractor(BlipTVIE())
  65. fd.download([DownloadTest.BLIP_URL])
  66. self.assertTrue(os.path.exists(DownloadTest.BLIP_FILE))
  67. md5_down_file = md5_for_file(DownloadTest.BLIP_FILE)
  68. self.assertEqual(md5_down_file, DownloadTest.BLIP_MD5)
  69. def test_vimeo(self):
  70. with open(DownloadTest.PARAMETERS_FILE) as f:
  71. fd = FileDownloader(json.load(f))
  72. fd.add_info_extractor(VimeoIE())
  73. fd.download([DownloadTest.VIMEO_URL])
  74. self.assertTrue(os.path.exists(DownloadTest.VIMEO_FILE))
  75. md5_down_file = md5_for_file(DownloadTest.VIMEO_FILE)
  76. self.assertEqual(md5_down_file, DownloadTest.VIMEO_MD5)
  77. def test_xvideo(self):
  78. return
  79. with open(DownloadTest.PARAMETERS_FILE) as f:
  80. fd = FileDownloader(json.load(f))
  81. fd.add_info_extractor(XVideosIE())
  82. fd.download([DownloadTest.XVIDEO_URL])
  83. self.assertTrue(os.path.exists(DownloadTest.XVIDEO_FILE))
  84. md5_down_file = md5_for_file(DownloadTest.XVIDEO_FILE)
  85. self.assertEqual(md5_down_file, DownloadTest.XVIDEO_MD5)
  86. def tearDown(self):
  87. if os.path.exists(DownloadTest.YOUTUBE_FILE):
  88. os.remove(DownloadTest.YOUTUBE_FILE)
  89. if os.path.exists(DownloadTest.DAILYMOTION_FILE):
  90. os.remove(DownloadTest.DAILYMOTION_FILE)
  91. if os.path.exists(DownloadTest.METACAFE_FILE):
  92. os.remove(DownloadTest.METACAFE_FILE)
  93. if os.path.exists(DownloadTest.BLIP_FILE):
  94. os.remove(DownloadTest.BLIP_FILE)
  95. if os.path.exists(DownloadTest.VIMEO_FILE):
  96. os.remove(DownloadTest.VIMEO_FILE)
  97. if os.path.exists(DownloadTest.XVIDEO_FILE):
  98. os.remove(DownloadTest.XVIDEO_FILE)
  99. def md5_for_file(filename, block_size=2**20):
  100. with open(filename) as f:
  101. md5 = hashlib.md5()
  102. while True:
  103. data = f.read(block_size)
  104. if not data:
  105. break
  106. md5.update(data)
  107. return md5.hexdigest()