Merge pull request #59 from coffeemakr/bugfix-test-urls-and-relative-fix
Add more tests and fix 2 bugs
This commit is contained in:
		
						commit
						179c38c619
					
				
					 22 changed files with 206 additions and 162 deletions
				
			
		|  | @ -0,0 +1,35 @@ | |||
| package org.schabi.newpipe.extractor.services.soundcloud; | ||||
| 
 | ||||
| import com.grack.nanojson.JsonObject; | ||||
| 
 | ||||
| import javax.annotation.Nonnull; | ||||
| 
 | ||||
| public class SoundcloudExtractorHelper { | ||||
|      | ||||
|     private static final String HTTP = "http://"; | ||||
|     private static final String HTTPS = "https://"; | ||||
| 
 | ||||
| 
 | ||||
|     private static String replaceHttpWithHttps(final String url) { | ||||
|         if(!url.isEmpty() && url.startsWith(HTTP)) { | ||||
|             return HTTPS + url.substring(HTTP.length()); | ||||
|         } | ||||
|         return url; | ||||
|     } | ||||
| 
 | ||||
|     @Nonnull | ||||
|     static String getUploaderUrl(JsonObject object) { | ||||
|         String url = object.getObject("user").getString("permalink_url", ""); | ||||
|         return replaceHttpWithHttps(url); | ||||
|     } | ||||
| 
 | ||||
|     @Nonnull | ||||
|     static String getAvatarUrl(JsonObject object) { | ||||
|         String url = object.getObject("user", new JsonObject()).getString("avatar_url", ""); | ||||
|         return replaceHttpWithHttps(url); | ||||
|     } | ||||
| 
 | ||||
|     public static String getUploaderName(JsonObject object) { | ||||
|         return object.getObject("user").getString("username", ""); | ||||
|     } | ||||
| } | ||||
|  | @ -4,7 +4,6 @@ import com.grack.nanojson.JsonObject; | |||
| import com.grack.nanojson.JsonParser; | ||||
| import com.grack.nanojson.JsonParserException; | ||||
| import org.schabi.newpipe.extractor.Downloader; | ||||
| import org.schabi.newpipe.extractor.NewPipe; | ||||
| import org.schabi.newpipe.extractor.StreamingService; | ||||
| import org.schabi.newpipe.extractor.exceptions.ExtractionException; | ||||
| import org.schabi.newpipe.extractor.exceptions.ParsingException; | ||||
|  | @ -69,17 +68,17 @@ public class SoundcloudPlaylistExtractor extends PlaylistExtractor { | |||
| 
 | ||||
|     @Override | ||||
|     public String getUploaderUrl() { | ||||
|         return playlist.getObject("user").getString("permalink_url", ""); | ||||
|         return SoundcloudExtractorHelper.getUploaderUrl(playlist); | ||||
|     } | ||||
| 
 | ||||
|     @Override | ||||
|     public String getUploaderName() { | ||||
|         return playlist.getObject("user").getString("username", ""); | ||||
|         return SoundcloudExtractorHelper.getUploaderName(playlist); | ||||
|     } | ||||
| 
 | ||||
|     @Override | ||||
|     public String getUploaderAvatarUrl() { | ||||
|         return playlist.getObject("user", new JsonObject()).getString("avatar_url", ""); | ||||
|         return SoundcloudExtractorHelper.getAvatarUrl(playlist); | ||||
|     } | ||||
| 
 | ||||
|     @Override | ||||
|  |  | |||
|  | @ -102,19 +102,19 @@ public class SoundcloudStreamExtractor extends StreamExtractor { | |||
|     @Nonnull | ||||
|     @Override | ||||
|     public String getUploaderUrl() { | ||||
|         return track.getObject("user").getString("permalink_url", ""); | ||||
|         return SoundcloudExtractorHelper.getUploaderUrl(track); | ||||
|     } | ||||
| 
 | ||||
|     @Nonnull | ||||
|     @Override | ||||
|     public String getUploaderName() { | ||||
|         return track.getObject("user").getString("username", ""); | ||||
|         return SoundcloudExtractorHelper.getUploaderName(track); | ||||
|     } | ||||
| 
 | ||||
|     @Nonnull | ||||
|     @Override | ||||
|     public String getUploaderAvatarUrl() { | ||||
|         return track.getObject("user", new JsonObject()).getString("avatar_url", ""); | ||||
|         return SoundcloudExtractorHelper.getAvatarUrl(track); | ||||
|     } | ||||
| 
 | ||||
|     @Override | ||||
|  |  | |||
|  | @ -265,7 +265,7 @@ public class YoutubePlaylistExtractor extends PlaylistExtractor { | |||
| 
 | ||||
|                 @Override | ||||
|                 public String getUploaderUrl() throws ParsingException { | ||||
|                     return getUploaderLink().attr("href"); | ||||
|                     return getUploaderLink().attr("abs:href"); | ||||
|                 } | ||||
| 
 | ||||
|                 @Override | ||||
|  |  | |||
|  | @ -100,7 +100,7 @@ public class YoutubeStreamInfoItemExtractor implements StreamInfoItemExtractor { | |||
|             try { | ||||
|                 return item.select("div[class=\"yt-lockup-byline\"]").first() | ||||
|                         .select("a").first() | ||||
|                         .attr("href"); | ||||
|                         .attr("abs:href"); | ||||
|             } catch (Exception e){} | ||||
| 
 | ||||
|             // try this if the first didn't work | ||||
|  |  | |||
|  | @ -110,7 +110,7 @@ public class YoutubeTrendingExtractor extends KioskExtractor { | |||
|                     @Override | ||||
|                     public String getUploaderUrl() throws ParsingException { | ||||
|                         try { | ||||
|                             String link = getUploaderLink().attr("href"); | ||||
|                             String link = getUploaderLink().attr("abs:href"); | ||||
|                             if (link.isEmpty()) { | ||||
|                                 throw new IllegalArgumentException("is empty"); | ||||
|                             } | ||||
|  |  | |||
|  | @ -1,9 +1,12 @@ | |||
| package org.schabi.newpipe.extractor; | ||||
| 
 | ||||
| import javax.annotation.Nonnull; | ||||
| import java.net.MalformedURLException; | ||||
| import java.net.URL; | ||||
| import java.util.List; | ||||
| 
 | ||||
| import static org.junit.Assert.assertEquals; | ||||
| 
 | ||||
| public class ExtractorAsserts { | ||||
|     public static void assertEmptyErrors(String message, List<Throwable> errors) { | ||||
|         if(!errors.isEmpty()) { | ||||
|  | @ -14,11 +17,21 @@ public class ExtractorAsserts { | |||
|         } | ||||
|     } | ||||
| 
 | ||||
|     public static void assertIsValidUrl(String url) { | ||||
|     @Nonnull | ||||
|     private static URL urlFromString(String url) { | ||||
|         try { | ||||
|             new URL(url); | ||||
|             return new URL(url); | ||||
|         } catch (MalformedURLException e) { | ||||
|             throw new AssertionError("Invalid url: " + url, e); | ||||
|         } | ||||
|     } | ||||
| 
 | ||||
|     public static void assertIsValidUrl(String url) { | ||||
|         urlFromString(url); | ||||
|     } | ||||
| 
 | ||||
|     public static void assertIsSecureUrl(String urlToCheck) { | ||||
|         URL url = urlFromString(urlToCheck); | ||||
|         assertEquals("Protocol of URL is not secure", "https", url.getProtocol()); | ||||
|     } | ||||
| } | ||||
|  |  | |||
|  | @ -0,0 +1,57 @@ | |||
| package org.schabi.newpipe.extractor.services.soundcloud; | ||||
| 
 | ||||
| import org.junit.Test; | ||||
| import org.schabi.newpipe.extractor.InfoItem; | ||||
| import org.schabi.newpipe.extractor.channel.ChannelInfoItem; | ||||
| import org.schabi.newpipe.extractor.playlist.PlaylistInfoItem; | ||||
| import org.schabi.newpipe.extractor.search.SearchResult; | ||||
| import org.schabi.newpipe.extractor.stream.StreamInfoItem; | ||||
| import org.schabi.newpipe.extractor.stream.StreamType; | ||||
| 
 | ||||
| import static org.junit.Assert.*; | ||||
| import static org.schabi.newpipe.extractor.ExtractorAsserts.assertIsSecureUrl; | ||||
| 
 | ||||
| public abstract class BaseSoundcloudSearchTest { | ||||
| 
 | ||||
|     protected static SearchResult result; | ||||
| 
 | ||||
|     @Test | ||||
|     public void testResultList() { | ||||
|         assertFalse("Got empty result list", result.resultList.isEmpty()); | ||||
|         for(InfoItem infoItem: result.resultList) { | ||||
|             assertIsSecureUrl(infoItem.getUrl()); | ||||
|             assertIsSecureUrl(infoItem.getThumbnailUrl()); | ||||
|             assertFalse(infoItem.getName().isEmpty()); | ||||
|             assertFalse("Name is probably a URI: " + infoItem.getName(), | ||||
|                     infoItem.getName().contains("://")); | ||||
|             if(infoItem instanceof StreamInfoItem) { | ||||
|                 // test stream item | ||||
|                 StreamInfoItem streamInfoItem = (StreamInfoItem) infoItem; | ||||
|                 assertIsSecureUrl(streamInfoItem.getUploaderUrl()); | ||||
|                 assertFalse(streamInfoItem.getUploadDate().isEmpty()); | ||||
|                 assertFalse(streamInfoItem.getUploaderName().isEmpty()); | ||||
|                 assertEquals(StreamType.AUDIO_STREAM, streamInfoItem.getStreamType()); | ||||
|             } else if(infoItem instanceof ChannelInfoItem) { | ||||
|                 // Nothing special to check? | ||||
|             } else if(infoItem instanceof PlaylistInfoItem)  { | ||||
|                 // test playlist item | ||||
|                 assertTrue(infoItem.getUrl().contains("/sets/")); | ||||
|                 long streamCount = ((PlaylistInfoItem) infoItem).getStreamCount(); | ||||
|                 assertTrue(streamCount > 0); | ||||
|             } else { | ||||
|                 fail("Unknown infoItem type: " + infoItem); | ||||
|             } | ||||
|         } | ||||
|     } | ||||
| 
 | ||||
|     @Test | ||||
|     public void testResultErrors() { | ||||
|         assertNotNull(result.errors); | ||||
|         if (!result.errors.isEmpty()) { | ||||
|             for (Throwable error : result.errors) { | ||||
|                 error.printStackTrace(); | ||||
|             } | ||||
|         } | ||||
|         assertTrue(result.errors.isEmpty()); | ||||
|     } | ||||
| } | ||||
|  | @ -8,6 +8,7 @@ import org.schabi.newpipe.extractor.NewPipe; | |||
| import org.schabi.newpipe.extractor.channel.ChannelExtractor; | ||||
| 
 | ||||
| import static org.junit.Assert.*; | ||||
| import static org.schabi.newpipe.extractor.ExtractorAsserts.assertIsSecureUrl; | ||||
| import static org.schabi.newpipe.extractor.ServiceList.SoundCloud; | ||||
| 
 | ||||
| /** | ||||
|  | @ -43,7 +44,7 @@ public class SoundcloudChannelExtractorTest { | |||
| 
 | ||||
|     @Test | ||||
|     public void testGetAvatarUrl() throws Exception { | ||||
|         assertTrue(extractor.getAvatarUrl().contains("https://")); | ||||
|         assertIsSecureUrl(extractor.getAvatarUrl()); | ||||
|     } | ||||
| 
 | ||||
|     @Test | ||||
|  |  | |||
|  | @ -8,6 +8,7 @@ import org.schabi.newpipe.extractor.exceptions.ExtractionException; | |||
| import org.schabi.newpipe.extractor.playlist.PlaylistExtractor; | ||||
| 
 | ||||
| import static org.junit.Assert.*; | ||||
| import static org.schabi.newpipe.extractor.ExtractorAsserts.assertIsSecureUrl; | ||||
| import static org.schabi.newpipe.extractor.ServiceList.SoundCloud; | ||||
| 
 | ||||
| /** | ||||
|  | @ -42,12 +43,13 @@ public class SoundcloudPlaylistExtractorTest { | |||
| 
 | ||||
|     @Test | ||||
|     public void testGetThumbnailUrl() throws Exception { | ||||
|         assertTrue(extractor.getThumbnailUrl(), extractor.getThumbnailUrl().contains("https://")); | ||||
|         assertIsSecureUrl(extractor.getThumbnailUrl()); | ||||
|     } | ||||
| 
 | ||||
|     @Test | ||||
|     public void testGetUploaderUrl() throws Exception { | ||||
|         assertEquals(extractor.getUploaderUrl(), "http://soundcloud.com/liluzivert"); | ||||
|         assertIsSecureUrl(extractor.getUploaderUrl()); | ||||
|         assertEquals(extractor.getUploaderUrl(), "https://soundcloud.com/liluzivert"); | ||||
|     } | ||||
| 
 | ||||
|     @Test | ||||
|  | @ -57,7 +59,7 @@ public class SoundcloudPlaylistExtractorTest { | |||
| 
 | ||||
|     @Test | ||||
|     public void testGetUploaderAvatarUrl() throws Exception { | ||||
|         assertTrue(extractor.getUploaderAvatarUrl(), extractor.getUploaderAvatarUrl().contains("https://")); | ||||
|         assertIsSecureUrl(extractor.getUploaderAvatarUrl()); | ||||
|     } | ||||
| 
 | ||||
|     @Test | ||||
|  |  | |||
|  | @ -6,9 +6,7 @@ import org.junit.Test; | |||
| import org.schabi.newpipe.Downloader; | ||||
| import org.schabi.newpipe.extractor.NewPipe; | ||||
| import org.schabi.newpipe.extractor.search.SearchEngine; | ||||
| import org.schabi.newpipe.extractor.search.SearchResult; | ||||
| 
 | ||||
| import static org.junit.Assert.assertFalse; | ||||
| import static org.junit.Assert.assertNotNull; | ||||
| import static org.junit.Assert.assertTrue; | ||||
| import static org.schabi.newpipe.extractor.ServiceList.SoundCloud; | ||||
|  | @ -16,8 +14,7 @@ import static org.schabi.newpipe.extractor.ServiceList.SoundCloud; | |||
| /** | ||||
|  * Test for {@link SearchEngine} | ||||
|  */ | ||||
| public class SoundcloudSearchEngineAllTest { | ||||
|     private static SearchResult result; | ||||
| public class SoundcloudSearchEngineAllTest extends BaseSoundcloudSearchTest { | ||||
| 
 | ||||
|     @BeforeClass | ||||
|     public static void setUp() throws Exception { | ||||
|  | @ -30,18 +27,6 @@ public class SoundcloudSearchEngineAllTest { | |||
|                 .getSearchResult(); | ||||
|     } | ||||
| 
 | ||||
|     @Test | ||||
|     public void testResultList() { | ||||
|         assertFalse(result.resultList.isEmpty()); | ||||
|     } | ||||
| 
 | ||||
|     @Test | ||||
|     public void testResultErrors() { | ||||
|         assertNotNull(result.errors); | ||||
|         if (!result.errors.isEmpty()) for (Throwable error : result.errors) error.printStackTrace(); | ||||
|         assertTrue(result.errors.isEmpty()); | ||||
|     } | ||||
| 
 | ||||
|     @Ignore | ||||
|     @Test | ||||
|     public void testSuggestion() { | ||||
|  |  | |||
|  | @ -15,8 +15,7 @@ import static org.schabi.newpipe.extractor.ServiceList.SoundCloud; | |||
| /** | ||||
|  * Test for {@link SearchEngine} | ||||
|  */ | ||||
| public class SoundcloudSearchEngineChannelTest { | ||||
|     private static SearchResult result; | ||||
| public class SoundcloudSearchEngineChannelTest extends BaseSoundcloudSearchTest { | ||||
| 
 | ||||
|     @BeforeClass | ||||
|     public static void setUp() throws Exception { | ||||
|  | @ -29,11 +28,6 @@ public class SoundcloudSearchEngineChannelTest { | |||
|                 .getSearchResult(); | ||||
|     } | ||||
| 
 | ||||
|     @Test | ||||
|     public void testResultList() { | ||||
|         assertFalse(result.resultList.isEmpty()); | ||||
|     } | ||||
| 
 | ||||
|     @Test | ||||
|     public void testResultsItemType() { | ||||
|         for (InfoItem infoItem : result.resultList) { | ||||
|  | @ -41,13 +35,6 @@ public class SoundcloudSearchEngineChannelTest { | |||
|         } | ||||
|     } | ||||
| 
 | ||||
|     @Test | ||||
|     public void testResultErrors() { | ||||
|         assertNotNull(result.errors); | ||||
|         if (!result.errors.isEmpty()) for (Throwable error : result.errors) error.printStackTrace(); | ||||
|         assertTrue(result.errors.isEmpty()); | ||||
|     } | ||||
| 
 | ||||
|     @Ignore | ||||
|     @Test | ||||
|     public void testSuggestion() { | ||||
|  |  | |||
|  | @ -36,8 +36,7 @@ import static org.schabi.newpipe.extractor.ServiceList.SoundCloud; | |||
| /** | ||||
|  * Test for {@link SearchEngine} | ||||
|  */ | ||||
| public class SoundcloudSearchEnginePlaylistTest { | ||||
|     private static SearchResult result; | ||||
| public class SoundcloudSearchEnginePlaylistTest extends BaseSoundcloudSearchTest { | ||||
| 
 | ||||
|     @BeforeClass | ||||
|     public static void setUp() throws Exception { | ||||
|  | @ -49,11 +48,6 @@ public class SoundcloudSearchEnginePlaylistTest { | |||
|                 .getSearchResult(); | ||||
|     } | ||||
| 
 | ||||
|     @Test | ||||
|     public void testResultList() { | ||||
|         assertFalse(result.resultList.isEmpty()); | ||||
|     } | ||||
| 
 | ||||
|     @Test | ||||
|     public void testUserItemType() { | ||||
|         for (InfoItem infoItem : result.resultList) { | ||||
|  | @ -61,13 +55,6 @@ public class SoundcloudSearchEnginePlaylistTest { | |||
|         } | ||||
|     } | ||||
| 
 | ||||
|     @Test | ||||
|     public void testResultErrors() { | ||||
|         assertNotNull(result.errors); | ||||
|         if (!result.errors.isEmpty()) for (Throwable error : result.errors) error.printStackTrace(); | ||||
|         assertTrue(result.errors.isEmpty()); | ||||
|     } | ||||
| 
 | ||||
|     @Ignore | ||||
|     @Test | ||||
|     public void testSuggestion() { | ||||
|  |  | |||
|  | @ -15,25 +15,19 @@ import static org.schabi.newpipe.extractor.ServiceList.SoundCloud; | |||
| /** | ||||
|  * Test for {@link SearchEngine} | ||||
|  */ | ||||
| public class SoundcloudSearchEngineStreamTest { | ||||
|     private static SearchResult result; | ||||
| public class SoundcloudSearchEngineStreamTest extends BaseSoundcloudSearchTest { | ||||
| 
 | ||||
|     @BeforeClass | ||||
|     public static void setUp() throws Exception { | ||||
|         NewPipe.init(Downloader.getInstance()); | ||||
|         SearchEngine engine = SoundCloud.getService().getSearchEngine(); | ||||
| 
 | ||||
|         // SoundCloud will suggest "lil uzi vert" instead of "lil uzi vert", | ||||
|         // SoundCloud will suggest "lil uzi vert" instead of "lill uzi vert", | ||||
|         // keep in mind that the suggestions can NOT change by country (the parameter "de") | ||||
|         result = engine.search("lill uzi vert", 0, "de", SearchEngine.Filter.STREAM) | ||||
|                 .getSearchResult(); | ||||
|     } | ||||
| 
 | ||||
|     @Test | ||||
|     public void testResultList() { | ||||
|         assertFalse(result.resultList.isEmpty()); | ||||
|     } | ||||
| 
 | ||||
|     @Test | ||||
|     public void testResultsItemType() { | ||||
|         for (InfoItem infoItem : result.resultList) { | ||||
|  | @ -41,13 +35,6 @@ public class SoundcloudSearchEngineStreamTest { | |||
|         } | ||||
|     } | ||||
| 
 | ||||
|     @Test | ||||
|     public void testResultErrors() { | ||||
|         assertNotNull(result.errors); | ||||
|         if (!result.errors.isEmpty()) for (Throwable error : result.errors) error.printStackTrace(); | ||||
|         assertTrue(result.errors.isEmpty()); | ||||
|     } | ||||
| 
 | ||||
|     @Ignore | ||||
|     @Test | ||||
|     public void testSuggestion() { | ||||
|  |  | |||
|  | @ -14,6 +14,7 @@ import org.schabi.newpipe.extractor.stream.SubtitlesFormat; | |||
| import java.io.IOException; | ||||
| 
 | ||||
| import static org.junit.Assert.*; | ||||
| import static org.schabi.newpipe.extractor.ExtractorAsserts.assertIsSecureUrl; | ||||
| import static org.schabi.newpipe.extractor.ServiceList.SoundCloud; | ||||
| 
 | ||||
| /** | ||||
|  | @ -69,22 +70,23 @@ public class SoundcloudStreamExtractorDefaultTest { | |||
| 
 | ||||
|     @Test | ||||
|     public void testGetUploadDate() throws ParsingException { | ||||
|         assertEquals(extractor.getUploadDate(), "2016-07-31"); | ||||
|         assertEquals("2016-07-31", extractor.getUploadDate()); | ||||
|     } | ||||
| 
 | ||||
|     @Test | ||||
|     public void testGetUploaderUrl() throws ParsingException { | ||||
|         assertEquals(extractor.getUploaderUrl(), "http://soundcloud.com/liluzivert"); | ||||
|         assertIsSecureUrl(extractor.getUploaderUrl()); | ||||
|         assertEquals("https://soundcloud.com/liluzivert", extractor.getUploaderUrl()); | ||||
|     } | ||||
| 
 | ||||
|     @Test | ||||
|     public void testGetThumbnailUrl() throws ParsingException { | ||||
|         assertTrue(extractor.getThumbnailUrl(), extractor.getThumbnailUrl().contains("https://")); | ||||
|         assertIsSecureUrl(extractor.getThumbnailUrl()); | ||||
|     } | ||||
| 
 | ||||
|     @Test | ||||
|     public void testGetUploaderAvatarUrl() throws ParsingException { | ||||
|         assertTrue(extractor.getUploaderAvatarUrl(), extractor.getUploaderAvatarUrl().contains("https://")); | ||||
|         assertIsSecureUrl(extractor.getUploaderAvatarUrl()); | ||||
|     } | ||||
| 
 | ||||
|     @Test | ||||
|  |  | |||
|  | @ -0,0 +1,55 @@ | |||
| package org.schabi.newpipe.extractor.services.youtube; | ||||
| 
 | ||||
| import org.junit.Test; | ||||
| import org.schabi.newpipe.extractor.InfoItem; | ||||
| import org.schabi.newpipe.extractor.channel.ChannelInfoItem; | ||||
| import org.schabi.newpipe.extractor.playlist.PlaylistInfoItem; | ||||
| import org.schabi.newpipe.extractor.search.SearchResult; | ||||
| import org.schabi.newpipe.extractor.stream.StreamInfoItem; | ||||
| 
 | ||||
| import static org.junit.Assert.*; | ||||
| import static org.junit.Assert.assertTrue; | ||||
| import static org.schabi.newpipe.extractor.ExtractorAsserts.assertIsSecureUrl; | ||||
| 
 | ||||
| public abstract class BaseYoutubeSearchTest { | ||||
| 
 | ||||
|     protected static SearchResult result; | ||||
| 
 | ||||
|     @Test | ||||
|     public void testResultList() { | ||||
|         assertFalse("Got empty result list", result.resultList.isEmpty()); | ||||
|         for(InfoItem infoItem: result.resultList) { | ||||
|             assertIsSecureUrl(infoItem.getUrl()); | ||||
|             assertIsSecureUrl(infoItem.getThumbnailUrl()); | ||||
|             assertFalse(infoItem.getName().isEmpty()); | ||||
|             assertFalse("Name is probably a URI: " + infoItem.getName(), | ||||
|                     infoItem.getName().contains("://")); | ||||
|             if(infoItem instanceof StreamInfoItem) { | ||||
|                 // test stream item | ||||
|                 StreamInfoItem streamInfoItem = (StreamInfoItem) infoItem; | ||||
|                 assertIsSecureUrl(streamInfoItem.getUploaderUrl()); | ||||
|                 assertFalse(streamInfoItem.getUploadDate().isEmpty()); | ||||
|                 assertFalse(streamInfoItem.getUploaderName().isEmpty()); | ||||
|             } else if(infoItem instanceof ChannelInfoItem) { | ||||
|                 // Nothing special to check? | ||||
|             } else if(infoItem instanceof PlaylistInfoItem)  { | ||||
|                 // test playlist item | ||||
|                 long streamCount = ((PlaylistInfoItem) infoItem).getStreamCount(); | ||||
|                 assertTrue(streamCount > 0); | ||||
|             } else { | ||||
|                 fail("Unknown infoItem type: " + infoItem); | ||||
|             } | ||||
|         } | ||||
|     } | ||||
| 
 | ||||
|     @Test | ||||
|     public void testResultErrors() { | ||||
|         assertNotNull(result.errors); | ||||
|         if (!result.errors.isEmpty()) { | ||||
|             for (Throwable error : result.errors) { | ||||
|                 error.printStackTrace(); | ||||
|             } | ||||
|         } | ||||
|         assertTrue(result.errors.isEmpty()); | ||||
|     } | ||||
| } | ||||
|  | @ -40,8 +40,7 @@ import static org.schabi.newpipe.extractor.ExtractorAsserts.assertIsValidUrl; | |||
| /** | ||||
|  * Test for {@link SearchEngine} | ||||
|  */ | ||||
| public class YoutubeSearchEngineAllTest { | ||||
|     private static SearchResult result; | ||||
| public class YoutubeSearchEngineAllTest extends BaseYoutubeSearchTest { | ||||
| 
 | ||||
|     @BeforeClass | ||||
|     public static void setUpClass() throws Exception { | ||||
|  | @ -53,29 +52,13 @@ public class YoutubeSearchEngineAllTest { | |||
|     } | ||||
| 
 | ||||
|     @Test | ||||
|     public void testResultList() { | ||||
|         final List<InfoItem> results = result.getResults(); | ||||
|         assertFalse("Results are empty: " + results, results.isEmpty()); | ||||
| 
 | ||||
|         InfoItem firstInfoItem = results.get(0); | ||||
|     public void testResultList_FirstElement() { | ||||
|         InfoItem firstInfoItem = result.getResults().get(0); | ||||
| 
 | ||||
|         // THe channel should be the first item | ||||
|         assertTrue(firstInfoItem instanceof ChannelInfoItem); | ||||
|         assertEquals("name", "PewDiePie", firstInfoItem.name); | ||||
|         assertEquals("url","https://www.youtube.com/user/PewDiePie", firstInfoItem.url); | ||||
| 
 | ||||
|         for(InfoItem item: results) { | ||||
|             assertIsValidUrl(item.url); | ||||
|         } | ||||
| 
 | ||||
|     } | ||||
| 
 | ||||
|     @Test | ||||
|     public void testResultErrors() { | ||||
|         for (Throwable error : result.getErrors()) { | ||||
|             error.printStackTrace(); | ||||
|         } | ||||
|         assertTrue(result.getErrors().isEmpty()); | ||||
|     } | ||||
| 
 | ||||
|     @Ignore | ||||
|  |  | |||
|  | @ -37,8 +37,7 @@ import static org.schabi.newpipe.extractor.ServiceList.YouTube; | |||
| /** | ||||
|  * Test for {@link SearchEngine} | ||||
|  */ | ||||
| public class YoutubeSearchEngineChannelTest { | ||||
|     private static SearchResult result; | ||||
| public class YoutubeSearchEngineChannelTest extends BaseYoutubeSearchTest { | ||||
| 
 | ||||
|     @BeforeClass | ||||
|     public static void setUp() throws Exception { | ||||
|  | @ -51,14 +50,6 @@ public class YoutubeSearchEngineChannelTest { | |||
|                 .getSearchResult(); | ||||
|     } | ||||
| 
 | ||||
|     @Test | ||||
|     public void testResultList() { | ||||
|         assertFalse(result.resultList.isEmpty()); | ||||
|         for(InfoItem item: result.getResults()) { | ||||
|             assertIsValidUrl(item.url); | ||||
|         } | ||||
|     } | ||||
| 
 | ||||
|     @Test | ||||
|     public void testResultsItemType() { | ||||
|         for (InfoItem infoItem : result.resultList) { | ||||
|  | @ -66,13 +57,6 @@ public class YoutubeSearchEngineChannelTest { | |||
|         } | ||||
|     } | ||||
| 
 | ||||
|     @Test | ||||
|     public void testResultErrors() { | ||||
|         assertNotNull(result.errors); | ||||
|         if (!result.errors.isEmpty()) for (Throwable error : result.errors) error.printStackTrace(); | ||||
|         assertTrue(result.errors.isEmpty()); | ||||
|     } | ||||
| 
 | ||||
|     @Ignore | ||||
|     @Test | ||||
|     public void testSuggestion() { | ||||
|  |  | |||
|  | @ -6,6 +6,7 @@ import org.junit.Test; | |||
| import org.schabi.newpipe.Downloader; | ||||
| import org.schabi.newpipe.extractor.InfoItem; | ||||
| import org.schabi.newpipe.extractor.NewPipe; | ||||
| import org.schabi.newpipe.extractor.playlist.PlaylistInfoItem; | ||||
| import org.schabi.newpipe.extractor.search.SearchEngine; | ||||
| import org.schabi.newpipe.extractor.search.SearchResult; | ||||
| 
 | ||||
|  | @ -37,8 +38,7 @@ import static org.schabi.newpipe.extractor.ServiceList.YouTube; | |||
| /** | ||||
|  * Test for {@link SearchEngine} | ||||
|  */ | ||||
| public class YoutubeSearchEnginePlaylistTest { | ||||
|     private static SearchResult result; | ||||
| public class YoutubeSearchEnginePlaylistTest extends BaseYoutubeSearchTest { | ||||
| 
 | ||||
|     @BeforeClass | ||||
|     public static void setUp() throws Exception { | ||||
|  | @ -52,27 +52,13 @@ public class YoutubeSearchEnginePlaylistTest { | |||
|     } | ||||
| 
 | ||||
|     @Test | ||||
|     public void testResultList() { | ||||
|         assertFalse(result.resultList.isEmpty()); | ||||
|         for(InfoItem item: result.getResults()) { | ||||
|             assertIsValidUrl(item.url); | ||||
|         } | ||||
|     } | ||||
| 
 | ||||
|     @Test | ||||
|     public void testUserItemType() { | ||||
|     public void testInfoItemType() { | ||||
|         for (InfoItem infoItem : result.resultList) { | ||||
|             assertTrue(infoItem instanceof PlaylistInfoItem); | ||||
|             assertEquals(InfoItem.InfoType.PLAYLIST, infoItem.info_type); | ||||
|         } | ||||
|     } | ||||
| 
 | ||||
|     @Test | ||||
|     public void testResultErrors() { | ||||
|         assertNotNull(result.errors); | ||||
|         if (!result.errors.isEmpty()) for (Throwable error : result.errors) error.printStackTrace(); | ||||
|         assertTrue(result.errors.isEmpty()); | ||||
|     } | ||||
| 
 | ||||
|     @Ignore | ||||
|     @Test | ||||
|     public void testSuggestion() { | ||||
|  |  | |||
|  | @ -37,8 +37,7 @@ import static org.schabi.newpipe.extractor.ServiceList.YouTube; | |||
| /** | ||||
|  * Test for {@link SearchEngine} | ||||
|  */ | ||||
| public class YoutubeSearchEngineStreamTest { | ||||
|     private static SearchResult result; | ||||
| public class YoutubeSearchEngineStreamTest extends BaseYoutubeSearchTest { | ||||
| 
 | ||||
|     @BeforeClass | ||||
|     public static void setUp() throws Exception { | ||||
|  | @ -51,14 +50,6 @@ public class YoutubeSearchEngineStreamTest { | |||
|                 .getSearchResult(); | ||||
|     } | ||||
| 
 | ||||
|     @Test | ||||
|     public void testResultList() { | ||||
|         assertFalse(result.resultList.isEmpty()); | ||||
|         for(InfoItem item: result.getResults()) { | ||||
|             assertIsValidUrl(item.url); | ||||
|         } | ||||
|     } | ||||
| 
 | ||||
|     @Test | ||||
|     public void testResultsItemType() { | ||||
|         for (InfoItem infoItem : result.resultList) { | ||||
|  | @ -66,13 +57,6 @@ public class YoutubeSearchEngineStreamTest { | |||
|         } | ||||
|     } | ||||
| 
 | ||||
|     @Test | ||||
|     public void testResultErrors() { | ||||
|         assertNotNull(result.errors); | ||||
|         if (!result.errors.isEmpty()) for (Throwable error : result.errors) error.printStackTrace(); | ||||
|         assertTrue(result.errors.isEmpty()); | ||||
|     } | ||||
| 
 | ||||
|     @Ignore | ||||
|     @Test | ||||
|     public void testSuggestion() { | ||||
|  |  | |||
|  | @ -3,6 +3,7 @@ package org.schabi.newpipe.extractor.services.youtube; | |||
| import org.junit.BeforeClass; | ||||
| import org.junit.Test; | ||||
| import org.schabi.newpipe.Downloader; | ||||
| import org.schabi.newpipe.extractor.ExtractorAsserts; | ||||
| import org.schabi.newpipe.extractor.NewPipe; | ||||
| import org.schabi.newpipe.extractor.exceptions.ExtractionException; | ||||
| import org.schabi.newpipe.extractor.exceptions.ParsingException; | ||||
|  | @ -12,6 +13,7 @@ import org.schabi.newpipe.extractor.utils.Utils; | |||
| import java.io.IOException; | ||||
| 
 | ||||
| import static org.junit.Assert.*; | ||||
| import static org.schabi.newpipe.extractor.ExtractorAsserts.assertIsSecureUrl; | ||||
| import static org.schabi.newpipe.extractor.ServiceList.YouTube; | ||||
| 
 | ||||
| /* | ||||
|  | @ -38,7 +40,6 @@ import static org.schabi.newpipe.extractor.ServiceList.YouTube; | |||
|  * Test for {@link StreamExtractor} | ||||
|  */ | ||||
| public class YoutubeStreamExtractorDefaultTest { | ||||
|     public static final String HTTPS = "https://"; | ||||
|     private static YoutubeStreamExtractor extractor; | ||||
| 
 | ||||
|     @BeforeClass | ||||
|  | @ -102,14 +103,12 @@ public class YoutubeStreamExtractorDefaultTest { | |||
| 
 | ||||
|     @Test | ||||
|     public void testGetThumbnailUrl() throws ParsingException { | ||||
|         assertTrue(extractor.getThumbnailUrl(), | ||||
|                 extractor.getThumbnailUrl().contains(HTTPS)); | ||||
|         assertIsSecureUrl(extractor.getThumbnailUrl()); | ||||
|     } | ||||
| 
 | ||||
|     @Test | ||||
|     public void testGetUploaderAvatarUrl() throws ParsingException { | ||||
|         assertTrue(extractor.getUploaderAvatarUrl(), | ||||
|                 extractor.getUploaderAvatarUrl().contains(HTTPS)); | ||||
|         assertIsSecureUrl(extractor.getUploaderAvatarUrl()); | ||||
|     } | ||||
| 
 | ||||
|     @Test | ||||
|  | @ -120,8 +119,7 @@ public class YoutubeStreamExtractorDefaultTest { | |||
|     @Test | ||||
|     public void testGetVideoStreams() throws IOException, ExtractionException { | ||||
|         for (VideoStream s : extractor.getVideoStreams()) { | ||||
|             assertTrue(s.url, | ||||
|                     s.url.contains(HTTPS)); | ||||
|             assertIsSecureUrl(s.url); | ||||
|             assertTrue(s.resolution.length() > 0); | ||||
|             assertTrue(Integer.toString(s.getFormatId()), | ||||
|                     0 <= s.getFormatId() && s.getFormatId() <= 4); | ||||
|  |  | |||
|  | @ -16,6 +16,7 @@ import java.util.ArrayList; | |||
| import java.util.List; | ||||
| 
 | ||||
| import static org.junit.Assert.*; | ||||
| import static org.schabi.newpipe.extractor.ExtractorAsserts.assertIsSecureUrl; | ||||
| import static org.schabi.newpipe.extractor.ServiceList.YouTube; | ||||
| 
 | ||||
| /** | ||||
|  | @ -85,14 +86,12 @@ public class YoutubeStreamExtractorRestrictedTest { | |||
| 
 | ||||
|     @Test | ||||
|     public void testGetThumbnailUrl() throws ParsingException { | ||||
|         assertTrue(extractor.getThumbnailUrl(), | ||||
|                 extractor.getThumbnailUrl().contains(HTTPS)); | ||||
|         assertIsSecureUrl(extractor.getThumbnailUrl()); | ||||
|     } | ||||
| 
 | ||||
|     @Test | ||||
|     public void testGetUploaderAvatarUrl() throws ParsingException { | ||||
|         assertTrue(extractor.getUploaderAvatarUrl(), | ||||
|                 extractor.getUploaderAvatarUrl().contains(HTTPS)); | ||||
|         assertIsSecureUrl(extractor.getUploaderAvatarUrl()); | ||||
|     } | ||||
| 
 | ||||
|     // FIXME: 25.11.17 Are there no streams or are they not listed? | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue