diff options
| author | Philipp Hagemeister <phihag@phihag.de> | 2014-09-13 07:31:48 +0200 | 
|---|---|---|
| committer | Philipp Hagemeister <phihag@phihag.de> | 2014-09-13 07:35:14 +0200 | 
| commit | 9291475f7da52bc7c7a7e6dada7e311197d3c7be (patch) | |
| tree | e65b678258db8b6d06ec5ec2779487f002f2010c | |
| parent | 81127aa55dc9eb4e971d841573e1a1661c9c18b6 (diff) | |
[youtube] Move more tests to Playlist IE, and simply suitable.
| -rw-r--r-- | test/test_youtube_lists.py | 46 | ||||
| -rw-r--r-- | youtube_dl/extractor/youtube.py | 41 | 
2 files changed, 35 insertions, 52 deletions
diff --git a/test/test_youtube_lists.py b/test/test_youtube_lists.py index 3aadedd64..1fa99f88b 100644 --- a/test/test_youtube_lists.py +++ b/test/test_youtube_lists.py @@ -25,15 +25,6 @@ class TestYoutubeLists(unittest.TestCase):          """Make sure the info has '_type' set to 'playlist'"""          self.assertEqual(info['_type'], 'playlist') -    def test_youtube_playlist(self): -        dl = FakeYDL() -        ie = YoutubePlaylistIE(dl) -        result = ie.extract('https://www.youtube.com/playlist?list=PLwiyx1dc3P2JR9N8gQaQN_BCvlSlap7re') -        self.assertIsPlaylist(result) -        self.assertEqual(result['title'], 'ytdl test PL') -        ytie_results = [YoutubeIE().extract_id(url['url']) for url in result['entries']] -        self.assertEqual(ytie_results, [ 'bV9L5Ht9LgY', 'FXxLjLQi3Fg', 'tU3Bgo5qJZE']) -      def test_youtube_playlist_noplaylist(self):          dl = FakeYDL()          dl.params['noplaylist'] = True @@ -41,36 +32,7 @@ class TestYoutubeLists(unittest.TestCase):          result = ie.extract('https://www.youtube.com/watch?v=FXxLjLQi3Fg&list=PLwiyx1dc3P2JR9N8gQaQN_BCvlSlap7re')          self.assertEqual(result['_type'], 'url')          self.assertEqual(YoutubeIE().extract_id(result['url']), 'FXxLjLQi3Fg') - -    def test_issue_673(self): -        dl = FakeYDL() -        ie = YoutubePlaylistIE(dl) -        result = ie.extract('PLBB231211A4F62143') -        self.assertTrue(len(result['entries']) > 25) - -    def test_youtube_playlist_long(self): -        dl = FakeYDL() -        ie = YoutubePlaylistIE(dl) -        result = ie.extract('https://www.youtube.com/playlist?list=UUBABnxM4Ar9ten8Mdjj1j0Q') -        self.assertIsPlaylist(result) -        self.assertTrue(len(result['entries']) >= 799) - -    def test_youtube_playlist_with_deleted(self): -        #651 -        dl = FakeYDL() -        ie = YoutubePlaylistIE(dl) -        result = ie.extract('https://www.youtube.com/playlist?list=PLwP_SiAcdui0KVebT0mU9Apz359a4ubsC') -        ytie_results = [YoutubeIE().extract_id(url['url']) for url in result['entries']] -        self.assertFalse('pElCt5oNDuI' in ytie_results) -        self.assertFalse('KdPEApIVdWM' in ytie_results) -         -    def test_youtube_playlist_empty(self): -        dl = FakeYDL() -        ie = YoutubePlaylistIE(dl) -        result = ie.extract('https://www.youtube.com/playlist?list=PLtPgu7CB4gbZDA7i_euNxn75ISqxwZPYx') -        self.assertIsPlaylist(result) -        self.assertEqual(len(result['entries']), 0) - +          def test_youtube_course(self):          dl = FakeYDL()          ie = YoutubePlaylistIE(dl) @@ -97,12 +59,6 @@ class TestYoutubeLists(unittest.TestCase):          result = ie.extract('https://www.youtube.com/user/TheLinuxFoundation')          self.assertTrue(len(result['entries']) >= 320) -    def test_youtube_safe_search(self): -        dl = FakeYDL() -        ie = YoutubePlaylistIE(dl) -        result = ie.extract('PLtPgu7CB4gbY9oDN3drwC3cMbJggS7dKl') -        self.assertEqual(len(result['entries']), 2) -      def test_youtube_show(self):          dl = FakeYDL()          ie = YoutubeShowIE(dl) diff --git a/youtube_dl/extractor/youtube.py b/youtube_dl/extractor/youtube.py index 10d7baef6..47ff53a35 100644 --- a/youtube_dl/extractor/youtube.py +++ b/youtube_dl/extractor/youtube.py @@ -221,6 +221,7 @@ class YoutubeIE(YoutubeBaseInfoExtractor, SubtitlesInfoExtractor):                           )                       )?                                                       # all until now is optional -> you can pass the naked ID                       ([0-9A-Za-z_-]{11})                                      # here is it! the YouTube video ID +                     (?!.*?&list=)                                            # combined list/video URLs are handled by the playlist IE                       (?(1).+)?                                                # if we found the ID, everything can follow                       $"""      _NEXT_URL_RE = r'[\?&]next_url=([^&]+)' @@ -387,13 +388,6 @@ class YoutubeIE(YoutubeBaseInfoExtractor, SubtitlesInfoExtractor):          },      ] - -    @classmethod -    def suitable(cls, url): -        """Receives a URL and returns True if suitable for this IE.""" -        if YoutubePlaylistIE.suitable(url): return False -        return re.match(cls._VALID_URL, url) is not None -      def __init__(self, *args, **kwargs):          super(YoutubeIE, self).__init__(*args, **kwargs)          self._player_cache = {} @@ -1026,6 +1020,39 @@ class YoutubePlaylistIE(YoutubeBaseInfoExtractor):              'title': 'ytdl test PL',          },          'playlist_count': 3, +    }, { +        'url': 'https://www.youtube.com/playlist?list=PLtPgu7CB4gbZDA7i_euNxn75ISqxwZPYx', +        'info_dict': { +            'title': 'YDL_Empty_List', +        }, +        'playlist_count': 0, +    }, { +        'note': 'Playlist with deleted videos (#651). As a bonus, the video #51 is also twice in this list.', +        'url': 'https://www.youtube.com/playlist?list=PLwP_SiAcdui0KVebT0mU9Apz359a4ubsC', +        'info_dict': { +            'title': '29C3: Not my department', +        }, +        'playlist_count': 95, +    }, { +        'note': 'issue #673', +        'url': 'PLBB231211A4F62143', +        'info_dict': { +            'title': 'Team Fortress 2 (Class-based LP)', +        }, +        'playlist_mincount': 26, +    }, { +        'note': 'Large playlist', +        'url': 'https://www.youtube.com/playlist?list=UUBABnxM4Ar9ten8Mdjj1j0Q', +        'info_dict': { +            'title': 'Uploads from Cauchemar', +        }, +        'playlist_mincount': 799, +    }, { +        'url': 'PLtPgu7CB4gbY9oDN3drwC3cMbJggS7dKl', +        'info_dict': { +            'title': 'YDL_safe_search', +        }, +        'playlist_count': 2,      }]      def _real_initialize(self):  | 
