mirror of
				https://gitlab.com/ytdl-org/youtube-dl.git
				synced 2025-11-04 10:27:07 -05:00 
			
		
		
		
	[bandcamp:album] Fix extractor results and associated test
This commit is contained in:
		@@ -109,7 +109,7 @@ class BandcampIE(InfoExtractor):
 | 
			
		||||
 | 
			
		||||
class BandcampAlbumIE(InfoExtractor):
 | 
			
		||||
    IE_NAME = 'Bandcamp:album'
 | 
			
		||||
    _VALID_URL = r'https?://(?:(?P<subdomain>[^.]+)\.)?bandcamp\.com(?:/album/(?P<title>[^?#]+)|/?(?:$|[?#]))'
 | 
			
		||||
    _VALID_URL = r'https?://(?:(?P<subdomain>[^.]+)\.)?bandcamp\.com(?:/album/(?P<album_id>[^?#]+)|/?(?:$|[?#]))'
 | 
			
		||||
 | 
			
		||||
    _TESTS = [{
 | 
			
		||||
        'url': 'http://blazo.bandcamp.com/album/jazz-format-mixtape-vol-1',
 | 
			
		||||
@@ -133,31 +133,37 @@ class BandcampAlbumIE(InfoExtractor):
 | 
			
		||||
        ],
 | 
			
		||||
        'info_dict': {
 | 
			
		||||
            'title': 'Jazz Format Mixtape vol.1',
 | 
			
		||||
            'id': 'jazz-format-mixtape-vol-1',
 | 
			
		||||
            'uploader_id': 'blazo',
 | 
			
		||||
        },
 | 
			
		||||
        'params': {
 | 
			
		||||
            'playlistend': 2
 | 
			
		||||
        },
 | 
			
		||||
        'skip': 'Bandcamp imposes download limits. See test_playlists:test_bandcamp_album for the playlist test'
 | 
			
		||||
        'skip': 'Bandcamp imposes download limits.'
 | 
			
		||||
    }, {
 | 
			
		||||
        'url': 'http://nightbringer.bandcamp.com/album/hierophany-of-the-open-grave',
 | 
			
		||||
        'info_dict': {
 | 
			
		||||
            'title': 'Hierophany of the Open Grave',
 | 
			
		||||
            'uploader_id': 'nightbringer',
 | 
			
		||||
            'id': 'hierophany-of-the-open-grave',
 | 
			
		||||
        },
 | 
			
		||||
        'playlist_mincount': 9,
 | 
			
		||||
    }, {
 | 
			
		||||
        'url': 'http://dotscale.bandcamp.com',
 | 
			
		||||
        'info_dict': {
 | 
			
		||||
            'title': 'Loom',
 | 
			
		||||
            'id': 'dotscale',
 | 
			
		||||
            'uploader_id': 'dotscale',
 | 
			
		||||
        },
 | 
			
		||||
        'playlist_mincount': 7,
 | 
			
		||||
    }]
 | 
			
		||||
 | 
			
		||||
    def _real_extract(self, url):
 | 
			
		||||
        mobj = re.match(self._VALID_URL, url)
 | 
			
		||||
        playlist_id = mobj.group('subdomain')
 | 
			
		||||
        title = mobj.group('title')
 | 
			
		||||
        display_id = title or playlist_id
 | 
			
		||||
        webpage = self._download_webpage(url, display_id)
 | 
			
		||||
        uploader_id = mobj.group('subdomain')
 | 
			
		||||
        album_id = mobj.group('album_id')
 | 
			
		||||
        playlist_id = album_id or uploader_id
 | 
			
		||||
        webpage = self._download_webpage(url, playlist_id)
 | 
			
		||||
        tracks_paths = re.findall(r'<a href="(.*?)" itemprop="url">', webpage)
 | 
			
		||||
        if not tracks_paths:
 | 
			
		||||
            raise ExtractorError('The page doesn\'t contain any tracks')
 | 
			
		||||
@@ -168,8 +174,8 @@ class BandcampAlbumIE(InfoExtractor):
 | 
			
		||||
            r'album_title\s*:\s*"(.*?)"', webpage, 'title', fatal=False)
 | 
			
		||||
        return {
 | 
			
		||||
            '_type': 'playlist',
 | 
			
		||||
            'uploader_id': uploader_id,
 | 
			
		||||
            'id': playlist_id,
 | 
			
		||||
            'display_id': display_id,
 | 
			
		||||
            'title': title,
 | 
			
		||||
            'entries': entries,
 | 
			
		||||
        }
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user