diff options
author | Philipp Hagemeister <[email protected]> | 2014-08-27 17:11:45 +0200 |
---|---|---|
committer | Philipp Hagemeister <[email protected]> | 2014-08-27 17:11:45 +0200 |
commit | 2857084000f7b8471b63759e4a5bb3bce5327cc2 (patch) | |
tree | b703e09fd2b6d16245907be961dba45bb63459b0 /test/test_download.py | |
parent | 2929b3e71d9148106aa55d1ae13ef5db8b3b6850 (diff) | |
download | youtube-dl-2857084000f7b8471b63759e4a5bb3bce5327cc2.tar.gz youtube-dl-2857084000f7b8471b63759e4a5bb3bce5327cc2.zip |
[test_download] Improve playlist handling
Diffstat (limited to 'test/test_download.py')
-rw-r--r-- | test/test_download.py | 21 |
1 files changed, 18 insertions, 3 deletions
diff --git a/test/test_download.py b/test/test_download.py index 6422ef119..167c1cf95 100644 --- a/test/test_download.py +++ b/test/test_download.py @@ -103,8 +103,11 @@ def generator(test_case): def get_tc_filename(tc): return tc.get('file') or ydl.prepare_filename(tc.get('info_dict', {})) - def try_rm_tcs_files(): - for tc in test_cases: + res_dict = None + def try_rm_tcs_files(tcs=None): + if tcs is None: + tcs = test_cases + for tc in tcs: tc_filename = get_tc_filename(tc) try_rm(tc_filename) try_rm(tc_filename + '.part') @@ -148,7 +151,14 @@ def generator(test_case): self.assertEqual( len(res_dict['entries']), test_case['playlist_count'], - 'Expected at %d in playlist %s, but got %d.') + 'Expected %d entries in playlist %s, but got %d.' % ( + len(res_dict['entries']), + test_case['url'], + test_case['playlist_count'])) + if 'playlist_duration_sum' in test_case: + got_duration = sum(e['duration'] for e in res_dict['entries']) + self.assertEqual( + test_case['playlist_duration_sum'], got_duration) for tc in test_cases: tc_filename = get_tc_filename(tc) @@ -166,6 +176,11 @@ def generator(test_case): expect_info_dict(self, tc.get('info_dict', {}), info_dict) finally: try_rm_tcs_files() + if is_playlist and res_dict is not None: + # Remove all other files that may have been extracted if the + # extractor returns full results even with extract_flat + res_tcs = [{'info_dict': e} for e in res_dict['entries']] + try_rm_tcs_files(res_tcs) return test_template |