test_download.py 5.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165
  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_MD5 = ""
  22. METACAFE_URL = "http://www.metacafe.com/watch/yt-bV9L5Ht9LgY/download_youtube_playlist_with_youtube_dl/"
  23. METACAFE_FILE = ""
  24. PHOTOBUCKET_MD5 = ""
  25. PHOTOBUCKET_URL = ""
  26. PHOTOBUCKET_FILE = ""
  27. FACEBOOK_MD5 = ""
  28. FACEBOOK_URL = ""
  29. FACEBOOK_FILE = ""
  30. BLIP_MD5 = ""
  31. BLIP_URL = ""
  32. BLIP_FILE = ""
  33. VIMEO_MD5 = ""
  34. VIMEO_URL = ""
  35. VIMEO_FILE = ""
  36. XVIDEO_MD5 = ""
  37. XVIDEO_URL = ""
  38. XVIDEO_FILE = ""
  39. def test_youtube(self):
  40. #let's download a file from youtube
  41. with open(DownloadTest.PARAMETERS_FILE) as f:
  42. fd = FileDownloader(json.load(f))
  43. fd.add_info_extractor(YoutubeIE())
  44. fd.download([DownloadTest.YOUTUBE_URL])
  45. print(os.path.abspath(DownloadTest.YOUTUBE_FILE))
  46. self.assertTrue(os.path.exists(DownloadTest.YOUTUBE_FILE))
  47. md5_down_file = md5_for_file(DownloadTest.YOUTUBE_FILE)
  48. self.assertEqual(md5_down_file, DownloadTest.YOUTUBE_MD5)
  49. def test_dailymotion(self):
  50. with open(DownloadTest.PARAMETERS_FILE) as f:
  51. fd = FileDownloader(json.load(f))
  52. fd.add_info_extractor(DailymotionIE())
  53. fd.download([DownloadTest.DAILYMOTION_URL])
  54. self.assertTrue(os.path.exists(DownloadTest.DAILYMOTION_FILE))
  55. md5_down_file = md5_for_file(DownloadTest.DAILYMOTION_FILE)
  56. self.assertEqual(md5_down_file, DownloadTest.DAILYMOTION_MD5)
  57. def test_metacafe(self):
  58. #this emulate a skip,to be 2.6 compatible
  59. return
  60. with open(DownloadTest.PARAMETERS_FILE) as f:
  61. fd = FileDownloader(json.load(f))
  62. print fd
  63. fd.add_info_extractor(MetacafeIE())
  64. fd.download([DownloadTest.METACAFE_URL])
  65. self.assertTrue(os.path.exists(DownloadTest.METACAFE_FILE))
  66. md5_down_file = md5_for_file(DownloadTest.METACAFE_FILE)
  67. self.assertEqual(md5_down_file, DownloadTest.METACAFE_MD5)
  68. def test_photobucket(self):
  69. return
  70. with open(DownloadTest.PARAMETERS_FILE) as f:
  71. fd = FileDownloader(json.load(f))
  72. fd.add_info_extractor(PhotobucketIE())
  73. fd.download([DownloadTest.PHOTOBUCKET_URL])
  74. self.assertTrue(os.path.exists(DownloadTest.PHOTOBUCKET_FILE))
  75. md5_down_file = md5_for_file(DownloadTest.PHOTOBUCKET_FILE)
  76. self.assertEqual(md5_down_file, DownloadTest.PHOTOBUCKET_MD5)
  77. def test_facebook(self):
  78. return
  79. with open(DownloadTest.PARAMETERS_FILE) as f:
  80. fd = FileDownloader(json.load(f))
  81. fd.add_info_extractor(FacebookIE())
  82. fd.download([DownloadTest.FACEBOOK_URL])
  83. self.assertTrue(os.path.exists(DownloadTest.FACEBOOK_FILE))
  84. md5_down_file = md5_for_file(DownloadTest.FACEBOOK_FILE)
  85. self.assertEqual(md5_down_file, DownloadTest.FACEBOOK_MD5)
  86. def test_blip(self):
  87. return
  88. with open(DownloadTest.PARAMETERS_FILE) as f:
  89. fd = FileDownloader(json.load(f))
  90. fd.add_info_extractor(BlipTVIE())
  91. fd.download([DownloadTest.BLIP_URL])
  92. self.assertTrue(os.path.exists(DownloadTest.BLIP_FILE))
  93. md5_down_file = md5_for_file(DownloadTest.BLIP_FILE)
  94. self.assertEqual(md5_down_file, DownloadTest.BLIP_MD5)
  95. def test_vimeo(self):
  96. return
  97. with open(DownloadTest.PARAMETERS_FILE) as f:
  98. fd = FileDownloader(json.load(f))
  99. fd.add_info_extractor(VimeoIE())
  100. fd.download([DownloadTest.VIMEO_URL])
  101. self.assertTrue(os.path.exists(DownloadTest.VIMEO_FILE))
  102. md5_down_file = md5_for_file(DownloadTest.VIMEO_FILE)
  103. self.assertEqual(md5_down_file, DownloadTest.VIMEO_MD5)
  104. def test_xvideo(self):
  105. return
  106. with open(DownloadTest.PARAMETERS_FILE) as f:
  107. fd = FileDownloader(json.load(f))
  108. fd.add_info_extractor(XVideosIE())
  109. fd.download([DownloadTest.XVIDEO_URL])
  110. self.assertTrue(os.path.exists(DownloadTest.XVIDEO_FILE))
  111. md5_down_file = md5_for_file(DownloadTest.XVIDEO_FILE)
  112. self.assertEqual(md5_down_file, DownloadTest.XVIDEO_MD5)
  113. def tearDown(self):
  114. if os.path.exists(DownloadTest.YOUTUBE_FILE):
  115. os.remove(DownloadTest.YOUTUBE_FILE)
  116. if os.path.exists(DownloadTest.DAILYMOTION_FILE):
  117. os.remove(DownloadTest.DAILYMOTION_FILE)
  118. if os.path.exists(DownloadTest.METACAFE_FILE):
  119. os.remove(DownloadTest.METACAFE_FILE)
  120. if os.path.exists(DownloadTest.PHOTOBUCKET_FILE):
  121. os.remove(DownloadTest.PHOTOBUCKET_FILE)
  122. if os.path.exists(DownloadTest.FACEBOOK_FILE):
  123. os.remove(DownloadTest.FACEBOOK_FILE)
  124. if os.path.exists(DownloadTest.BLIP_FILE):
  125. os.remove(DownloadTest.BLIP_FILE)
  126. if os.path.exists(DownloadTest.VIMEO_FILE):
  127. os.remove(DownloadTest.VIMEO_FILE)
  128. if os.path.exists(DownloadTest.XVIDEO_FILE):
  129. os.remove(DownloadTest.XVIDEO_FILE)
  130. def md5_for_file(filename, block_size=2**20):
  131. with open(filename) as f:
  132. md5 = hashlib.md5()
  133. while True:
  134. data = f.read(block_size)
  135. if not data:
  136. break
  137. md5.update(data)
  138. return md5.hexdigest()