mirror of
https://github.com/TeamNewPipe/NewPipeExtractor.git
synced 2024-12-14 14:20:33 +05:30
Introduce class that indicates when the time ago is an approximation
This commit is contained in:
parent
6ca4c8986a
commit
3d21ef5dba
@ -1,8 +1,9 @@
|
|||||||
package org.schabi.newpipe.extractor.comments;
|
package org.schabi.newpipe.extractor.comments;
|
||||||
|
|
||||||
import org.schabi.newpipe.extractor.InfoItem;
|
import org.schabi.newpipe.extractor.InfoItem;
|
||||||
|
import org.schabi.newpipe.extractor.localization.DateWrapper;
|
||||||
|
|
||||||
import java.util.Calendar;
|
import javax.annotation.Nullable;
|
||||||
|
|
||||||
public class CommentsInfoItem extends InfoItem {
|
public class CommentsInfoItem extends InfoItem {
|
||||||
|
|
||||||
@ -12,7 +13,7 @@ public class CommentsInfoItem extends InfoItem {
|
|||||||
private String authorThumbnail;
|
private String authorThumbnail;
|
||||||
private String authorEndpoint;
|
private String authorEndpoint;
|
||||||
private String textualPublishedTime;
|
private String textualPublishedTime;
|
||||||
private Calendar publishedTime;
|
@Nullable private DateWrapper publishedTime;
|
||||||
private int likeCount;
|
private int likeCount;
|
||||||
|
|
||||||
public CommentsInfoItem(int serviceId, String url, String name) {
|
public CommentsInfoItem(int serviceId, String url, String name) {
|
||||||
@ -67,11 +68,12 @@ public class CommentsInfoItem extends InfoItem {
|
|||||||
this.textualPublishedTime = textualPublishedTime;
|
this.textualPublishedTime = textualPublishedTime;
|
||||||
}
|
}
|
||||||
|
|
||||||
public Calendar getPublishedTime() {
|
@Nullable
|
||||||
|
public DateWrapper getPublishedTime() {
|
||||||
return publishedTime;
|
return publishedTime;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void setPublishedTime(Calendar publishedTime) {
|
public void setPublishedTime(@Nullable DateWrapper publishedTime) {
|
||||||
this.publishedTime = publishedTime;
|
this.publishedTime = publishedTime;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2,8 +2,9 @@ package org.schabi.newpipe.extractor.comments;
|
|||||||
|
|
||||||
import org.schabi.newpipe.extractor.InfoItemExtractor;
|
import org.schabi.newpipe.extractor.InfoItemExtractor;
|
||||||
import org.schabi.newpipe.extractor.exceptions.ParsingException;
|
import org.schabi.newpipe.extractor.exceptions.ParsingException;
|
||||||
|
import org.schabi.newpipe.extractor.localization.DateWrapper;
|
||||||
|
|
||||||
import java.util.Calendar;
|
import javax.annotation.Nullable;
|
||||||
|
|
||||||
public interface CommentsInfoItemExtractor extends InfoItemExtractor {
|
public interface CommentsInfoItemExtractor extends InfoItemExtractor {
|
||||||
String getCommentId() throws ParsingException;
|
String getCommentId() throws ParsingException;
|
||||||
@ -12,6 +13,7 @@ public interface CommentsInfoItemExtractor extends InfoItemExtractor {
|
|||||||
String getAuthorThumbnail() throws ParsingException;
|
String getAuthorThumbnail() throws ParsingException;
|
||||||
String getAuthorEndpoint() throws ParsingException;
|
String getAuthorEndpoint() throws ParsingException;
|
||||||
String getTextualPublishedTime() throws ParsingException;
|
String getTextualPublishedTime() throws ParsingException;
|
||||||
Calendar getPublishedTime() throws ParsingException;
|
@Nullable
|
||||||
|
DateWrapper getPublishedTime() throws ParsingException;
|
||||||
int getLikeCount() throws ParsingException;
|
int getLikeCount() throws ParsingException;
|
||||||
}
|
}
|
||||||
|
@ -0,0 +1,39 @@
|
|||||||
|
package org.schabi.newpipe.extractor.localization;
|
||||||
|
|
||||||
|
import edu.umd.cs.findbugs.annotations.NonNull;
|
||||||
|
|
||||||
|
import java.io.Serializable;
|
||||||
|
import java.util.Calendar;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* A wrapper class that provides a field to describe if the date is precise or just an approximation.
|
||||||
|
*/
|
||||||
|
public class DateWrapper implements Serializable {
|
||||||
|
@NonNull private final Calendar date;
|
||||||
|
private final boolean isApproximation;
|
||||||
|
|
||||||
|
public DateWrapper(@NonNull Calendar date) {
|
||||||
|
this(date, false);
|
||||||
|
}
|
||||||
|
|
||||||
|
public DateWrapper(@NonNull Calendar date, boolean isApproximation) {
|
||||||
|
this.date = date;
|
||||||
|
this.isApproximation = isApproximation;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return the wrapped date.
|
||||||
|
*/
|
||||||
|
@NonNull
|
||||||
|
public Calendar date() {
|
||||||
|
return date;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return if the date is considered is precise or just an approximation (e.g. service only returns an approximation
|
||||||
|
* like 2 weeks ago instead of a precise date).
|
||||||
|
*/
|
||||||
|
public boolean isApproximation() {
|
||||||
|
return isApproximation;
|
||||||
|
}
|
||||||
|
}
|
@ -31,15 +31,16 @@ public class TimeAgoParser {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Parses a textual date in the format '2 days ago' into a Calendar representation.
|
* Parses a textual date in the format '2 days ago' into a Calendar representation which is then wrapped in a
|
||||||
* Beginning with weeks ago, marks the date as approximated by setting minutes, seconds
|
* {@link DateWrapper} object.
|
||||||
* and milliseconds to 0.
|
* <p>
|
||||||
|
* Beginning with days ago, the date is considered as an approximation.
|
||||||
*
|
*
|
||||||
* @param textualDate The original date as provided by the streaming service
|
* @param textualDate The original date as provided by the streaming service
|
||||||
* @return The parsed (approximated) time
|
* @return The parsed time (can be approximated)
|
||||||
* @throws ParsingException if the time unit could not be recognized
|
* @throws ParsingException if the time unit could not be recognized
|
||||||
*/
|
*/
|
||||||
public Calendar parse(String textualDate) throws ParsingException {
|
public DateWrapper parse(String textualDate) throws ParsingException {
|
||||||
for (Map.Entry<TimeAgoUnit, Map<String, Integer>> caseUnitEntry : patternsHolder.specialCases().entrySet()) {
|
for (Map.Entry<TimeAgoUnit, Map<String, Integer>> caseUnitEntry : patternsHolder.specialCases().entrySet()) {
|
||||||
final TimeAgoUnit timeAgoUnit = caseUnitEntry.getKey();
|
final TimeAgoUnit timeAgoUnit = caseUnitEntry.getKey();
|
||||||
for (Map.Entry<String, Integer> caseMapToAmountEntry : caseUnitEntry.getValue().entrySet()) {
|
for (Map.Entry<String, Integer> caseMapToAmountEntry : caseUnitEntry.getValue().entrySet()) {
|
||||||
@ -47,7 +48,7 @@ public class TimeAgoParser {
|
|||||||
final Integer caseAmount = caseMapToAmountEntry.getValue();
|
final Integer caseAmount = caseMapToAmountEntry.getValue();
|
||||||
|
|
||||||
if (textualDateMatches(textualDate, caseText)) {
|
if (textualDateMatches(textualDate, caseText)) {
|
||||||
return getCalendar(caseAmount, timeAgoUnit);
|
return getResultFor(caseAmount, timeAgoUnit);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -61,8 +62,8 @@ public class TimeAgoParser {
|
|||||||
timeAgoAmount = 1;
|
timeAgoAmount = 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
TimeAgoUnit timeAgoUnit = parseTimeAgoUnit(textualDate);
|
final TimeAgoUnit timeAgoUnit = parseTimeAgoUnit(textualDate);
|
||||||
return getCalendar(timeAgoAmount, timeAgoUnit);
|
return getResultFor(timeAgoAmount, timeAgoUnit);
|
||||||
}
|
}
|
||||||
|
|
||||||
private int parseTimeAgoAmount(String textualDate) throws NumberFormatException {
|
private int parseTimeAgoAmount(String textualDate) throws NumberFormatException {
|
||||||
@ -110,8 +111,9 @@ public class TimeAgoParser {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private Calendar getCalendar(int timeAgoAmount, TimeAgoUnit timeAgoUnit) {
|
private DateWrapper getResultFor(int timeAgoAmount, TimeAgoUnit timeAgoUnit) {
|
||||||
Calendar calendarTime = getNow();
|
final Calendar calendarTime = getNow();
|
||||||
|
boolean isApproximation = false;
|
||||||
|
|
||||||
switch (timeAgoUnit) {
|
switch (timeAgoUnit) {
|
||||||
case SECONDS:
|
case SECONDS:
|
||||||
@ -128,28 +130,32 @@ public class TimeAgoParser {
|
|||||||
|
|
||||||
case DAYS:
|
case DAYS:
|
||||||
calendarTime.add(Calendar.DAY_OF_MONTH, -timeAgoAmount);
|
calendarTime.add(Calendar.DAY_OF_MONTH, -timeAgoAmount);
|
||||||
markApproximatedTime(calendarTime);
|
isApproximation = true;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case WEEKS:
|
case WEEKS:
|
||||||
calendarTime.add(Calendar.WEEK_OF_YEAR, -timeAgoAmount);
|
calendarTime.add(Calendar.WEEK_OF_YEAR, -timeAgoAmount);
|
||||||
markApproximatedTime(calendarTime);
|
isApproximation = true;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case MONTHS:
|
case MONTHS:
|
||||||
calendarTime.add(Calendar.MONTH, -timeAgoAmount);
|
calendarTime.add(Calendar.MONTH, -timeAgoAmount);
|
||||||
markApproximatedTime(calendarTime);
|
isApproximation = true;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case YEARS:
|
case YEARS:
|
||||||
calendarTime.add(Calendar.YEAR, -timeAgoAmount);
|
calendarTime.add(Calendar.YEAR, -timeAgoAmount);
|
||||||
// Prevent `PrettyTime` from showing '12 months ago'.
|
// Prevent `PrettyTime` from showing '12 months ago'.
|
||||||
calendarTime.add(Calendar.DAY_OF_MONTH, -1);
|
calendarTime.add(Calendar.DAY_OF_MONTH, -1);
|
||||||
markApproximatedTime(calendarTime);
|
isApproximation = true;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
return calendarTime;
|
if (isApproximation) {
|
||||||
|
markApproximatedTime(calendarTime);
|
||||||
|
}
|
||||||
|
|
||||||
|
return new DateWrapper(calendarTime, isApproximation);
|
||||||
}
|
}
|
||||||
|
|
||||||
private Calendar getNow() {
|
private Calendar getNow() {
|
||||||
|
@ -10,15 +10,12 @@ import org.schabi.newpipe.extractor.downloader.Downloader;
|
|||||||
import org.schabi.newpipe.extractor.exceptions.ExtractionException;
|
import org.schabi.newpipe.extractor.exceptions.ExtractionException;
|
||||||
import org.schabi.newpipe.extractor.exceptions.ParsingException;
|
import org.schabi.newpipe.extractor.exceptions.ParsingException;
|
||||||
import org.schabi.newpipe.extractor.linkhandler.LinkHandler;
|
import org.schabi.newpipe.extractor.linkhandler.LinkHandler;
|
||||||
|
import org.schabi.newpipe.extractor.localization.DateWrapper;
|
||||||
import org.schabi.newpipe.extractor.stream.*;
|
import org.schabi.newpipe.extractor.stream.*;
|
||||||
|
|
||||||
import javax.annotation.Nonnull;
|
import javax.annotation.Nonnull;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.text.ParseException;
|
|
||||||
import java.text.SimpleDateFormat;
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.Calendar;
|
|
||||||
import java.util.Date;
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
public class MediaCCCStreamExtractor extends StreamExtractor {
|
public class MediaCCCStreamExtractor extends StreamExtractor {
|
||||||
@ -38,8 +35,8 @@ public class MediaCCCStreamExtractor extends StreamExtractor {
|
|||||||
|
|
||||||
@Nonnull
|
@Nonnull
|
||||||
@Override
|
@Override
|
||||||
public Calendar getUploadDate() throws ParsingException {
|
public DateWrapper getUploadDate() throws ParsingException {
|
||||||
return MediaCCCParsingHelper.parseDateFrom(getTextualUploadDate());
|
return new DateWrapper(MediaCCCParsingHelper.parseDateFrom(getTextualUploadDate()));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Nonnull
|
@Nonnull
|
||||||
|
@ -2,11 +2,12 @@ package org.schabi.newpipe.extractor.services.media_ccc.extractors.infoItems;
|
|||||||
|
|
||||||
import com.grack.nanojson.JsonObject;
|
import com.grack.nanojson.JsonObject;
|
||||||
import org.schabi.newpipe.extractor.exceptions.ParsingException;
|
import org.schabi.newpipe.extractor.exceptions.ParsingException;
|
||||||
|
import org.schabi.newpipe.extractor.localization.DateWrapper;
|
||||||
import org.schabi.newpipe.extractor.services.media_ccc.extractors.MediaCCCParsingHelper;
|
import org.schabi.newpipe.extractor.services.media_ccc.extractors.MediaCCCParsingHelper;
|
||||||
import org.schabi.newpipe.extractor.stream.StreamInfoItemExtractor;
|
import org.schabi.newpipe.extractor.stream.StreamInfoItemExtractor;
|
||||||
import org.schabi.newpipe.extractor.stream.StreamType;
|
import org.schabi.newpipe.extractor.stream.StreamType;
|
||||||
|
|
||||||
import java.util.Calendar;
|
import javax.annotation.Nullable;
|
||||||
|
|
||||||
public class MediaCCCStreamInfoItemExtractor implements StreamInfoItemExtractor {
|
public class MediaCCCStreamInfoItemExtractor implements StreamInfoItemExtractor {
|
||||||
|
|
||||||
@ -47,14 +48,16 @@ public class MediaCCCStreamInfoItemExtractor implements StreamInfoItemExtractor
|
|||||||
return event.getString("conference_url");
|
return event.getString("conference_url");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Nullable
|
||||||
@Override
|
@Override
|
||||||
public String getTextualUploadDate() throws ParsingException {
|
public String getTextualUploadDate() throws ParsingException {
|
||||||
return event.getString("release_date");
|
return event.getString("release_date");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Nullable
|
||||||
@Override
|
@Override
|
||||||
public Calendar getUploadDate() throws ParsingException {
|
public DateWrapper getUploadDate() throws ParsingException {
|
||||||
return MediaCCCParsingHelper.parseDateFrom(getTextualUploadDate());
|
return new DateWrapper(MediaCCCParsingHelper.parseDateFrom(getTextualUploadDate()));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -9,15 +9,14 @@ import org.schabi.newpipe.extractor.exceptions.ContentNotAvailableException;
|
|||||||
import org.schabi.newpipe.extractor.exceptions.ExtractionException;
|
import org.schabi.newpipe.extractor.exceptions.ExtractionException;
|
||||||
import org.schabi.newpipe.extractor.exceptions.ParsingException;
|
import org.schabi.newpipe.extractor.exceptions.ParsingException;
|
||||||
import org.schabi.newpipe.extractor.linkhandler.LinkHandler;
|
import org.schabi.newpipe.extractor.linkhandler.LinkHandler;
|
||||||
|
import org.schabi.newpipe.extractor.localization.DateWrapper;
|
||||||
import org.schabi.newpipe.extractor.stream.*;
|
import org.schabi.newpipe.extractor.stream.*;
|
||||||
|
|
||||||
import javax.annotation.Nonnull;
|
import javax.annotation.Nonnull;
|
||||||
import javax.annotation.Nullable;
|
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.io.UnsupportedEncodingException;
|
import java.io.UnsupportedEncodingException;
|
||||||
import java.net.URLEncoder;
|
import java.net.URLEncoder;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.Calendar;
|
|
||||||
import java.util.Collections;
|
import java.util.Collections;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
@ -58,8 +57,8 @@ public class SoundcloudStreamExtractor extends StreamExtractor {
|
|||||||
|
|
||||||
@Nonnull
|
@Nonnull
|
||||||
@Override
|
@Override
|
||||||
public Calendar getUploadDate() throws ParsingException {
|
public DateWrapper getUploadDate() throws ParsingException {
|
||||||
return SoundcloudParsingHelper.parseDate(getTextualUploadDate());
|
return new DateWrapper(SoundcloudParsingHelper.parseDate(getTextualUploadDate()));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Nonnull
|
@Nonnull
|
||||||
|
@ -2,11 +2,10 @@ package org.schabi.newpipe.extractor.services.soundcloud;
|
|||||||
|
|
||||||
import com.grack.nanojson.JsonObject;
|
import com.grack.nanojson.JsonObject;
|
||||||
import org.schabi.newpipe.extractor.exceptions.ParsingException;
|
import org.schabi.newpipe.extractor.exceptions.ParsingException;
|
||||||
|
import org.schabi.newpipe.extractor.localization.DateWrapper;
|
||||||
import org.schabi.newpipe.extractor.stream.StreamInfoItemExtractor;
|
import org.schabi.newpipe.extractor.stream.StreamInfoItemExtractor;
|
||||||
import org.schabi.newpipe.extractor.stream.StreamType;
|
import org.schabi.newpipe.extractor.stream.StreamType;
|
||||||
|
|
||||||
import java.util.Calendar;
|
|
||||||
|
|
||||||
import static org.schabi.newpipe.extractor.utils.Utils.replaceHttpWithHttps;
|
import static org.schabi.newpipe.extractor.utils.Utils.replaceHttpWithHttps;
|
||||||
|
|
||||||
public class SoundcloudStreamInfoItemExtractor implements StreamInfoItemExtractor {
|
public class SoundcloudStreamInfoItemExtractor implements StreamInfoItemExtractor {
|
||||||
@ -48,8 +47,8 @@ public class SoundcloudStreamInfoItemExtractor implements StreamInfoItemExtracto
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Calendar getUploadDate() throws ParsingException {
|
public DateWrapper getUploadDate() throws ParsingException {
|
||||||
return SoundcloudParsingHelper.parseDate(getTextualUploadDate());
|
return new DateWrapper(SoundcloudParsingHelper.parseDate(getTextualUploadDate()));
|
||||||
}
|
}
|
||||||
|
|
||||||
private String getCreatedAt() {
|
private String getCreatedAt() {
|
||||||
|
@ -5,10 +5,11 @@ import com.grack.nanojson.JsonObject;
|
|||||||
import org.schabi.newpipe.extractor.comments.CommentsInfoItemExtractor;
|
import org.schabi.newpipe.extractor.comments.CommentsInfoItemExtractor;
|
||||||
import org.schabi.newpipe.extractor.exceptions.ParsingException;
|
import org.schabi.newpipe.extractor.exceptions.ParsingException;
|
||||||
import org.schabi.newpipe.extractor.localization.TimeAgoParser;
|
import org.schabi.newpipe.extractor.localization.TimeAgoParser;
|
||||||
|
import org.schabi.newpipe.extractor.localization.DateWrapper;
|
||||||
import org.schabi.newpipe.extractor.utils.JsonUtils;
|
import org.schabi.newpipe.extractor.utils.JsonUtils;
|
||||||
import org.schabi.newpipe.extractor.utils.Utils;
|
import org.schabi.newpipe.extractor.utils.Utils;
|
||||||
|
|
||||||
import java.util.Calendar;
|
import javax.annotation.Nullable;
|
||||||
|
|
||||||
public class YoutubeCommentsInfoItemExtractor implements CommentsInfoItemExtractor {
|
public class YoutubeCommentsInfoItemExtractor implements CommentsInfoItemExtractor {
|
||||||
|
|
||||||
@ -55,8 +56,9 @@ public class YoutubeCommentsInfoItemExtractor implements CommentsInfoItemExtract
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Nullable
|
||||||
@Override
|
@Override
|
||||||
public Calendar getPublishedTime() throws ParsingException {
|
public DateWrapper getPublishedTime() throws ParsingException {
|
||||||
String textualPublishedTime = getTextualPublishedTime();
|
String textualPublishedTime = getTextualPublishedTime();
|
||||||
if (timeAgoParser != null && textualPublishedTime != null && !textualPublishedTime.isEmpty()) {
|
if (timeAgoParser != null && textualPublishedTime != null && !textualPublishedTime.isEmpty()) {
|
||||||
return timeAgoParser.parse(textualPublishedTime);
|
return timeAgoParser.parse(textualPublishedTime);
|
||||||
|
@ -23,6 +23,7 @@ import org.schabi.newpipe.extractor.exceptions.ParsingException;
|
|||||||
import org.schabi.newpipe.extractor.exceptions.ReCaptchaException;
|
import org.schabi.newpipe.extractor.exceptions.ReCaptchaException;
|
||||||
import org.schabi.newpipe.extractor.linkhandler.LinkHandler;
|
import org.schabi.newpipe.extractor.linkhandler.LinkHandler;
|
||||||
import org.schabi.newpipe.extractor.localization.TimeAgoParser;
|
import org.schabi.newpipe.extractor.localization.TimeAgoParser;
|
||||||
|
import org.schabi.newpipe.extractor.localization.DateWrapper;
|
||||||
import org.schabi.newpipe.extractor.services.youtube.ItagItem;
|
import org.schabi.newpipe.extractor.services.youtube.ItagItem;
|
||||||
import org.schabi.newpipe.extractor.services.youtube.linkHandler.YoutubeParsingHelper;
|
import org.schabi.newpipe.extractor.services.youtube.linkHandler.YoutubeParsingHelper;
|
||||||
import org.schabi.newpipe.extractor.stream.*;
|
import org.schabi.newpipe.extractor.stream.*;
|
||||||
@ -134,14 +135,14 @@ public class YoutubeStreamExtractor extends StreamExtractor {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Calendar getUploadDate() throws ParsingException {
|
public DateWrapper getUploadDate() throws ParsingException {
|
||||||
final String textualUploadDate = getTextualUploadDate();
|
final String textualUploadDate = getTextualUploadDate();
|
||||||
|
|
||||||
if (textualUploadDate == null) {
|
if (textualUploadDate == null) {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
return YoutubeParsingHelper.parseDateFrom(textualUploadDate);
|
return new DateWrapper(YoutubeParsingHelper.parseDateFrom(textualUploadDate));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Nonnull
|
@Nonnull
|
||||||
|
@ -4,6 +4,7 @@ import org.jsoup.nodes.Element;
|
|||||||
import org.jsoup.select.Elements;
|
import org.jsoup.select.Elements;
|
||||||
import org.schabi.newpipe.extractor.exceptions.ParsingException;
|
import org.schabi.newpipe.extractor.exceptions.ParsingException;
|
||||||
import org.schabi.newpipe.extractor.localization.TimeAgoParser;
|
import org.schabi.newpipe.extractor.localization.TimeAgoParser;
|
||||||
|
import org.schabi.newpipe.extractor.localization.DateWrapper;
|
||||||
import org.schabi.newpipe.extractor.services.youtube.linkHandler.YoutubeParsingHelper;
|
import org.schabi.newpipe.extractor.services.youtube.linkHandler.YoutubeParsingHelper;
|
||||||
import org.schabi.newpipe.extractor.stream.StreamInfoItemExtractor;
|
import org.schabi.newpipe.extractor.stream.StreamInfoItemExtractor;
|
||||||
import org.schabi.newpipe.extractor.stream.StreamType;
|
import org.schabi.newpipe.extractor.stream.StreamType;
|
||||||
@ -141,6 +142,7 @@ public class YoutubeStreamInfoItemExtractor implements StreamInfoItemExtractor {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Nullable
|
||||||
@Override
|
@Override
|
||||||
public String getTextualUploadDate() throws ParsingException {
|
public String getTextualUploadDate() throws ParsingException {
|
||||||
if (getStreamType().equals(StreamType.LIVE_STREAM)) {
|
if (getStreamType().equals(StreamType.LIVE_STREAM)) {
|
||||||
@ -173,17 +175,15 @@ public class YoutubeStreamInfoItemExtractor implements StreamInfoItemExtractor {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Nullable
|
||||||
@Override
|
@Override
|
||||||
public Calendar getUploadDate() throws ParsingException {
|
public DateWrapper getUploadDate() throws ParsingException {
|
||||||
if (getStreamType().equals(StreamType.LIVE_STREAM)) {
|
if (getStreamType().equals(StreamType.LIVE_STREAM)) {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (isVideoReminder()) {
|
if (isVideoReminder()) {
|
||||||
final Calendar calendar = getDateFromReminder();
|
return new DateWrapper(getDateFromReminder());
|
||||||
if (calendar != null) {
|
|
||||||
return calendar;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
String textualUploadDate = getTextualUploadDate();
|
String textualUploadDate = getTextualUploadDate();
|
||||||
|
@ -26,13 +26,12 @@ import org.schabi.newpipe.extractor.StreamingService;
|
|||||||
import org.schabi.newpipe.extractor.exceptions.ExtractionException;
|
import org.schabi.newpipe.extractor.exceptions.ExtractionException;
|
||||||
import org.schabi.newpipe.extractor.exceptions.ParsingException;
|
import org.schabi.newpipe.extractor.exceptions.ParsingException;
|
||||||
import org.schabi.newpipe.extractor.linkhandler.LinkHandler;
|
import org.schabi.newpipe.extractor.linkhandler.LinkHandler;
|
||||||
|
import org.schabi.newpipe.extractor.localization.DateWrapper;
|
||||||
import org.schabi.newpipe.extractor.utils.Parser;
|
import org.schabi.newpipe.extractor.utils.Parser;
|
||||||
|
|
||||||
import javax.annotation.Nonnull;
|
import javax.annotation.Nonnull;
|
||||||
import javax.annotation.Nullable;
|
import javax.annotation.Nullable;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.util.ArrayList;
|
|
||||||
import java.util.Calendar;
|
|
||||||
import java.util.Collections;
|
import java.util.Collections;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
@ -72,7 +71,7 @@ public abstract class StreamExtractor extends Extractor {
|
|||||||
* @see #getTextualUploadDate()
|
* @see #getTextualUploadDate()
|
||||||
*/
|
*/
|
||||||
@Nullable
|
@Nullable
|
||||||
public abstract Calendar getUploadDate() throws ParsingException;
|
public abstract DateWrapper getUploadDate() throws ParsingException;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* This will return the url to the thumbnail of the stream. Try to return the medium resolution here.
|
* This will return the url to the thumbnail of the stream. Try to return the medium resolution here.
|
||||||
|
@ -1,19 +1,19 @@
|
|||||||
package org.schabi.newpipe.extractor.stream;
|
package org.schabi.newpipe.extractor.stream;
|
||||||
|
|
||||||
import java.io.IOException;
|
|
||||||
import java.util.ArrayList;
|
|
||||||
import java.util.Calendar;
|
|
||||||
import java.util.List;
|
|
||||||
|
|
||||||
import org.schabi.newpipe.extractor.Info;
|
import org.schabi.newpipe.extractor.Info;
|
||||||
import org.schabi.newpipe.extractor.InfoItem;
|
import org.schabi.newpipe.extractor.InfoItem;
|
||||||
import org.schabi.newpipe.extractor.NewPipe;
|
import org.schabi.newpipe.extractor.NewPipe;
|
||||||
import org.schabi.newpipe.extractor.StreamingService;
|
import org.schabi.newpipe.extractor.StreamingService;
|
||||||
import org.schabi.newpipe.extractor.exceptions.ContentNotAvailableException;
|
import org.schabi.newpipe.extractor.exceptions.ContentNotAvailableException;
|
||||||
import org.schabi.newpipe.extractor.exceptions.ExtractionException;
|
import org.schabi.newpipe.extractor.exceptions.ExtractionException;
|
||||||
|
import org.schabi.newpipe.extractor.localization.DateWrapper;
|
||||||
import org.schabi.newpipe.extractor.utils.DashMpdParser;
|
import org.schabi.newpipe.extractor.utils.DashMpdParser;
|
||||||
import org.schabi.newpipe.extractor.utils.ExtractorHelper;
|
import org.schabi.newpipe.extractor.utils.ExtractorHelper;
|
||||||
|
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Created by Christian Schabesberger on 26.08.15.
|
* Created by Christian Schabesberger on 26.08.15.
|
||||||
*
|
*
|
||||||
@ -278,7 +278,7 @@ public class StreamInfo extends Info {
|
|||||||
private StreamType streamType;
|
private StreamType streamType;
|
||||||
private String thumbnailUrl = "";
|
private String thumbnailUrl = "";
|
||||||
private String textualUploadDate;
|
private String textualUploadDate;
|
||||||
private Calendar uploadDate;
|
private DateWrapper uploadDate;
|
||||||
private long duration = -1;
|
private long duration = -1;
|
||||||
private int ageLimit = -1;
|
private int ageLimit = -1;
|
||||||
private String description;
|
private String description;
|
||||||
@ -342,11 +342,11 @@ public class StreamInfo extends Info {
|
|||||||
this.textualUploadDate = textualUploadDate;
|
this.textualUploadDate = textualUploadDate;
|
||||||
}
|
}
|
||||||
|
|
||||||
public Calendar getUploadDate() {
|
public DateWrapper getUploadDate() {
|
||||||
return uploadDate;
|
return uploadDate;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void setUploadDate(Calendar uploadDate) {
|
public void setUploadDate(DateWrapper uploadDate) {
|
||||||
this.uploadDate = uploadDate;
|
this.uploadDate = uploadDate;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -21,9 +21,9 @@ package org.schabi.newpipe.extractor.stream;
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
import org.schabi.newpipe.extractor.InfoItem;
|
import org.schabi.newpipe.extractor.InfoItem;
|
||||||
|
import org.schabi.newpipe.extractor.localization.DateWrapper;
|
||||||
|
|
||||||
import javax.annotation.Nullable;
|
import javax.annotation.Nullable;
|
||||||
import java.util.Calendar;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Info object for previews of unopened videos, eg search results, related videos
|
* Info object for previews of unopened videos, eg search results, related videos
|
||||||
@ -33,7 +33,7 @@ public class StreamInfoItem extends InfoItem {
|
|||||||
|
|
||||||
private String uploaderName;
|
private String uploaderName;
|
||||||
private String textualUploadDate;
|
private String textualUploadDate;
|
||||||
private Calendar uploadDate;
|
@Nullable private DateWrapper uploadDate;
|
||||||
private long viewCount = -1;
|
private long viewCount = -1;
|
||||||
private long duration = -1;
|
private long duration = -1;
|
||||||
|
|
||||||
@ -80,10 +80,6 @@ public class StreamInfoItem extends InfoItem {
|
|||||||
this.uploaderUrl = uploaderUrl;
|
this.uploaderUrl = uploaderUrl;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* @return The original textual upload date as returned by the streaming service.
|
|
||||||
* @see #getUploadDate()
|
|
||||||
*/
|
|
||||||
@Nullable
|
@Nullable
|
||||||
public String getTextualUploadDate() {
|
public String getTextualUploadDate() {
|
||||||
return textualUploadDate;
|
return textualUploadDate;
|
||||||
@ -93,16 +89,12 @@ public class StreamInfoItem extends InfoItem {
|
|||||||
this.textualUploadDate = uploadDate;
|
this.textualUploadDate = uploadDate;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* @return The (approximated) date and time this item was uploaded or {@code null}.
|
|
||||||
* @see #getTextualUploadDate()
|
|
||||||
*/
|
|
||||||
@Nullable
|
@Nullable
|
||||||
public Calendar getUploadDate() {
|
public DateWrapper getUploadDate() {
|
||||||
return uploadDate;
|
return uploadDate;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void setUploadDate(Calendar uploadDate) {
|
public void setUploadDate(@Nullable DateWrapper uploadDate) {
|
||||||
this.uploadDate = uploadDate;
|
this.uploadDate = uploadDate;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2,8 +2,9 @@ package org.schabi.newpipe.extractor.stream;
|
|||||||
|
|
||||||
import org.schabi.newpipe.extractor.InfoItemExtractor;
|
import org.schabi.newpipe.extractor.InfoItemExtractor;
|
||||||
import org.schabi.newpipe.extractor.exceptions.ParsingException;
|
import org.schabi.newpipe.extractor.exceptions.ParsingException;
|
||||||
|
import org.schabi.newpipe.extractor.localization.DateWrapper;
|
||||||
|
|
||||||
import java.util.Calendar;
|
import javax.annotation.Nullable;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Created by Christian Schabesberger on 28.02.16.
|
* Created by Christian Schabesberger on 28.02.16.
|
||||||
@ -69,26 +70,27 @@ public interface StreamInfoItemExtractor extends InfoItemExtractor {
|
|||||||
* The original textual date provided by the service. Should be used as a fallback if
|
* The original textual date provided by the service. Should be used as a fallback if
|
||||||
* {@link #getUploadDate()} isn't provided by the service, or it fails for some reason.
|
* {@link #getUploadDate()} isn't provided by the service, or it fails for some reason.
|
||||||
*
|
*
|
||||||
* @return The original textual date provided by the service.
|
* @return The original textual date provided by the service or {@code null} if not provided.
|
||||||
* @throws ParsingException if there is an error in the extraction
|
* @throws ParsingException if there is an error in the extraction
|
||||||
* @see #getUploadDate()
|
* @see #getUploadDate()
|
||||||
*/
|
*/
|
||||||
|
@Nullable
|
||||||
String getTextualUploadDate() throws ParsingException;
|
String getTextualUploadDate() throws ParsingException;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Extracts the upload date and time of this item and parses it.
|
* Extracts the upload date and time of this item and parses it.
|
||||||
* <p>
|
* <p>
|
||||||
* If the service doesn't provide an exact time, an approximation can be returned.
|
* If the service doesn't provide an exact time, an approximation can be returned.
|
||||||
* The approximation should be marked by setting seconds and milliseconds to zero.
|
|
||||||
* <br>
|
* <br>
|
||||||
* If the service doesn't provide any date at all, then {@code null} should be returned.
|
* If the service doesn't provide any date at all, then {@code null} should be returned.
|
||||||
* </p>
|
* </p>
|
||||||
*
|
*
|
||||||
* @return The (approximated) date and time this item was uploaded or {@code null}.
|
* @return The date and time (can be approximated) this item was uploaded or {@code null}.
|
||||||
* @throws ParsingException if there is an error in the extraction
|
* @throws ParsingException if there is an error in the extraction
|
||||||
* or the extracted date couldn't be parsed.
|
* or the extracted date couldn't be parsed.
|
||||||
* @see #getTextualUploadDate()
|
* @see #getTextualUploadDate()
|
||||||
*/
|
*/
|
||||||
Calendar getUploadDate() throws ParsingException;
|
@Nullable
|
||||||
|
DateWrapper getUploadDate() throws ParsingException;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -2,6 +2,7 @@ package org.schabi.newpipe.extractor.services;
|
|||||||
|
|
||||||
import org.schabi.newpipe.extractor.InfoItem;
|
import org.schabi.newpipe.extractor.InfoItem;
|
||||||
import org.schabi.newpipe.extractor.ListExtractor;
|
import org.schabi.newpipe.extractor.ListExtractor;
|
||||||
|
import org.schabi.newpipe.extractor.localization.DateWrapper;
|
||||||
import org.schabi.newpipe.extractor.stream.StreamInfoItem;
|
import org.schabi.newpipe.extractor.stream.StreamInfoItem;
|
||||||
|
|
||||||
import java.util.Calendar;
|
import java.util.Calendar;
|
||||||
@ -31,9 +32,9 @@ public final class DefaultTests {
|
|||||||
|
|
||||||
final String textualUploadDate = streamInfoItem.getTextualUploadDate();
|
final String textualUploadDate = streamInfoItem.getTextualUploadDate();
|
||||||
if (textualUploadDate != null && !textualUploadDate.isEmpty()) {
|
if (textualUploadDate != null && !textualUploadDate.isEmpty()) {
|
||||||
final Calendar uploadDate = streamInfoItem.getUploadDate();
|
final DateWrapper uploadDate = streamInfoItem.getUploadDate();
|
||||||
assertNotNull("No parsed upload date", uploadDate);
|
assertNotNull("No parsed upload date", uploadDate);
|
||||||
assertTrue("Upload date not in the past", uploadDate.before(Calendar.getInstance()));
|
assertTrue("Upload date not in the past", uploadDate.date().before(Calendar.getInstance()));
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -14,6 +14,7 @@ import java.text.ParseException;
|
|||||||
import java.text.SimpleDateFormat;
|
import java.text.SimpleDateFormat;
|
||||||
import java.util.Calendar;
|
import java.util.Calendar;
|
||||||
|
|
||||||
|
import static java.util.Objects.requireNonNull;
|
||||||
import static junit.framework.TestCase.assertEquals;
|
import static junit.framework.TestCase.assertEquals;
|
||||||
import static org.schabi.newpipe.extractor.ServiceList.MediaCCC;
|
import static org.schabi.newpipe.extractor.ServiceList.MediaCCC;
|
||||||
|
|
||||||
@ -95,6 +96,6 @@ public class MediaCCCStreamExtractorTest implements BaseExtractorTest {
|
|||||||
public void testGetUploadDate() throws ParsingException, ParseException {
|
public void testGetUploadDate() throws ParsingException, ParseException {
|
||||||
final Calendar instance = Calendar.getInstance();
|
final Calendar instance = Calendar.getInstance();
|
||||||
instance.setTime(new SimpleDateFormat("yyyy-MM-dd").parse("2018-05-11"));
|
instance.setTime(new SimpleDateFormat("yyyy-MM-dd").parse("2018-05-11"));
|
||||||
Assert.assertEquals(instance, extractor.getUploadDate());
|
assertEquals(instance, requireNonNull(extractor.getUploadDate()).date());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -16,6 +16,7 @@ import java.text.ParseException;
|
|||||||
import java.text.SimpleDateFormat;
|
import java.text.SimpleDateFormat;
|
||||||
import java.util.Calendar;
|
import java.util.Calendar;
|
||||||
|
|
||||||
|
import static java.util.Objects.requireNonNull;
|
||||||
import static org.junit.Assert.*;
|
import static org.junit.Assert.*;
|
||||||
import static org.schabi.newpipe.extractor.ExtractorAsserts.assertIsSecureUrl;
|
import static org.schabi.newpipe.extractor.ExtractorAsserts.assertIsSecureUrl;
|
||||||
import static org.schabi.newpipe.extractor.ServiceList.SoundCloud;
|
import static org.schabi.newpipe.extractor.ServiceList.SoundCloud;
|
||||||
@ -80,7 +81,7 @@ public class SoundcloudStreamExtractorDefaultTest {
|
|||||||
public void testGetUploadDate() throws ParsingException, ParseException {
|
public void testGetUploadDate() throws ParsingException, ParseException {
|
||||||
final Calendar instance = Calendar.getInstance();
|
final Calendar instance = Calendar.getInstance();
|
||||||
instance.setTime(new SimpleDateFormat("yyyy/MM/dd HH:mm:ss +0000").parse("2016/07/31 18:18:07 +0000"));
|
instance.setTime(new SimpleDateFormat("yyyy/MM/dd HH:mm:ss +0000").parse("2016/07/31 18:18:07 +0000"));
|
||||||
Assert.assertEquals(instance, extractor.getUploadDate());
|
assertEquals(instance, requireNonNull(extractor.getUploadDate()).date());
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
|
@ -7,6 +7,7 @@ import org.schabi.newpipe.extractor.ListExtractor;
|
|||||||
import org.schabi.newpipe.extractor.NewPipe;
|
import org.schabi.newpipe.extractor.NewPipe;
|
||||||
import org.schabi.newpipe.extractor.channel.ChannelExtractor;
|
import org.schabi.newpipe.extractor.channel.ChannelExtractor;
|
||||||
import org.schabi.newpipe.extractor.localization.Localization;
|
import org.schabi.newpipe.extractor.localization.Localization;
|
||||||
|
import org.schabi.newpipe.extractor.localization.DateWrapper;
|
||||||
import org.schabi.newpipe.extractor.stream.StreamInfoItem;
|
import org.schabi.newpipe.extractor.stream.StreamInfoItem;
|
||||||
|
|
||||||
import java.text.SimpleDateFormat;
|
import java.text.SimpleDateFormat;
|
||||||
@ -61,9 +62,9 @@ public class YoutubeChannelLocalizationTest {
|
|||||||
String debugMessage = "[" + String.format("%02d", i) + "] "
|
String debugMessage = "[" + String.format("%02d", i) + "] "
|
||||||
+ currentLocalization.getLocalizationCode() + " → " + item.getName()
|
+ currentLocalization.getLocalizationCode() + " → " + item.getName()
|
||||||
+ "\n:::: " + item.getStreamType() + ", views = " + item.getViewCount();
|
+ "\n:::: " + item.getStreamType() + ", views = " + item.getViewCount();
|
||||||
final Calendar uploadDate = item.getUploadDate();
|
final DateWrapper uploadDate = item.getUploadDate();
|
||||||
if (uploadDate != null) {
|
if (uploadDate != null) {
|
||||||
String dateAsText = dateFormat.format(uploadDate.getTime());
|
String dateAsText = dateFormat.format(uploadDate.date().getTime());
|
||||||
debugMessage += "\n:::: " + item.getTextualUploadDate() +
|
debugMessage += "\n:::: " + item.getTextualUploadDate() +
|
||||||
"\n:::: " + dateAsText;
|
"\n:::: " + dateAsText;
|
||||||
}
|
}
|
||||||
@ -102,17 +103,17 @@ public class YoutubeChannelLocalizationTest {
|
|||||||
final StreamInfoItem referenceItem = referenceList.get(i);
|
final StreamInfoItem referenceItem = referenceList.get(i);
|
||||||
final StreamInfoItem currentItem = currentList.get(i);
|
final StreamInfoItem currentItem = currentList.get(i);
|
||||||
|
|
||||||
final Calendar referenceUploadDate = referenceItem.getUploadDate();
|
final DateWrapper referenceUploadDate = referenceItem.getUploadDate();
|
||||||
final Calendar currentUploadDate = currentItem.getUploadDate();
|
final DateWrapper currentUploadDate = currentItem.getUploadDate();
|
||||||
|
|
||||||
final String referenceDateString = referenceUploadDate == null ? "null" :
|
final String referenceDateString = referenceUploadDate == null ? "null" :
|
||||||
dateFormat.format(referenceUploadDate.getTime());
|
dateFormat.format(referenceUploadDate.date().getTime());
|
||||||
final String currentDateString = currentUploadDate == null ? "null" :
|
final String currentDateString = currentUploadDate == null ? "null" :
|
||||||
dateFormat.format(currentUploadDate.getTime());
|
dateFormat.format(currentUploadDate.date().getTime());
|
||||||
|
|
||||||
long difference = -1;
|
long difference = -1;
|
||||||
if (referenceUploadDate != null && currentUploadDate != null) {
|
if (referenceUploadDate != null && currentUploadDate != null) {
|
||||||
difference = Math.abs(referenceUploadDate.getTimeInMillis() - currentUploadDate.getTimeInMillis());
|
difference = Math.abs(referenceUploadDate.date().getTimeInMillis() - currentUploadDate.date().getTimeInMillis());
|
||||||
}
|
}
|
||||||
|
|
||||||
final boolean areTimeEquals = difference < 5 * 60 * 1000L;
|
final boolean areTimeEquals = difference < 5 * 60 * 1000L;
|
||||||
|
@ -1,7 +1,6 @@
|
|||||||
package org.schabi.newpipe.extractor.services.youtube.stream;
|
package org.schabi.newpipe.extractor.services.youtube.stream;
|
||||||
|
|
||||||
import org.junit.BeforeClass;
|
import org.junit.BeforeClass;
|
||||||
import org.junit.Ignore;
|
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
import org.schabi.newpipe.DownloaderTestImpl;
|
import org.schabi.newpipe.DownloaderTestImpl;
|
||||||
import org.schabi.newpipe.extractor.MediaFormat;
|
import org.schabi.newpipe.extractor.MediaFormat;
|
||||||
@ -18,9 +17,9 @@ import java.text.ParseException;
|
|||||||
import java.text.SimpleDateFormat;
|
import java.text.SimpleDateFormat;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.Calendar;
|
import java.util.Calendar;
|
||||||
import java.util.Date;
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
|
import static java.util.Objects.requireNonNull;
|
||||||
import static org.junit.Assert.*;
|
import static org.junit.Assert.*;
|
||||||
import static org.schabi.newpipe.extractor.ExtractorAsserts.assertIsSecureUrl;
|
import static org.schabi.newpipe.extractor.ExtractorAsserts.assertIsSecureUrl;
|
||||||
import static org.schabi.newpipe.extractor.ServiceList.YouTube;
|
import static org.schabi.newpipe.extractor.ServiceList.YouTube;
|
||||||
@ -93,7 +92,7 @@ public class YoutubeStreamExtractorAgeRestrictedTest {
|
|||||||
public void testGetUploadDate() throws ParsingException, ParseException {
|
public void testGetUploadDate() throws ParsingException, ParseException {
|
||||||
final Calendar instance = Calendar.getInstance();
|
final Calendar instance = Calendar.getInstance();
|
||||||
instance.setTime(new SimpleDateFormat("yyyy-MM-dd").parse("2017-01-25"));
|
instance.setTime(new SimpleDateFormat("yyyy-MM-dd").parse("2017-01-25"));
|
||||||
assertEquals(instance, extractor.getUploadDate());
|
assertEquals(instance, requireNonNull(extractor.getUploadDate()).date());
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
|
@ -20,6 +20,7 @@ import java.util.ArrayList;
|
|||||||
import java.util.Calendar;
|
import java.util.Calendar;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
|
import static java.util.Objects.requireNonNull;
|
||||||
import static org.junit.Assert.*;
|
import static org.junit.Assert.*;
|
||||||
import static org.schabi.newpipe.extractor.ExtractorAsserts.assertIsSecureUrl;
|
import static org.schabi.newpipe.extractor.ExtractorAsserts.assertIsSecureUrl;
|
||||||
import static org.schabi.newpipe.extractor.ServiceList.YouTube;
|
import static org.schabi.newpipe.extractor.ServiceList.YouTube;
|
||||||
@ -92,7 +93,7 @@ public class YoutubeStreamExtractorControversialTest {
|
|||||||
public void testGetUploadDate() throws ParsingException, ParseException {
|
public void testGetUploadDate() throws ParsingException, ParseException {
|
||||||
final Calendar instance = Calendar.getInstance();
|
final Calendar instance = Calendar.getInstance();
|
||||||
instance.setTime(new SimpleDateFormat("yyyy-MM-dd").parse("2010-09-09"));
|
instance.setTime(new SimpleDateFormat("yyyy-MM-dd").parse("2010-09-09"));
|
||||||
assertEquals(instance, extractor.getUploadDate());
|
assertEquals(instance, requireNonNull(extractor.getUploadDate()).date());
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
|
@ -17,9 +17,9 @@ import java.io.IOException;
|
|||||||
import java.text.ParseException;
|
import java.text.ParseException;
|
||||||
import java.text.SimpleDateFormat;
|
import java.text.SimpleDateFormat;
|
||||||
import java.util.Calendar;
|
import java.util.Calendar;
|
||||||
import java.util.Date;
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
|
import static java.util.Objects.*;
|
||||||
import static org.junit.Assert.*;
|
import static org.junit.Assert.*;
|
||||||
import static org.schabi.newpipe.extractor.ExtractorAsserts.assertIsSecureUrl;
|
import static org.schabi.newpipe.extractor.ExtractorAsserts.assertIsSecureUrl;
|
||||||
import static org.schabi.newpipe.extractor.ServiceList.YouTube;
|
import static org.schabi.newpipe.extractor.ServiceList.YouTube;
|
||||||
@ -119,7 +119,7 @@ public class YoutubeStreamExtractorDefaultTest {
|
|||||||
public void testGetUploadDate() throws ParsingException, ParseException {
|
public void testGetUploadDate() throws ParsingException, ParseException {
|
||||||
final Calendar instance = Calendar.getInstance();
|
final Calendar instance = Calendar.getInstance();
|
||||||
instance.setTime(new SimpleDateFormat("yyyy-MM-dd").parse("2015-10-22"));
|
instance.setTime(new SimpleDateFormat("yyyy-MM-dd").parse("2015-10-22"));
|
||||||
Assert.assertEquals(instance, extractor.getUploadDate());
|
assertEquals(instance, requireNonNull(extractor.getUploadDate()).date());
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
|
Loading…
Reference in New Issue
Block a user