vevo: fixing naming when there are featured artists
authorAndrew J. Erickson <andy@bolt.me>
Wed, 9 Nov 2016 22:54:17 +0000 (14:54 -0800)
committerSergey M․ <dstftw@gmail.com>
Thu, 24 Nov 2016 16:07:28 +0000 (23:07 +0700)
youtube_dl/extractor/vevo.py

index 783efda7d337217fe0ed86a97a5dfa0902a5b7bf..ce607945fffc0d97443212670c30d3eb11b182fb 100644 (file)
@@ -91,14 +91,30 @@ class VevoIE(VevoBaseIE):
         'info_dict': {
             'id': 'USUV71503000',
             'ext': 'mp4',
-            'title': 'K Camp - Till I Die',
+            'title': 'K Camp ft. T.I. - Till I Die',
             'age_limit': 18,
             'timestamp': 1449468000,
             'upload_date': '20151207',
             'uploader': 'K Camp',
             'track': 'Till I Die',
             'artist': 'K Camp',
-            'genre': 'Rap/Hip-Hop',
+            'genre': 'Hip-Hop',
+        },
+    }, {
+        'note': 'Featured test',
+        'url': 'https://www.vevo.com/watch/lemaitre/Wait/USUV71402190',
+        'md5': 'd28675e5e8805035d949dc5cf161071d',
+        'info_dict': {
+            'id': 'USUV71402190',
+            'ext': 'mp4',
+            'title': 'Lemaitre ft. LoLo - Wait',
+            'age_limit': 0,
+            'timestamp': 1413432000,
+            'upload_date': '20141016',
+            'uploader': 'Lemaitre',
+            'track': 'Wait',
+            'artist': 'Lemaitre',
+            'genre': 'Electronic',
         },
     }, {
         'note': 'Only available via webpage',
@@ -242,8 +258,15 @@ class VevoIE(VevoBaseIE):
 
             timestamp = parse_iso8601(video_info.get('releaseDate'))
             artists = video_info.get('artists')
-            if artists:
-                artist = uploader = artists[0]['name']
+            for curr_artist in artists:
+                if 'role' in curr_artist:
+                    if curr_artist['role'] == 'Featured':
+                        featured_artist = curr_artist['name']
+                    elif curr_artist['role'] == 'Main':
+                        artist = uploader = curr_artist['name']
+                else:
+                    artist = uploader = curr_artist['name']
+                    break
             view_count = int_or_none(video_info.get('views', {}).get('total'))
 
             for video_version in video_versions: