mirror of
https://github.com/TeamNewPipe/NewPipe
synced 2025-01-03 14:00:32 +00:00
Fix SubscriptionManagerTest tests
The breakage of these tests is related to the channel tabs changes. The testRememberRecentStreams test method has been removed, as it doesn't seem to be relevant anymore to managing subscriptions.
This commit is contained in:
parent
8fbc8ffc7c
commit
0d9910cbbe
@ -10,19 +10,13 @@ import org.junit.Rule;
|
|||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
import org.schabi.newpipe.database.AppDatabase;
|
import org.schabi.newpipe.database.AppDatabase;
|
||||||
import org.schabi.newpipe.database.feed.model.FeedGroupEntity;
|
import org.schabi.newpipe.database.feed.model.FeedGroupEntity;
|
||||||
import org.schabi.newpipe.database.stream.model.StreamEntity;
|
|
||||||
import org.schabi.newpipe.database.subscription.SubscriptionEntity;
|
import org.schabi.newpipe.database.subscription.SubscriptionEntity;
|
||||||
import org.schabi.newpipe.extractor.channel.ChannelInfo;
|
import org.schabi.newpipe.extractor.channel.ChannelInfo;
|
||||||
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.stream.StreamInfoItem;
|
|
||||||
import org.schabi.newpipe.extractor.stream.StreamType;
|
|
||||||
import org.schabi.newpipe.testUtil.TestDatabase;
|
import org.schabi.newpipe.testUtil.TestDatabase;
|
||||||
import org.schabi.newpipe.testUtil.TrampolineSchedulerRule;
|
import org.schabi.newpipe.testUtil.TrampolineSchedulerRule;
|
||||||
|
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.time.OffsetDateTime;
|
|
||||||
import java.util.Comparator;
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
public class SubscriptionManagerTest {
|
public class SubscriptionManagerTest {
|
||||||
@ -58,7 +52,7 @@ public class SubscriptionManagerTest {
|
|||||||
final ChannelInfo info = ChannelInfo.getInfo("https://www.youtube.com/c/3blue1brown");
|
final ChannelInfo info = ChannelInfo.getInfo("https://www.youtube.com/c/3blue1brown");
|
||||||
final SubscriptionEntity subscription = SubscriptionEntity.from(info);
|
final SubscriptionEntity subscription = SubscriptionEntity.from(info);
|
||||||
|
|
||||||
manager.insertSubscription(subscription, info);
|
manager.insertSubscription(subscription);
|
||||||
final SubscriptionEntity readSubscription = getAssertOneSubscriptionEntity();
|
final SubscriptionEntity readSubscription = getAssertOneSubscriptionEntity();
|
||||||
|
|
||||||
// the uid has changed, since the uid is chosen upon inserting, but the rest should match
|
// the uid has changed, since the uid is chosen upon inserting, but the rest should match
|
||||||
@ -76,7 +70,7 @@ public class SubscriptionManagerTest {
|
|||||||
final SubscriptionEntity subscription = SubscriptionEntity.from(info);
|
final SubscriptionEntity subscription = SubscriptionEntity.from(info);
|
||||||
subscription.setNotificationMode(0);
|
subscription.setNotificationMode(0);
|
||||||
|
|
||||||
manager.insertSubscription(subscription, info);
|
manager.insertSubscription(subscription);
|
||||||
manager.updateNotificationMode(subscription.getServiceId(), subscription.getUrl(), 1)
|
manager.updateNotificationMode(subscription.getServiceId(), subscription.getUrl(), 1)
|
||||||
.blockingAwait();
|
.blockingAwait();
|
||||||
final SubscriptionEntity anotherSubscription = getAssertOneSubscriptionEntity();
|
final SubscriptionEntity anotherSubscription = getAssertOneSubscriptionEntity();
|
||||||
@ -85,35 +79,4 @@ public class SubscriptionManagerTest {
|
|||||||
assertEquals(subscription.getUrl(), anotherSubscription.getUrl());
|
assertEquals(subscription.getUrl(), anotherSubscription.getUrl());
|
||||||
assertEquals(1, anotherSubscription.getNotificationMode());
|
assertEquals(1, anotherSubscription.getNotificationMode());
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
|
||||||
public void testRememberRecentStreams() throws ExtractionException, IOException {
|
|
||||||
final ChannelInfo info = ChannelInfo.getInfo("https://www.youtube.com/c/Polyphia");
|
|
||||||
final List<StreamInfoItem> relatedItems = List.of(
|
|
||||||
new StreamInfoItem(0, "a", "b", StreamType.VIDEO_STREAM),
|
|
||||||
new StreamInfoItem(1, "c", "d", StreamType.AUDIO_STREAM),
|
|
||||||
new StreamInfoItem(2, "e", "f", StreamType.AUDIO_LIVE_STREAM),
|
|
||||||
new StreamInfoItem(3, "g", "h", StreamType.LIVE_STREAM));
|
|
||||||
relatedItems.forEach(item -> {
|
|
||||||
// these two fields must be non-null for the insert to succeed
|
|
||||||
item.setUploaderUrl(info.getUrl());
|
|
||||||
item.setUploaderName(info.getName());
|
|
||||||
// the upload date must not be too much in the past for the item to actually be inserted
|
|
||||||
item.setUploadDate(new DateWrapper(OffsetDateTime.now()));
|
|
||||||
});
|
|
||||||
info.setRelatedItems(relatedItems);
|
|
||||||
final SubscriptionEntity subscription = SubscriptionEntity.from(info);
|
|
||||||
|
|
||||||
manager.insertSubscription(subscription, info);
|
|
||||||
final List<StreamEntity> streams = database.streamDAO().getAll().blockingFirst();
|
|
||||||
|
|
||||||
assertEquals(4, streams.size());
|
|
||||||
streams.sort(Comparator.comparing(StreamEntity::getServiceId));
|
|
||||||
for (int i = 0; i < 4; i++) {
|
|
||||||
assertEquals(relatedItems.get(0).getServiceId(), streams.get(0).getServiceId());
|
|
||||||
assertEquals(relatedItems.get(0).getUrl(), streams.get(0).getUrl());
|
|
||||||
assertEquals(relatedItems.get(0).getName(), streams.get(0).getTitle());
|
|
||||||
assertEquals(relatedItems.get(0).getStreamType(), streams.get(0).getStreamType());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user