mirror of
https://github.com/Sonarr/Sonarr.git
synced 2025-01-06 06:41:40 +02:00
Season Search will only search for past episodes if it falls back to that.
This commit is contained in:
parent
1dddf2ffde
commit
75cfb7e044
@ -1,4 +1,5 @@
|
|||||||
using System.Collections.Generic;
|
using System;
|
||||||
|
using System.Collections.Generic;
|
||||||
using System.Linq;
|
using System.Linq;
|
||||||
|
|
||||||
using FizzWare.NBuilder;
|
using FizzWare.NBuilder;
|
||||||
@ -20,21 +21,19 @@ public class SeasonSearchJobTest : CoreTest
|
|||||||
[Test]
|
[Test]
|
||||||
public void SeasonSearch_full_season_success()
|
public void SeasonSearch_full_season_success()
|
||||||
{
|
{
|
||||||
var mocker = new AutoMoqer(MockBehavior.Strict);
|
|
||||||
|
|
||||||
var notification = new ProgressNotification("Season Search");
|
var notification = new ProgressNotification("Season Search");
|
||||||
|
|
||||||
mocker.GetMock<SearchProvider>()
|
Mocker.GetMock<SearchProvider>()
|
||||||
.Setup(c => c.SeasonSearch(notification, 1, 1)).Returns(true);
|
.Setup(c => c.SeasonSearch(notification, 1, 1)).Returns(true);
|
||||||
|
|
||||||
//Act
|
//Act
|
||||||
mocker.Resolve<SeasonSearchJob>().Start(notification, 1, 1);
|
Mocker.Resolve<SeasonSearchJob>().Start(notification, 1, 1);
|
||||||
|
|
||||||
//Assert
|
//Assert
|
||||||
mocker.VerifyAllMocks();
|
Mocker.VerifyAllMocks();
|
||||||
mocker.GetMock<SearchProvider>().Verify(c => c.SeasonSearch(notification, 1, 1), Times.Once());
|
Mocker.GetMock<SearchProvider>().Verify(c => c.SeasonSearch(notification, 1, 1), Times.Once());
|
||||||
mocker.GetMock<SearchProvider>().Verify(c => c.PartialSeasonSearch(notification, 1, 1), Times.Never());
|
Mocker.GetMock<SearchProvider>().Verify(c => c.PartialSeasonSearch(notification, 1, 1), Times.Never());
|
||||||
mocker.GetMock<EpisodeSearchJob>().Verify(c => c.Start(notification, It.IsAny<int>(), 0), Times.Never());
|
Mocker.GetMock<EpisodeSearchJob>().Verify(c => c.Start(notification, It.IsAny<int>(), 0), Times.Never());
|
||||||
}
|
}
|
||||||
|
|
||||||
[Test]
|
[Test]
|
||||||
@ -46,28 +45,26 @@ public void SeasonSearch_partial_season_success()
|
|||||||
.With(e => e.SeasonNumber = 1)
|
.With(e => e.SeasonNumber = 1)
|
||||||
.Build();
|
.Build();
|
||||||
|
|
||||||
var mocker = new AutoMoqer(MockBehavior.Strict);
|
|
||||||
|
|
||||||
var notification = new ProgressNotification("Season Search");
|
var notification = new ProgressNotification("Season Search");
|
||||||
|
|
||||||
mocker.GetMock<SearchProvider>()
|
Mocker.GetMock<SearchProvider>()
|
||||||
.Setup(c => c.SeasonSearch(notification, 1, 1)).Returns(false);
|
.Setup(c => c.SeasonSearch(notification, 1, 1)).Returns(false);
|
||||||
|
|
||||||
mocker.GetMock<EpisodeProvider>()
|
Mocker.GetMock<EpisodeProvider>()
|
||||||
.Setup(c => c.GetEpisodesBySeason(1, 1)).Returns(episodes);
|
.Setup(c => c.GetEpisodesBySeason(1, 1)).Returns(episodes);
|
||||||
|
|
||||||
mocker.GetMock<SearchProvider>()
|
Mocker.GetMock<SearchProvider>()
|
||||||
.Setup(c => c.PartialSeasonSearch(notification, 1, 1))
|
.Setup(c => c.PartialSeasonSearch(notification, 1, 1))
|
||||||
.Returns(episodes.Select(e => e.EpisodeNumber).ToList());
|
.Returns(episodes.Select(e => e.EpisodeNumber).ToList());
|
||||||
|
|
||||||
//Act
|
//Act
|
||||||
mocker.Resolve<SeasonSearchJob>().Start(notification, 1, 1);
|
Mocker.Resolve<SeasonSearchJob>().Start(notification, 1, 1);
|
||||||
|
|
||||||
//Assert
|
//Assert
|
||||||
mocker.VerifyAllMocks();
|
Mocker.VerifyAllMocks();
|
||||||
mocker.GetMock<SearchProvider>().Verify(c => c.SeasonSearch(notification, 1, 1), Times.Once());
|
Mocker.GetMock<SearchProvider>().Verify(c => c.SeasonSearch(notification, 1, 1), Times.Once());
|
||||||
mocker.GetMock<SearchProvider>().Verify(c => c.PartialSeasonSearch(notification, 1, 1), Times.Once());
|
Mocker.GetMock<SearchProvider>().Verify(c => c.PartialSeasonSearch(notification, 1, 1), Times.Once());
|
||||||
mocker.GetMock<EpisodeSearchJob>().Verify(c => c.Start(notification, It.IsAny<int>(), 0), Times.Never());
|
Mocker.GetMock<EpisodeSearchJob>().Verify(c => c.Start(notification, It.IsAny<int>(), 0), Times.Never());
|
||||||
}
|
}
|
||||||
|
|
||||||
[Test]
|
[Test]
|
||||||
@ -78,33 +75,70 @@ public void SeasonSearch_partial_season_failure()
|
|||||||
.With(e => e.SeriesId = 1)
|
.With(e => e.SeriesId = 1)
|
||||||
.With(e => e.SeasonNumber = 1)
|
.With(e => e.SeasonNumber = 1)
|
||||||
.With(e => e.Ignored = false)
|
.With(e => e.Ignored = false)
|
||||||
|
.With(e => e.AirDate = DateTime.Today.AddDays(-1))
|
||||||
.Build();
|
.Build();
|
||||||
|
|
||||||
var mocker = new AutoMoqer(MockBehavior.Strict);
|
|
||||||
|
|
||||||
var notification = new ProgressNotification("Season Search");
|
var notification = new ProgressNotification("Season Search");
|
||||||
|
|
||||||
mocker.GetMock<SearchProvider>()
|
Mocker.GetMock<SearchProvider>()
|
||||||
.Setup(c => c.SeasonSearch(notification, 1, 1)).Returns(false);
|
.Setup(c => c.SeasonSearch(notification, 1, 1)).Returns(false);
|
||||||
|
|
||||||
mocker.GetMock<EpisodeProvider>()
|
Mocker.GetMock<EpisodeProvider>()
|
||||||
.Setup(c => c.GetEpisodesBySeason(1, 1)).Returns(episodes);
|
.Setup(c => c.GetEpisodesBySeason(1, 1)).Returns(episodes);
|
||||||
|
|
||||||
mocker.GetMock<SearchProvider>()
|
Mocker.GetMock<SearchProvider>()
|
||||||
.Setup(c => c.PartialSeasonSearch(notification, 1, 1))
|
.Setup(c => c.PartialSeasonSearch(notification, 1, 1))
|
||||||
.Returns(new List<int>{1});
|
.Returns(new List<int>{1});
|
||||||
|
|
||||||
mocker.GetMock<EpisodeSearchJob>()
|
Mocker.GetMock<EpisodeSearchJob>()
|
||||||
.Setup(c => c.Start(notification, It.IsAny<int>(), 0)).Verifiable();
|
.Setup(c => c.Start(notification, It.IsAny<int>(), 0)).Verifiable();
|
||||||
|
|
||||||
//Act
|
//Act
|
||||||
mocker.Resolve<SeasonSearchJob>().Start(notification, 1, 1);
|
Mocker.Resolve<SeasonSearchJob>().Start(notification, 1, 1);
|
||||||
|
|
||||||
//Assert
|
//Assert
|
||||||
mocker.VerifyAllMocks();
|
Mocker.VerifyAllMocks();
|
||||||
mocker.GetMock<SearchProvider>().Verify(c => c.SeasonSearch(notification, 1, 1), Times.Once());
|
Mocker.GetMock<SearchProvider>().Verify(c => c.SeasonSearch(notification, 1, 1), Times.Once());
|
||||||
mocker.GetMock<SearchProvider>().Verify(c => c.PartialSeasonSearch(notification, 1, 1), Times.Once());
|
Mocker.GetMock<SearchProvider>().Verify(c => c.PartialSeasonSearch(notification, 1, 1), Times.Once());
|
||||||
mocker.GetMock<EpisodeSearchJob>().Verify(c => c.Start(notification, It.IsAny<int>(), 0), Times.Exactly(4));
|
Mocker.GetMock<EpisodeSearchJob>().Verify(c => c.Start(notification, It.IsAny<int>(), 0), Times.Exactly(4));
|
||||||
|
}
|
||||||
|
|
||||||
|
[Test]
|
||||||
|
public void SeasonSearch_should_not_search_for_episodes_that_havent_aired_yet_or_air_tomorrow()
|
||||||
|
{
|
||||||
|
var episodes = Builder<Episode>.CreateListOfSize(5)
|
||||||
|
.All()
|
||||||
|
.With(e => e.SeriesId = 1)
|
||||||
|
.With(e => e.SeasonNumber = 1)
|
||||||
|
.With(e => e.Ignored = false)
|
||||||
|
.With(e => e.AirDate = DateTime.Today.AddDays(-1))
|
||||||
|
.TheLast(2)
|
||||||
|
.With(e => e.AirDate = DateTime.Today.AddDays(2))
|
||||||
|
.Build();
|
||||||
|
|
||||||
|
var notification = new ProgressNotification("Season Search");
|
||||||
|
|
||||||
|
Mocker.GetMock<SearchProvider>()
|
||||||
|
.Setup(c => c.SeasonSearch(notification, 1, 1)).Returns(false);
|
||||||
|
|
||||||
|
Mocker.GetMock<EpisodeProvider>()
|
||||||
|
.Setup(c => c.GetEpisodesBySeason(1, 1)).Returns(episodes);
|
||||||
|
|
||||||
|
Mocker.GetMock<SearchProvider>()
|
||||||
|
.Setup(c => c.PartialSeasonSearch(notification, 1, 1))
|
||||||
|
.Returns(new List<int>());
|
||||||
|
|
||||||
|
Mocker.GetMock<EpisodeSearchJob>()
|
||||||
|
.Setup(c => c.Start(notification, It.IsAny<int>(), 0)).Verifiable();
|
||||||
|
|
||||||
|
//Act
|
||||||
|
Mocker.Resolve<SeasonSearchJob>().Start(notification, 1, 1);
|
||||||
|
|
||||||
|
//Assert
|
||||||
|
Mocker.VerifyAllMocks();
|
||||||
|
Mocker.GetMock<SearchProvider>().Verify(c => c.SeasonSearch(notification, 1, 1), Times.Once());
|
||||||
|
Mocker.GetMock<SearchProvider>().Verify(c => c.PartialSeasonSearch(notification, 1, 1), Times.Once());
|
||||||
|
Mocker.GetMock<EpisodeSearchJob>().Verify(c => c.Start(notification, It.IsAny<int>(), 0), Times.Exactly(3));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
@ -61,7 +61,7 @@ public virtual void Start(ProgressNotification notification, int targetId, int s
|
|||||||
var addedSeries = _searchProvider.PartialSeasonSearch(notification, targetId, secondaryTargetId);
|
var addedSeries = _searchProvider.PartialSeasonSearch(notification, targetId, secondaryTargetId);
|
||||||
|
|
||||||
addedSeries.Distinct().ToList().Sort();
|
addedSeries.Distinct().ToList().Sort();
|
||||||
var episodeNumbers = episodes.Select(s => s.EpisodeNumber).ToList();
|
var episodeNumbers = episodes.Where(w => w.AirDate <= DateTime.Today.AddDays(1)).Select(s => s.EpisodeNumber).ToList();
|
||||||
episodeNumbers.Sort();
|
episodeNumbers.Sort();
|
||||||
|
|
||||||
if (addedSeries.SequenceEqual(episodeNumbers))
|
if (addedSeries.SequenceEqual(episodeNumbers))
|
||||||
|
Loading…
Reference in New Issue
Block a user