projects
/
youtube-dl
/ commitdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
| commitdiff |
tree
raw
|
patch
|
inline
| side by side (parent:
93dfcb9
)
[downloader/dash] Add testing facility
author
Yen Chi Hsuan
<yan12125@gmail.com>
Wed, 10 Jun 2015 06:45:54 +0000
(14:45 +0800)
committer
Yen Chi Hsuan
<yan12125@gmail.com>
Wed, 10 Jun 2015 06:45:54 +0000
(14:45 +0800)
youtube_dl/downloader/dash.py
patch
|
blob
|
history
diff --git
a/youtube_dl/downloader/dash.py
b/youtube_dl/downloader/dash.py
index cd84e0b07200d5d93304757eac78f8e51d716845..a4685d307fa3b0cc1357f08c4a1398b7f251c3fe 100644
(file)
--- a/
youtube_dl/downloader/dash.py
+++ b/
youtube_dl/downloader/dash.py
@@
-16,12
+16,21
@@
class DashSegmentsFD(FileDownloader):
base_url = info_dict['url']
segment_urls = info_dict['segment_urls']
base_url = info_dict['url']
segment_urls = info_dict['segment_urls']
+ is_test = self.params.get('test', False)
+ remaining_bytes = self._TEST_FILE_SIZE if is_test else None
byte_counter = 0
byte_counter = 0
- def append_url_to_file(outf, target_url, target_name):
+ def append_url_to_file(outf, target_url, target_name
, remaining_bytes=None
):
self.to_screen('[DashSegments] %s: Downloading %s' % (info_dict['id'], target_name))
req = compat_urllib_request.Request(target_url)
self.to_screen('[DashSegments] %s: Downloading %s' % (info_dict['id'], target_name))
req = compat_urllib_request.Request(target_url)
+ if remaining_bytes is not None:
+ req.add_header('Range', 'bytes=0-%d' % (remaining_bytes - 1))
+
data = self.ydl.urlopen(req).read()
data = self.ydl.urlopen(req).read()
+
+ if remaining_bytes is not None:
+ data = data[:remaining_bytes]
+
outf.write(data)
return len(data)
outf.write(data)
return len(data)
@@
-37,8
+46,13
@@
class DashSegmentsFD(FileDownloader):
for i, segment_url in enumerate(segment_urls):
segment_len = append_url_to_file(
outf, combine_url(base_url, segment_url),
for i, segment_url in enumerate(segment_urls):
segment_len = append_url_to_file(
outf, combine_url(base_url, segment_url),
- 'segment %d / %d' % (i + 1, len(segment_urls)))
+ 'segment %d / %d' % (i + 1, len(segment_urls)),
+ remaining_bytes)
byte_counter += segment_len
byte_counter += segment_len
+ if remaining_bytes is not None:
+ remaining_bytes -= segment_len
+ if remaining_bytes <= 0:
+ break
self.try_rename(tmpfilename, filename)
self.try_rename(tmpfilename, filename)