mirror of
https://github.com/TeamNewPipe/NewPipeExtractor.git
synced 2024-12-14 06:10:33 +05:30
[PeerTube] Parse timestamp from url (previously unimplemented)
This commit is contained in:
parent
7ae3cb6d07
commit
aeeae87641
@ -112,9 +112,16 @@ public class PeertubeStreamExtractor extends StreamExtractor {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public long getTimeStamp() {
|
public long getTimeStamp() throws ParsingException {
|
||||||
//TODO fetch timestamp from url if present;
|
long timestamp =
|
||||||
return 0;
|
getTimestampSeconds("((#|&|\\?)start=\\d{0,3}h?\\d{0,3}m?\\d{1,3}s?)");
|
||||||
|
|
||||||
|
if (timestamp == -2) {
|
||||||
|
// regex for timestamp was not found
|
||||||
|
return 0;
|
||||||
|
} else {
|
||||||
|
return timestamp;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -27,7 +27,9 @@ public class PeertubeStreamExtractorTest {
|
|||||||
public static class WhatIsPeertube extends DefaultStreamExtractorTest {
|
public static class WhatIsPeertube extends DefaultStreamExtractorTest {
|
||||||
private static final String ID = "9c9de5e8-0a1e-484a-b099-e80766180a6d";
|
private static final String ID = "9c9de5e8-0a1e-484a-b099-e80766180a6d";
|
||||||
private static final String INSTANCE = "https://framatube.org";
|
private static final String INSTANCE = "https://framatube.org";
|
||||||
private static final String URL = INSTANCE + BASE_URL + ID;
|
private static final int TIMESTAMP_MINUTE = 1;
|
||||||
|
private static final int TIMESTAMP_SECOND = 21;
|
||||||
|
private static final String URL = INSTANCE + BASE_URL + ID + "?start=" + TIMESTAMP_MINUTE + "m" + TIMESTAMP_SECOND + "s";
|
||||||
private static StreamExtractor extractor;
|
private static StreamExtractor extractor;
|
||||||
|
|
||||||
@BeforeClass
|
@BeforeClass
|
||||||
@ -48,7 +50,7 @@ public class PeertubeStreamExtractorTest {
|
|||||||
@Override public StreamingService expectedService() { return PeerTube; }
|
@Override public StreamingService expectedService() { return PeerTube; }
|
||||||
@Override public String expectedName() { return "What is PeerTube?"; }
|
@Override public String expectedName() { return "What is PeerTube?"; }
|
||||||
@Override public String expectedId() { return ID; }
|
@Override public String expectedId() { return ID; }
|
||||||
@Override public String expectedUrlContains() { return BASE_URL + ID; }
|
@Override public String expectedUrlContains() { return INSTANCE + BASE_URL + ID; }
|
||||||
@Override public String expectedOriginalUrlContains() { return URL; }
|
@Override public String expectedOriginalUrlContains() { return URL; }
|
||||||
|
|
||||||
@Override public StreamType expectedStreamType() { return StreamType.VIDEO_STREAM; }
|
@Override public StreamType expectedStreamType() { return StreamType.VIDEO_STREAM; }
|
||||||
@ -74,6 +76,7 @@ public class PeertubeStreamExtractorTest {
|
|||||||
+ "**Video sources**: https://gitlab.gnome.org/Jehan/what-is-peertube/");
|
+ "**Video sources**: https://gitlab.gnome.org/Jehan/what-is-peertube/");
|
||||||
}
|
}
|
||||||
@Override public long expectedLength() { return 113; }
|
@Override public long expectedLength() { return 113; }
|
||||||
|
@Override public long expectedTimestamp() { return TIMESTAMP_MINUTE*60 + TIMESTAMP_SECOND; }
|
||||||
@Override public long expectedViewCountAtLeast() { return 38600; }
|
@Override public long expectedViewCountAtLeast() { return 38600; }
|
||||||
@Nullable @Override public String expectedUploadDate() { return "2018-10-01 12:52:46.396"; } // GMT (!)
|
@Nullable @Override public String expectedUploadDate() { return "2018-10-01 12:52:46.396"; } // GMT (!)
|
||||||
@Nullable @Override public String expectedTextualUploadDate() { return "2018-10-01T10:52:46.396Z"; }
|
@Nullable @Override public String expectedTextualUploadDate() { return "2018-10-01T10:52:46.396Z"; }
|
||||||
@ -103,7 +106,7 @@ public class PeertubeStreamExtractorTest {
|
|||||||
@Override public StreamingService expectedService() { return PeerTube; }
|
@Override public StreamingService expectedService() { return PeerTube; }
|
||||||
@Override public String expectedName() { return "A DPR Combatant Describes how Orders are Given through Russian Officers"; }
|
@Override public String expectedName() { return "A DPR Combatant Describes how Orders are Given through Russian Officers"; }
|
||||||
@Override public String expectedId() { return ID; }
|
@Override public String expectedId() { return ID; }
|
||||||
@Override public String expectedUrlContains() { return BASE_URL + ID; }
|
@Override public String expectedUrlContains() { return URL; }
|
||||||
@Override public String expectedOriginalUrlContains() { return URL; }
|
@Override public String expectedOriginalUrlContains() { return URL; }
|
||||||
|
|
||||||
@Override public StreamType expectedStreamType() { return StreamType.VIDEO_STREAM; }
|
@Override public StreamType expectedStreamType() { return StreamType.VIDEO_STREAM; }
|
||||||
|
Loading…
Reference in New Issue
Block a user