diff --git a/test/test_youtube_lists.py b/test/test_youtube_lists.py index c4f0abbeaaac..e5fa03aaa518 100644 --- a/test/test_youtube_lists.py +++ b/test/test_youtube_lists.py @@ -45,8 +45,8 @@ def test_youtube_mix(self): result = ie.extract('https://www.youtube.com/watch?v=W01L70IGBgE&index=2&list=RDOQpdSVF_k_w') entries = result['entries'] self.assertTrue(len(entries) >= 50) - original_video = entries[0] - self.assertEqual(original_video['id'], 'OQpdSVF_k_w') + original_video_id = 'OQpdSVF_k_w' + self.assertTrue(original_video_id in {entry['id'] for entry in entries}) def test_youtube_toptracks(self): print('Skipping: The playlist page gives error 500') diff --git a/youtube_dl/extractor/youtube.py b/youtube_dl/extractor/youtube.py index 6ae2e58c1765..260e776215cb 100644 --- a/youtube_dl/extractor/youtube.py +++ b/youtube_dl/extractor/youtube.py @@ -2781,8 +2781,7 @@ def _extract_mix(self, playlist_id): webpage = self._download_webpage( url, playlist_id, 'Downloading page {0} of Youtube mix'.format(n)) new_ids = orderedSet(re.findall( - r'''(?xs)data-video-username=".*?".*? - href="/watch\?v=([0-9A-Za-z_-]{11})&[^"]*?list=%s''' % re.escape(playlist_id), + r'[\'"]/watch\?v=([0-9A-Za-z_-]{11})(?:&|\\u0026)[^"]*?list=%s' % re.escape(playlist_id), webpage)) # Fetch new pages until all the videos are repeated, it seems that # there are always 51 unique videos.