mirror of
				https://github.com/yt-dlp/yt-dlp.git
				synced 2025-10-30 22:25:19 +00:00 
			
		
		
		
	Merge 'ytdl-org/youtube-dl/master' release 2020.11.19
Old Extractors left behind: VLivePlaylistIE YoutubeSearchURLIE YoutubeShowIE YoutubeFavouritesIE If removing old extractors, make corresponding changes in docs/supportedsites.md youtube_dlc/extractor/extractors.py Not merged: .github/ISSUE_TEMPLATE/1_broken_site.md .github/ISSUE_TEMPLATE/2_site_support_request.md .github/ISSUE_TEMPLATE/3_site_feature_request.md .github/ISSUE_TEMPLATE/4_bug_report.md .github/ISSUE_TEMPLATE/5_feature_request.md test/test_all_urls.py youtube_dlc/version.py Changelog
This commit is contained in:
		| @@ -31,15 +31,17 @@ class TestAllURLsMatching(unittest.TestCase): | ||||
|  | ||||
|     def test_youtube_playlist_matching(self): | ||||
|         assertPlaylist = lambda url: self.assertMatch(url, ['youtube:playlist']) | ||||
|         assertTab = lambda url: self.assertMatch(url, ['youtube:tab']) | ||||
|         assertPlaylist('ECUl4u3cNGP61MdtwGTqZA0MreSaDybji8') | ||||
|         assertPlaylist('UUBABnxM4Ar9ten8Mdjj1j0Q')  # 585 | ||||
|         assertPlaylist('https://www.youtube.com/playlist?list=UUBABnxM4Ar9ten8Mdjj1j0Q') | ||||
|         assertPlaylist('PL63F0C78739B09958') | ||||
|         assertTab('https://www.youtube.com/playlist?list=UUBABnxM4Ar9ten8Mdjj1j0Q') | ||||
|         assertPlaylist('https://www.youtube.com/course?list=ECUl4u3cNGP61MdtwGTqZA0MreSaDybji8') | ||||
|         assertPlaylist('https://www.youtube.com/playlist?list=PLwP_SiAcdui0KVebT0mU9Apz359a4ubsC') | ||||
|         assertPlaylist('https://www.youtube.com/watch?v=AV6J6_AeFEQ&playnext=1&list=PL4023E734DA416012')  # 668 | ||||
|         assertTab('https://www.youtube.com/playlist?list=PLwP_SiAcdui0KVebT0mU9Apz359a4ubsC') | ||||
|         assertTab('https://www.youtube.com/watch?v=AV6J6_AeFEQ&playnext=1&list=PL4023E734DA416012')  # 668 | ||||
|         self.assertFalse('youtube:playlist' in self.matching_ies('PLtS2H6bU1M')) | ||||
|         # Top tracks | ||||
|         assertPlaylist('https://www.youtube.com/playlist?list=MCUS.20142101') | ||||
|         assertTab('https://www.youtube.com/playlist?list=MCUS.20142101') | ||||
|  | ||||
|     def test_youtube_matching(self): | ||||
|         self.assertTrue(YoutubeIE.suitable('PLtS2H6bU1M')) | ||||
| @@ -50,26 +52,22 @@ class TestAllURLsMatching(unittest.TestCase): | ||||
|         self.assertMatch('http://www.cleanvideosearch.com/media/action/yt/watch?videoId=8v_4O44sfjM', ['youtube']) | ||||
|  | ||||
|     def test_youtube_channel_matching(self): | ||||
|         assertChannel = lambda url: self.assertMatch(url, ['youtube:channel']) | ||||
|         assertChannel = lambda url: self.assertMatch(url, ['youtube:tab']) | ||||
|         assertChannel('https://www.youtube.com/channel/HCtnHdj3df7iM') | ||||
|         assertChannel('https://www.youtube.com/channel/HCtnHdj3df7iM?feature=gb_ch_rec') | ||||
|         assertChannel('https://www.youtube.com/channel/HCtnHdj3df7iM/videos') | ||||
|  | ||||
|     def test_youtube_user_matching(self): | ||||
|         self.assertMatch('http://www.youtube.com/NASAgovVideo/videos', ['youtube:user']) | ||||
|     # def test_youtube_user_matching(self): | ||||
|     #     self.assertMatch('http://www.youtube.com/NASAgovVideo/videos', ['youtube:tab']) | ||||
|  | ||||
|     def test_youtube_feeds(self): | ||||
|         self.assertMatch('https://www.youtube.com/feed/watch_later', ['youtube:watchlater']) | ||||
|         self.assertMatch('https://www.youtube.com/feed/subscriptions', ['youtube:subscriptions']) | ||||
|         self.assertMatch('https://www.youtube.com/feed/recommended', ['youtube:recommended']) | ||||
|         self.assertMatch('https://www.youtube.com/my_favorites', ['youtube:favorites']) | ||||
|  | ||||
|     def test_youtube_show_matching(self): | ||||
|         self.assertMatch('http://www.youtube.com/show/airdisasters', ['youtube:show']) | ||||
|  | ||||
|     def test_youtube_search_matching(self): | ||||
|         self.assertMatch('http://www.youtube.com/results?search_query=making+mustard', ['youtube:search_url']) | ||||
|         self.assertMatch('https://www.youtube.com/results?baz=bar&search_query=youtube-dl+test+video&filters=video&lclk=video', ['youtube:search_url']) | ||||
|     # def test_youtube_search_matching(self): | ||||
|     #     self.assertMatch('http://www.youtube.com/results?search_query=making+mustard', ['youtube:search_url']) | ||||
|     #     self.assertMatch('https://www.youtube.com/results?baz=bar&search_query=youtube-dl+test+video&filters=video&lclk=video', ['youtube:search_url']) | ||||
|  | ||||
|     def test_youtube_extract(self): | ||||
|         assertExtractId = lambda url, id: self.assertEqual(YoutubeIE.extract_id(url), id) | ||||
|   | ||||
| @@ -937,6 +937,28 @@ class TestUtil(unittest.TestCase): | ||||
|         self.assertEqual(d['x'], 1) | ||||
|         self.assertEqual(d['y'], 'a') | ||||
|  | ||||
|         # Just drop ! prefix for now though this results in a wrong value | ||||
|         on = js_to_json('''{ | ||||
|             a: !0, | ||||
|             b: !1, | ||||
|             c: !!0, | ||||
|             d: !!42.42, | ||||
|             e: !!![], | ||||
|             f: !"abc", | ||||
|             g: !"", | ||||
|             !42: 42 | ||||
|         }''') | ||||
|         self.assertEqual(json.loads(on), { | ||||
|             'a': 0, | ||||
|             'b': 1, | ||||
|             'c': 0, | ||||
|             'd': 42.42, | ||||
|             'e': [], | ||||
|             'f': "abc", | ||||
|             'g': "", | ||||
|             '42': 42 | ||||
|         }) | ||||
|  | ||||
|         on = js_to_json('["abc", "def",]') | ||||
|         self.assertEqual(json.loads(on), ['abc', 'def']) | ||||
|  | ||||
| @@ -994,6 +1016,12 @@ class TestUtil(unittest.TestCase): | ||||
|         on = js_to_json('{42:4.2e1}') | ||||
|         self.assertEqual(json.loads(on), {'42': 42.0}) | ||||
|  | ||||
|         on = js_to_json('{ "0x40": "0x40" }') | ||||
|         self.assertEqual(json.loads(on), {'0x40': '0x40'}) | ||||
|  | ||||
|         on = js_to_json('{ "040": "040" }') | ||||
|         self.assertEqual(json.loads(on), {'040': '040'}) | ||||
|  | ||||
|     def test_js_to_json_malformed(self): | ||||
|         self.assertEqual(js_to_json('42a1'), '42"a1"') | ||||
|         self.assertEqual(js_to_json('42a-1'), '42"a"-1') | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 pukkandan
					pukkandan