Refactor collectors
* Define a common iterface * Use generic types * Remove some duplicated code * Simplify InfoItemSearchCollector and remove unused methods * SearchResult: Make fields final
This commit is contained in:
		
							parent
							
								
									bc44557bdb
								
							
						
					
					
						commit
						ceb556384b
					
				
					 22 changed files with 223 additions and 144 deletions
				
			
		
							
								
								
									
										46
									
								
								src/main/java/org/schabi/newpipe/extractor/Collector.java
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										46
									
								
								src/main/java/org/schabi/newpipe/extractor/Collector.java
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,46 @@ | ||||||
|  | package org.schabi.newpipe.extractor; | ||||||
|  | 
 | ||||||
|  | import org.schabi.newpipe.extractor.exceptions.ParsingException; | ||||||
|  | 
 | ||||||
|  | import java.util.List; | ||||||
|  | 
 | ||||||
|  | /** | ||||||
|  |  * Collectors are used to simplify the collection of information | ||||||
|  |  * from extractors | ||||||
|  |  * @param <I> the item type | ||||||
|  |  * @param <E> the extractor type | ||||||
|  |  */ | ||||||
|  | public interface Collector<I, E> { | ||||||
|  | 
 | ||||||
|  |     /** | ||||||
|  |      * Try to add an extractor to the collection | ||||||
|  |      * @param extractor the extractor to add | ||||||
|  |      */ | ||||||
|  |     void commit(E extractor); | ||||||
|  | 
 | ||||||
|  |     /** | ||||||
|  |      * Try to extract the item from an extractor without adding it to the collection | ||||||
|  |      * @param extractor the extractor to use | ||||||
|  |      * @return the item | ||||||
|  |      * @throws ParsingException thrown if there is an error extracting the | ||||||
|  |      *                          <b>required</b> fields of the item. | ||||||
|  |      */ | ||||||
|  |     I extract(E extractor) throws ParsingException; | ||||||
|  | 
 | ||||||
|  |     /** | ||||||
|  |      * Get all items | ||||||
|  |      * @return the items | ||||||
|  |      */ | ||||||
|  |     List<I> getItemList(); | ||||||
|  | 
 | ||||||
|  |     /** | ||||||
|  |      * Get all errors | ||||||
|  |      * @return the errors | ||||||
|  |      */ | ||||||
|  |     List<Throwable> getErrors(); | ||||||
|  | 
 | ||||||
|  |     /** | ||||||
|  |      * Reset all collected items and errors | ||||||
|  |      */ | ||||||
|  |     void reset(); | ||||||
|  | } | ||||||
|  | @ -32,6 +32,8 @@ public abstract class Extractor { | ||||||
|     private String cleanUrl; |     private String cleanUrl; | ||||||
| 
 | 
 | ||||||
|     public Extractor(StreamingService service, String url) throws ExtractionException { |     public Extractor(StreamingService service, String url) throws ExtractionException { | ||||||
|  |         if(service == null) throw new NullPointerException("service is null"); | ||||||
|  |         if(url == null) throw new NullPointerException("url is null"); | ||||||
|         this.service = service; |         this.service = service; | ||||||
|         this.originalUrl = url; |         this.originalUrl = url; | ||||||
|     } |     } | ||||||
|  | @ -53,6 +55,10 @@ public abstract class Extractor { | ||||||
|         return originalUrl; |         return originalUrl; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |     /** | ||||||
|  |      * Get a clean url and as a fallback the original url. | ||||||
|  |      * @return the clean url or the original url | ||||||
|  |      */ | ||||||
|     public String getCleanUrl() { |     public String getCleanUrl() { | ||||||
|         if (cleanUrl != null && !cleanUrl.isEmpty()) return cleanUrl; |         if (cleanUrl != null && !cleanUrl.isEmpty()) return cleanUrl; | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -20,8 +20,6 @@ package org.schabi.newpipe.extractor; | ||||||
|  * along with NewPipe.  If not, see <http://www.gnu.org/licenses/>. |  * along with NewPipe.  If not, see <http://www.gnu.org/licenses/>. | ||||||
|  */ |  */ | ||||||
| 
 | 
 | ||||||
| import org.schabi.newpipe.extractor.stream.StreamType; |  | ||||||
| 
 |  | ||||||
| import java.io.Serializable; | import java.io.Serializable; | ||||||
| 
 | 
 | ||||||
| public abstract class InfoItem implements Serializable { | public abstract class InfoItem implements Serializable { | ||||||
|  |  | ||||||
|  | @ -1,8 +1,9 @@ | ||||||
| package org.schabi.newpipe.extractor; | package org.schabi.newpipe.extractor; | ||||||
| 
 | 
 | ||||||
| import org.schabi.newpipe.extractor.exceptions.ExtractionException; | import org.schabi.newpipe.extractor.exceptions.ParsingException; | ||||||
| 
 | 
 | ||||||
| import java.util.ArrayList; | import java.util.ArrayList; | ||||||
|  | import java.util.Collections; | ||||||
| import java.util.List; | import java.util.List; | ||||||
| 
 | 
 | ||||||
| /* | /* | ||||||
|  | @ -25,42 +26,66 @@ import java.util.List; | ||||||
|  * along with NewPipe.  If not, see <http://www.gnu.org/licenses/>. |  * along with NewPipe.  If not, see <http://www.gnu.org/licenses/>. | ||||||
|  */ |  */ | ||||||
| 
 | 
 | ||||||
| public abstract class InfoItemCollector { | public abstract class InfoItemCollector<I extends InfoItem, E> implements Collector<I,E> { | ||||||
|     private List<InfoItem> itemList = new ArrayList<>(); |  | ||||||
|     private List<Throwable> errors = new ArrayList<>(); |  | ||||||
|     private int serviceId = -1; |  | ||||||
| 
 | 
 | ||||||
|  |     private final List<I> itemList = new ArrayList<>(); | ||||||
|  |     private final List<Throwable> errors = new ArrayList<>(); | ||||||
|  |     private final int serviceId; | ||||||
|  | 
 | ||||||
|  |     /** | ||||||
|  |      * Create a new collector | ||||||
|  |      * @param serviceId the service id | ||||||
|  |      */ | ||||||
|     public InfoItemCollector(int serviceId) { |     public InfoItemCollector(int serviceId) { | ||||||
|         this.serviceId = serviceId; |         this.serviceId = serviceId; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     public List<InfoItem> getItemList() { |     @Override | ||||||
|         return itemList; |     public List<I> getItemList() { | ||||||
|  |         return Collections.unmodifiableList(itemList); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |     @Override | ||||||
|     public List<Throwable> getErrors() { |     public List<Throwable> getErrors() { | ||||||
|         return errors; |         return Collections.unmodifiableList(errors); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     protected void addFromCollector(InfoItemCollector otherC) throws ExtractionException { |     @Override | ||||||
|         if (serviceId != otherC.serviceId) { |     public void reset() { | ||||||
|             throw new ExtractionException("Service Id does not equal: " |         itemList.clear(); | ||||||
|                     + NewPipe.getNameOfService(serviceId) |         errors.clear(); | ||||||
|                     + " and " + NewPipe.getNameOfService((otherC.serviceId))); |  | ||||||
|         } |  | ||||||
|         errors.addAll(otherC.errors); |  | ||||||
|         itemList.addAll(otherC.itemList); |  | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     protected void addError(Exception e) { |     /** | ||||||
|         errors.add(e); |      * Add an error | ||||||
|  |      * @param error the error | ||||||
|  |      */ | ||||||
|  |     protected void addError(Exception error) { | ||||||
|  |         errors.add(error); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     protected void addItem(InfoItem item) { |     /** | ||||||
|  |      * Add an item | ||||||
|  |      * @param item the item | ||||||
|  |      */ | ||||||
|  |     protected void addItem(I item) { | ||||||
|         itemList.add(item); |         itemList.add(item); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     protected int getServiceId() { |     /** | ||||||
|  |      * Get the service id | ||||||
|  |      * @return the service id | ||||||
|  |      */ | ||||||
|  |     public int getServiceId() { | ||||||
|         return serviceId; |         return serviceId; | ||||||
|     } |     } | ||||||
|  | 
 | ||||||
|  |     @Override | ||||||
|  |     public void commit(E extractor) { | ||||||
|  |         try { | ||||||
|  |             addItem(extract(extractor)); | ||||||
|  |         } catch (ParsingException e) { | ||||||
|  |             addError(e); | ||||||
|  |         } | ||||||
|  |     } | ||||||
| } | } | ||||||
|  |  | ||||||
|  | @ -87,6 +87,18 @@ public abstract class ListExtractor extends Extractor { | ||||||
|         public boolean hasMoreStreams() { |         public boolean hasMoreStreams() { | ||||||
|             return nextItemsUrl != null && !nextItemsUrl.isEmpty(); |             return nextItemsUrl != null && !nextItemsUrl.isEmpty(); | ||||||
|         } |         } | ||||||
|  | 
 | ||||||
|  |         public List<InfoItem> getNextItemsList() { | ||||||
|  |             return nextItemsList; | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         public String getNextItemsUrl() { | ||||||
|  |             return nextItemsUrl; | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         public List<Throwable> getErrors() { | ||||||
|  |             return errors; | ||||||
|  |         } | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
| } | } | ||||||
|  |  | ||||||
|  | @ -11,7 +11,7 @@ public abstract class ListInfo extends Info { | ||||||
|         super(serviceId, id, url, name); |         super(serviceId, id, url, name); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     public List<InfoItem> getRelated_streams() { |     public List<InfoItem> getRelatedStreams() { | ||||||
|         return related_streams; |         return related_streams; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  | @ -19,7 +19,7 @@ public abstract class ListInfo extends Info { | ||||||
|         this.related_streams = related_streams; |         this.related_streams = related_streams; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     public boolean isHas_more_streams() { |     public boolean hasMoreStreams() { | ||||||
|         return has_more_streams; |         return has_more_streams; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  | @ -27,7 +27,7 @@ public abstract class ListInfo extends Info { | ||||||
|         this.has_more_streams = has_more_streams; |         this.has_more_streams = has_more_streams; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     public String getNext_streams_url() { |     public String getNextStreamsUrl() { | ||||||
|         return next_streams_url; |         return next_streams_url; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -23,11 +23,12 @@ import org.schabi.newpipe.extractor.exceptions.ParsingException; | ||||||
|  * along with NewPipe.  If not, see <http://www.gnu.org/licenses/>. |  * along with NewPipe.  If not, see <http://www.gnu.org/licenses/>. | ||||||
|  */ |  */ | ||||||
| 
 | 
 | ||||||
| public class ChannelInfoItemCollector extends InfoItemCollector { | public class ChannelInfoItemCollector extends InfoItemCollector<ChannelInfoItem, ChannelInfoItemExtractor> { | ||||||
|     public ChannelInfoItemCollector(int serviceId) { |     public ChannelInfoItemCollector(int serviceId) { | ||||||
|         super(serviceId); |         super(serviceId); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |     @Override | ||||||
|     public ChannelInfoItem extract(ChannelInfoItemExtractor extractor) throws ParsingException { |     public ChannelInfoItem extract(ChannelInfoItemExtractor extractor) throws ParsingException { | ||||||
|         // important information |         // important information | ||||||
|         int serviceId = getServiceId(); |         int serviceId = getServiceId(); | ||||||
|  | @ -60,12 +61,4 @@ public class ChannelInfoItemCollector extends InfoItemCollector { | ||||||
|         } |         } | ||||||
|         return resultItem; |         return resultItem; | ||||||
|     } |     } | ||||||
| 
 |  | ||||||
|     public void commit(ChannelInfoItemExtractor extractor) throws ParsingException { |  | ||||||
|         try { |  | ||||||
|             addItem(extract(extractor)); |  | ||||||
|         } catch (Exception e) { |  | ||||||
|             addError(e); |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
| } | } | ||||||
|  |  | ||||||
|  | @ -3,11 +3,13 @@ package org.schabi.newpipe.extractor.playlist; | ||||||
| import org.schabi.newpipe.extractor.InfoItemCollector; | import org.schabi.newpipe.extractor.InfoItemCollector; | ||||||
| import org.schabi.newpipe.extractor.exceptions.ParsingException; | import org.schabi.newpipe.extractor.exceptions.ParsingException; | ||||||
| 
 | 
 | ||||||
| public class PlaylistInfoItemCollector extends InfoItemCollector { | public class PlaylistInfoItemCollector extends InfoItemCollector<PlaylistInfoItem, PlaylistInfoItemExtractor> { | ||||||
|  | 
 | ||||||
|     public PlaylistInfoItemCollector(int serviceId) { |     public PlaylistInfoItemCollector(int serviceId) { | ||||||
|         super(serviceId); |         super(serviceId); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |     @Override | ||||||
|     public PlaylistInfoItem extract(PlaylistInfoItemExtractor extractor) throws ParsingException { |     public PlaylistInfoItem extract(PlaylistInfoItemExtractor extractor) throws ParsingException { | ||||||
| 
 | 
 | ||||||
|         String name = extractor.getName(); |         String name = extractor.getName(); | ||||||
|  | @ -33,12 +35,4 @@ public class PlaylistInfoItemCollector extends InfoItemCollector { | ||||||
|         } |         } | ||||||
|         return resultItem; |         return resultItem; | ||||||
|     } |     } | ||||||
| 
 |  | ||||||
|     public void commit(PlaylistInfoItemExtractor extractor) throws ParsingException { |  | ||||||
|         try { |  | ||||||
|             addItem(extract(extractor)); |  | ||||||
|         } catch (Exception e) { |  | ||||||
|             addError(e); |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
| } | } | ||||||
|  |  | ||||||
|  | @ -1,10 +1,10 @@ | ||||||
| package org.schabi.newpipe.extractor.search; | package org.schabi.newpipe.extractor.search; | ||||||
| 
 | 
 | ||||||
| import org.schabi.newpipe.extractor.InfoItemCollector; | import org.schabi.newpipe.extractor.*; | ||||||
| import org.schabi.newpipe.extractor.channel.ChannelInfoItemCollector; | import org.schabi.newpipe.extractor.channel.ChannelInfoItemCollector; | ||||||
| import org.schabi.newpipe.extractor.channel.ChannelInfoItemExtractor; | import org.schabi.newpipe.extractor.channel.ChannelInfoItemExtractor; | ||||||
| import org.schabi.newpipe.extractor.exceptions.ExtractionException; | import org.schabi.newpipe.extractor.exceptions.ExtractionException; | ||||||
| import org.schabi.newpipe.extractor.exceptions.FoundAdException; | import org.schabi.newpipe.extractor.exceptions.ParsingException; | ||||||
| import org.schabi.newpipe.extractor.playlist.PlaylistInfoItemCollector; | import org.schabi.newpipe.extractor.playlist.PlaylistInfoItemCollector; | ||||||
| import org.schabi.newpipe.extractor.playlist.PlaylistInfoItemExtractor; | import org.schabi.newpipe.extractor.playlist.PlaylistInfoItemExtractor; | ||||||
| import org.schabi.newpipe.extractor.stream.StreamInfoItemCollector; | import org.schabi.newpipe.extractor.stream.StreamInfoItemCollector; | ||||||
|  | @ -30,13 +30,23 @@ import org.schabi.newpipe.extractor.stream.StreamInfoItemExtractor; | ||||||
|  * along with NewPipe.  If not, see <http://www.gnu.org/licenses/>. |  * along with NewPipe.  If not, see <http://www.gnu.org/licenses/>. | ||||||
|  */ |  */ | ||||||
| 
 | 
 | ||||||
| public class InfoItemSearchCollector extends InfoItemCollector { | /** | ||||||
|  |  * Collector for search results | ||||||
|  |  * | ||||||
|  |  * This collector can handle the following extractor types: | ||||||
|  |  * <ul> | ||||||
|  |  *     <li>{@link StreamInfoItemExtractor}</li> | ||||||
|  |  *     <li>{@link ChannelInfoItemExtractor}</li> | ||||||
|  |  *     <li>{@link PlaylistInfoItemExtractor}</li> | ||||||
|  |  * </ul> | ||||||
|  |  * Calling {@link #extract(InfoItemExtractor)} or {@link #commit(Object)} with any | ||||||
|  |  * other extractor type will raise an exception. | ||||||
|  |  */ | ||||||
|  | public class InfoItemSearchCollector extends InfoItemCollector<InfoItem, InfoItemExtractor> { | ||||||
|     private String suggestion = ""; |     private String suggestion = ""; | ||||||
|     private StreamInfoItemCollector streamCollector; |     private final StreamInfoItemCollector streamCollector; | ||||||
|     private ChannelInfoItemCollector userCollector; |     private final ChannelInfoItemCollector userCollector; | ||||||
|     private PlaylistInfoItemCollector playlistCollector; |     private final PlaylistInfoItemCollector playlistCollector; | ||||||
| 
 |  | ||||||
|     private SearchResult result = new SearchResult(); |  | ||||||
| 
 | 
 | ||||||
|     InfoItemSearchCollector(int serviceId) { |     InfoItemSearchCollector(int serviceId) { | ||||||
|         super(serviceId); |         super(serviceId); | ||||||
|  | @ -50,43 +60,20 @@ public class InfoItemSearchCollector extends InfoItemCollector { | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     public SearchResult getSearchResult() throws ExtractionException { |     public SearchResult getSearchResult() throws ExtractionException { | ||||||
| 
 |         return new SearchResult(getServiceId(), suggestion, getItemList(), getErrors()); | ||||||
|         addFromCollector(userCollector); |  | ||||||
|         addFromCollector(streamCollector); |  | ||||||
|         addFromCollector(playlistCollector); |  | ||||||
| 
 |  | ||||||
|         result.suggestion = suggestion; |  | ||||||
|         result.errors = getErrors(); |  | ||||||
|         return result; |  | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     public void commit(StreamInfoItemExtractor extractor) { |     @Override | ||||||
|         try { |     public InfoItem extract(InfoItemExtractor extractor) throws ParsingException { | ||||||
|             result.resultList.add(streamCollector.extract(extractor)); |         // Use the corresponding collector for each item extractor type | ||||||
|         } catch (FoundAdException ae) { |         if(extractor instanceof StreamInfoItemExtractor) { | ||||||
|             System.err.println("Found ad"); |             return streamCollector.extract((StreamInfoItemExtractor) extractor); | ||||||
|         } catch (Exception e) { |         } else if(extractor instanceof ChannelInfoItemExtractor) { | ||||||
|             addError(e); |             return userCollector.extract((ChannelInfoItemExtractor) extractor); | ||||||
|         } |         } else if(extractor instanceof PlaylistInfoItemExtractor) { | ||||||
|     } |             return playlistCollector.extract((PlaylistInfoItemExtractor) extractor); | ||||||
| 
 |         } else { | ||||||
|     public void commit(ChannelInfoItemExtractor extractor) { |             throw new IllegalArgumentException("Invalid extractor type: " + extractor); | ||||||
|         try { |  | ||||||
|             result.resultList.add(userCollector.extract(extractor)); |  | ||||||
|         } catch (FoundAdException ae) { |  | ||||||
|             System.err.println("Found ad"); |  | ||||||
|         } catch (Exception e) { |  | ||||||
|             addError(e); |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     public void commit(PlaylistInfoItemExtractor extractor) { |  | ||||||
|         try { |  | ||||||
|             result.resultList.add(playlistCollector.extract(extractor)); |  | ||||||
|         } catch (FoundAdException ae) { |  | ||||||
|             System.err.println("Found ad"); |  | ||||||
|         } catch (Exception e) { |  | ||||||
|             addError(e); |  | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  |  | ||||||
|  | @ -5,6 +5,8 @@ import org.schabi.newpipe.extractor.exceptions.ExtractionException; | ||||||
| 
 | 
 | ||||||
| import java.io.IOException; | import java.io.IOException; | ||||||
| import java.util.ArrayList; | import java.util.ArrayList; | ||||||
|  | import java.util.Collection; | ||||||
|  | import java.util.Collections; | ||||||
| import java.util.List; | import java.util.List; | ||||||
| 
 | 
 | ||||||
| /* | /* | ||||||
|  | @ -28,6 +30,18 @@ import java.util.List; | ||||||
|  */ |  */ | ||||||
| 
 | 
 | ||||||
| public class SearchResult { | public class SearchResult { | ||||||
|  |     private final int serviceId; | ||||||
|  |     public final String suggestion; | ||||||
|  |     public final List<InfoItem> resultList; | ||||||
|  |     public final List<Throwable> errors; | ||||||
|  | 
 | ||||||
|  |     public SearchResult(int serviceId, String suggestion, List<InfoItem> results, List<Throwable> errors) { | ||||||
|  |         this.serviceId = serviceId; | ||||||
|  |         this.suggestion = suggestion; | ||||||
|  |         this.resultList = Collections.unmodifiableList(new ArrayList<>(results)); | ||||||
|  |         this.errors = Collections.unmodifiableList(new ArrayList<>(errors)); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|     public static SearchResult getSearchResult(SearchEngine engine, String query, int page, String languageCode, SearchEngine.Filter filter) |     public static SearchResult getSearchResult(SearchEngine engine, String query, int page, String languageCode, SearchEngine.Filter filter) | ||||||
|             throws IOException, ExtractionException { |             throws IOException, ExtractionException { | ||||||
| 
 | 
 | ||||||
|  | @ -47,7 +61,20 @@ public class SearchResult { | ||||||
|         return result; |         return result; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     public String suggestion; |     public String getSuggestion() { | ||||||
|     public List<InfoItem> resultList = new ArrayList<>(); |         return suggestion; | ||||||
|     public List<Throwable> errors = new ArrayList<>(); |     } | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  |     public List<InfoItem> getResults() { | ||||||
|  |         return Collections.unmodifiableList(resultList); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public List<Throwable> getErrors() { | ||||||
|  |         return errors; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public int getServiceId() { | ||||||
|  |         return serviceId; | ||||||
|  |     } | ||||||
| } | } | ||||||
|  |  | ||||||
|  | @ -214,7 +214,7 @@ public class YoutubeChannelExtractor extends ChannelExtractor { | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     private void collectStreamsFrom(StreamInfoItemCollector collector, Element element) throws ParsingException { |     private void collectStreamsFrom(StreamInfoItemCollector collector, Element element) throws ParsingException { | ||||||
|         collector.getItemList().clear(); |         collector.reset(); | ||||||
| 
 | 
 | ||||||
|         final String uploaderName = getName(); |         final String uploaderName = getName(); | ||||||
|         for (final Element li : element.children()) { |         for (final Element li : element.children()) { | ||||||
|  |  | ||||||
|  | @ -195,7 +195,7 @@ public class YoutubePlaylistExtractor extends PlaylistExtractor { | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     private void collectStreamsFrom(StreamInfoItemCollector collector, Element element) throws ParsingException { |     private void collectStreamsFrom(StreamInfoItemCollector collector, Element element) throws ParsingException { | ||||||
|         collector.getItemList().clear(); |         collector.reset(); | ||||||
| 
 | 
 | ||||||
|         final UrlIdHandler streamUrlIdHandler = getService().getStreamUrlIdHandler(); |         final UrlIdHandler streamUrlIdHandler = getService().getStreamUrlIdHandler(); | ||||||
|         for (final Element li : element.children()) { |         for (final Element li : element.children()) { | ||||||
|  |  | ||||||
|  | @ -25,18 +25,6 @@ import org.schabi.newpipe.extractor.MediaFormat; | ||||||
| public class AudioStream extends Stream { | public class AudioStream extends Stream { | ||||||
|     public int average_bitrate = -1; |     public int average_bitrate = -1; | ||||||
| 
 | 
 | ||||||
|     /** |  | ||||||
|      * Create a new audio stream |  | ||||||
|      * @param url the url |  | ||||||
|      * @param format the id of the format |  | ||||||
|      * @param averageBitrate the average bit rate |  | ||||||
|      * @deprecated use {@link AudioStream#AudioStream(String, MediaFormat, int)} instead |  | ||||||
|      */ |  | ||||||
|     @Deprecated |  | ||||||
|     public AudioStream(String url, int format, int averageBitrate) { |  | ||||||
|         this(url, MediaFormat.getFormatById(format), averageBitrate); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     /** |     /** | ||||||
|      * Create a new audio stream |      * Create a new audio stream | ||||||
|      * @param url the url |      * @param url the url | ||||||
|  |  | ||||||
|  | @ -8,6 +8,11 @@ import java.util.List; | ||||||
| public abstract class Stream implements Serializable { | public abstract class Stream implements Serializable { | ||||||
|     private final MediaFormat mediaFormat; |     private final MediaFormat mediaFormat; | ||||||
|     public final String url; |     public final String url; | ||||||
|  | 
 | ||||||
|  |     /** | ||||||
|  |      * @deprecated Use {@link #getFormat()}  or {@link #getFormatId()} | ||||||
|  |      */ | ||||||
|  |     @Deprecated | ||||||
|     public final int format; |     public final int format; | ||||||
| 
 | 
 | ||||||
|     public Stream(String url, MediaFormat format) { |     public Stream(String url, MediaFormat format) { | ||||||
|  | @ -20,7 +25,7 @@ public abstract class Stream implements Serializable { | ||||||
|      * Reveals whether two streams have the same stats (format and bitrate, for example) |      * Reveals whether two streams have the same stats (format and bitrate, for example) | ||||||
|      */ |      */ | ||||||
|     public boolean equalStats(Stream cmp) { |     public boolean equalStats(Stream cmp) { | ||||||
|         return cmp != null && format == cmp.format; |         return cmp != null && getFormatId() == cmp.getFormatId(); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     /** |     /** | ||||||
|  | @ -48,4 +53,8 @@ public abstract class Stream implements Serializable { | ||||||
|     public MediaFormat getFormat() { |     public MediaFormat getFormat() { | ||||||
|         return mediaFormat; |         return mediaFormat; | ||||||
|     } |     } | ||||||
|  | 
 | ||||||
|  |     public int getFormatId() { | ||||||
|  |         return mediaFormat.id; | ||||||
|  |     } | ||||||
| } | } | ||||||
|  |  | ||||||
|  | @ -28,13 +28,14 @@ import java.util.Vector; | ||||||
|  * along with NewPipe.  If not, see <http://www.gnu.org/licenses/>. |  * along with NewPipe.  If not, see <http://www.gnu.org/licenses/>. | ||||||
|  */ |  */ | ||||||
| 
 | 
 | ||||||
| public class StreamInfoItemCollector extends InfoItemCollector { | public class StreamInfoItemCollector extends InfoItemCollector<StreamInfoItem, StreamInfoItemExtractor> { | ||||||
| 
 | 
 | ||||||
|     public StreamInfoItemCollector(int serviceId) { |     public StreamInfoItemCollector(int serviceId) { | ||||||
|         super(serviceId); |         super(serviceId); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     public StreamInfoItem extract(StreamInfoItemExtractor extractor) throws Exception { |     @Override | ||||||
|  |     public StreamInfoItem extract(StreamInfoItemExtractor extractor) throws ParsingException { | ||||||
|         if (extractor.isAd()) { |         if (extractor.isAd()) { | ||||||
|             throw new FoundAdException("Found ad"); |             throw new FoundAdException("Found ad"); | ||||||
|         } |         } | ||||||
|  | @ -82,7 +83,8 @@ public class StreamInfoItemCollector extends InfoItemCollector { | ||||||
|         return resultItem; |         return resultItem; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     public void commit(StreamInfoItemExtractor extractor) throws ParsingException { |     @Override | ||||||
|  |     public void commit(StreamInfoItemExtractor extractor) { | ||||||
|         try { |         try { | ||||||
|             addItem(extract(extractor)); |             addItem(extract(extractor)); | ||||||
|         } catch (FoundAdException ae) { |         } catch (FoundAdException ae) { | ||||||
|  |  | ||||||
|  | @ -26,22 +26,6 @@ public class VideoStream extends Stream { | ||||||
|     public String resolution; |     public String resolution; | ||||||
|     public boolean isVideoOnly; |     public boolean isVideoOnly; | ||||||
| 
 | 
 | ||||||
|     /** |  | ||||||
|      * @deprecated use {@link VideoStream#VideoStream(String, MediaFormat, String)} |  | ||||||
|      */ |  | ||||||
|     @Deprecated |  | ||||||
|     public VideoStream(String url, int format, String res) { |  | ||||||
|         this(url, MediaFormat.getFormatById(format), res); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     /** |  | ||||||
|      * @deprecated use {@link VideoStream#VideoStream(String, MediaFormat, String, boolean)} |  | ||||||
|      */ |  | ||||||
|     @Deprecated |  | ||||||
|     public VideoStream(String url, int format, String res, boolean isVideoOnly) { |  | ||||||
|         this(url, MediaFormat.getFormatById(format), res, isVideoOnly); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
| 
 | 
 | ||||||
|     public VideoStream(String url, MediaFormat format, String resolution) { |     public VideoStream(String url, MediaFormat format, String resolution) { | ||||||
|         this(url, format, resolution, false); |         this(url, format, resolution, false); | ||||||
|  |  | ||||||
|  | @ -13,6 +13,9 @@ import org.schabi.newpipe.Downloader; | ||||||
| import org.schabi.newpipe.extractor.InfoItemCollector; | import org.schabi.newpipe.extractor.InfoItemCollector; | ||||||
| import org.schabi.newpipe.extractor.NewPipe; | import org.schabi.newpipe.extractor.NewPipe; | ||||||
| import org.schabi.newpipe.extractor.kiosk.KioskExtractor; | import org.schabi.newpipe.extractor.kiosk.KioskExtractor; | ||||||
|  | import org.schabi.newpipe.extractor.stream.StreamInfoItemCollector; | ||||||
|  | 
 | ||||||
|  | import java.util.List; | ||||||
| 
 | 
 | ||||||
| /** | /** | ||||||
|  * Test for {@link SoundcloudChartsUrlIdHandler} |  * Test for {@link SoundcloudChartsUrlIdHandler} | ||||||
|  | @ -48,10 +51,10 @@ public class SoundcloudChartsExtractorTest { | ||||||
| 
 | 
 | ||||||
|     @Test |     @Test | ||||||
|     public void testGetStreams() throws Exception { |     public void testGetStreams() throws Exception { | ||||||
|         InfoItemCollector collector = extractor.getStreams(); |         StreamInfoItemCollector collector = extractor.getStreams(); | ||||||
|         if(!collector.getErrors().isEmpty()) { |         if(!collector.getErrors().isEmpty()) { | ||||||
|             System.err.println("----------"); |             System.err.println("----------"); | ||||||
|             for(Throwable e : collector.getErrors()) { |             for(Throwable e: collector.getErrors()) { | ||||||
|                 e.printStackTrace(); |                 e.printStackTrace(); | ||||||
|                 System.err.println("----------"); |                 System.err.println("----------"); | ||||||
|             } |             } | ||||||
|  |  | ||||||
|  | @ -1,6 +1,7 @@ | ||||||
| package org.schabi.newpipe.extractor.services.youtube; | package org.schabi.newpipe.extractor.services.youtube; | ||||||
| 
 | 
 | ||||||
| import org.junit.Before; | import org.junit.Before; | ||||||
|  | import org.junit.BeforeClass; | ||||||
| import org.junit.Ignore; | import org.junit.Ignore; | ||||||
| import org.junit.Test; | import org.junit.Test; | ||||||
| import org.schabi.newpipe.Downloader; | import org.schabi.newpipe.Downloader; | ||||||
|  | @ -36,12 +37,12 @@ import static org.schabi.newpipe.extractor.ServiceList.YouTube; | ||||||
|  * Test for {@link SearchEngine} |  * Test for {@link SearchEngine} | ||||||
|  */ |  */ | ||||||
| public class YoutubeSearchEngineAllTest { | public class YoutubeSearchEngineAllTest { | ||||||
|     private SearchResult result; |     private static SearchResult result; | ||||||
| 
 | 
 | ||||||
|     @Before |     @BeforeClass | ||||||
|     public void setUp() throws Exception { |     public static void setUpClass() throws Exception { | ||||||
|         NewPipe.init(Downloader.getInstance()); |         NewPipe.init(Downloader.getInstance()); | ||||||
|         SearchEngine engine = YouTube.getService().getSearchEngine(); |         YoutubeSearchEngine engine = new YoutubeSearchEngine(1); | ||||||
| 
 | 
 | ||||||
|         // Youtube will suggest "asdf" instead of "asdgff" |         // Youtube will suggest "asdf" instead of "asdgff" | ||||||
|         // keep in mind that the suggestions can change by country (the parameter "de") |         // keep in mind that the suggestions can change by country (the parameter "de") | ||||||
|  | @ -51,19 +52,22 @@ public class YoutubeSearchEngineAllTest { | ||||||
| 
 | 
 | ||||||
|     @Test |     @Test | ||||||
|     public void testResultList() { |     public void testResultList() { | ||||||
|         assertFalse(result.resultList.isEmpty()); |         System.out.println("Results: " + result.getResults()); | ||||||
|  |         assertFalse("Results are empty: " + result.resultList, result.resultList.isEmpty()); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     @Test |     @Test | ||||||
|     public void testResultErrors() { |     public void testResultErrors() { | ||||||
|         if (!result.errors.isEmpty()) for (Throwable error : result.errors) error.printStackTrace(); |         for (Throwable error : result.getErrors()) { | ||||||
|         assertTrue(result.errors == null || result.errors.isEmpty()); |             error.printStackTrace(); | ||||||
|  |         } | ||||||
|  |         assertTrue(result.getErrors().isEmpty()); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     @Ignore |     @Ignore | ||||||
|     @Test |     @Test | ||||||
|     public void testSuggestion() { |     public void testSuggestion() { | ||||||
|         //todo write a real test |         //todo write a real test | ||||||
|         assertTrue(result.suggestion != null); |         assertTrue(result.getSuggestion() != null); | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  |  | ||||||
|  | @ -119,8 +119,8 @@ public class YoutubeStreamExtractorDefaultTest { | ||||||
|             assertTrue(s.url, |             assertTrue(s.url, | ||||||
|                     s.url.contains(HTTPS)); |                     s.url.contains(HTTPS)); | ||||||
|             assertTrue(s.resolution.length() > 0); |             assertTrue(s.resolution.length() > 0); | ||||||
|             assertTrue(Integer.toString(s.format), |             assertTrue(Integer.toString(s.getFormatId()), | ||||||
|                     0 <= s.format && s.format <= 4); |                     0 <= s.getFormatId() && s.getFormatId() <= 4); | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -98,11 +98,11 @@ public class YoutubeStreamExtractorRestrictedTest { | ||||||
|     @Test |     @Test | ||||||
|     public void testGetVideoStreams() throws IOException, ExtractionException { |     public void testGetVideoStreams() throws IOException, ExtractionException { | ||||||
|         for (VideoStream s : extractor.getVideoStreams()) { |         for (VideoStream s : extractor.getVideoStreams()) { | ||||||
|             assertTrue(s.url, |             assertTrue(s.getUrl(), | ||||||
|                     s.url.contains(HTTPS)); |                     s.getUrl().contains(HTTPS)); | ||||||
|             assertTrue(s.resolution.length() > 0); |             assertTrue(s.resolution.length() > 0); | ||||||
|             assertTrue(Integer.toString(s.format), |             assertTrue(Integer.toString(s.getFormatId()), | ||||||
|                     0 <= s.format && s.format <= 4); |                     0 <= s.getFormatId() && s.getFormatId() <= 4); | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -50,16 +50,16 @@ public class YoutubeTreindingKioskInfoTest { | ||||||
| 
 | 
 | ||||||
|     @Test |     @Test | ||||||
|     public void getStreams() { |     public void getStreams() { | ||||||
|         assertFalse(kioskInfo.related_streams.isEmpty()); |         assertFalse(kioskInfo.getRelatedStreams().isEmpty()); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     @Test |     @Test | ||||||
|     public void getId() { |     public void getId() { | ||||||
|         assertEquals(kioskInfo.id, "Trending"); |         assertEquals(kioskInfo.getId(), "Trending"); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     @Test |     @Test | ||||||
|     public void getName() { |     public void getName() { | ||||||
|         assertFalse(kioskInfo.name.isEmpty()); |         assertFalse(kioskInfo.getName().isEmpty()); | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  |  | ||||||
|  | @ -26,6 +26,7 @@ import org.schabi.newpipe.Downloader; | ||||||
| import org.schabi.newpipe.extractor.InfoItemCollector; | import org.schabi.newpipe.extractor.InfoItemCollector; | ||||||
| import org.schabi.newpipe.extractor.NewPipe; | import org.schabi.newpipe.extractor.NewPipe; | ||||||
| import org.schabi.newpipe.extractor.kiosk.KioskExtractor; | import org.schabi.newpipe.extractor.kiosk.KioskExtractor; | ||||||
|  | import org.schabi.newpipe.extractor.stream.StreamInfoItemCollector; | ||||||
| 
 | 
 | ||||||
| import static junit.framework.TestCase.assertFalse; | import static junit.framework.TestCase.assertFalse; | ||||||
| import static org.junit.Assert.assertEquals; | import static org.junit.Assert.assertEquals; | ||||||
|  | @ -67,7 +68,7 @@ public class YoutubeTrendingExtractorTest { | ||||||
| 
 | 
 | ||||||
|     @Test |     @Test | ||||||
|     public void testGetStreams() throws Exception { |     public void testGetStreams() throws Exception { | ||||||
|         InfoItemCollector collector = extractor.getStreams(); |         StreamInfoItemCollector collector = extractor.getStreams(); | ||||||
|         if(!collector.getErrors().isEmpty()) { |         if(!collector.getErrors().isEmpty()) { | ||||||
|             System.err.println("----------"); |             System.err.println("----------"); | ||||||
|             for(Throwable e : collector.getErrors()) { |             for(Throwable e : collector.getErrors()) { | ||||||
|  | @ -95,7 +96,7 @@ public class YoutubeTrendingExtractorTest { | ||||||
|     @Test |     @Test | ||||||
|     public void testGetNextStreams() throws Exception { |     public void testGetNextStreams() throws Exception { | ||||||
|         assertTrue("extractor has next streams", extractor.getNextStreams() == null |         assertTrue("extractor has next streams", extractor.getNextStreams() == null | ||||||
|                 || extractor.getNextStreams().nextItemsList.isEmpty()); |                 || extractor.getNextStreams().getNextItemsList().isEmpty()); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     @Test |     @Test | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue