mirror of
https://github.com/lidarr/Lidarr
synced 2024-12-25 17:17:02 +00:00
Fixed season ignore
This commit is contained in:
parent
ea643630ed
commit
a853f80f9e
3 changed files with 108 additions and 36 deletions
|
@ -26,8 +26,6 @@ public void import_new_series_succesfull()
|
||||||
.AndTheNext(1).Has(s => s.SeriesId = 15)
|
.AndTheNext(1).Has(s => s.SeriesId = 15)
|
||||||
.Build();
|
.Build();
|
||||||
|
|
||||||
var episodes = Builder<Episode>.CreateListOfSize(10).Build();
|
|
||||||
|
|
||||||
var notification = new ProgressNotification("Test");
|
var notification = new ProgressNotification("Test");
|
||||||
|
|
||||||
var mocker = new AutoMoqer(MockBehavior.Strict);
|
var mocker = new AutoMoqer(MockBehavior.Strict);
|
||||||
|
@ -39,23 +37,21 @@ public void import_new_series_succesfull()
|
||||||
|
|
||||||
mocker.GetMock<DiskScanJob>()
|
mocker.GetMock<DiskScanJob>()
|
||||||
.Setup(j => j.Start(notification, series[0].SeriesId))
|
.Setup(j => j.Start(notification, series[0].SeriesId))
|
||||||
.Callback(() => series[0].LastDiskSync = DateTime.Now)
|
.Callback(() => series[0].LastDiskSync = DateTime.Now);
|
||||||
.AtMostOnce();
|
|
||||||
|
|
||||||
mocker.GetMock<DiskScanJob>()
|
mocker.GetMock<DiskScanJob>()
|
||||||
.Setup(j => j.Start(notification, series[1].SeriesId))
|
.Setup(j => j.Start(notification, series[1].SeriesId))
|
||||||
.Callback(() => series[1].LastDiskSync = DateTime.Now)
|
.Callback(() => series[1].LastDiskSync = DateTime.Now);
|
||||||
.AtMostOnce();
|
|
||||||
|
|
||||||
mocker.GetMock<UpdateInfoJob>()
|
mocker.GetMock<UpdateInfoJob>()
|
||||||
.Setup(j => j.Start(notification, series[0].SeriesId))
|
.Setup(j => j.Start(notification, series[0].SeriesId))
|
||||||
.Callback(() => series[0].LastInfoSync = DateTime.Now)
|
.Callback(() => series[0].LastInfoSync = DateTime.Now);
|
||||||
.AtMostOnce();
|
|
||||||
|
|
||||||
mocker.GetMock<UpdateInfoJob>()
|
mocker.GetMock<UpdateInfoJob>()
|
||||||
.Setup(j => j.Start(notification, series[1].SeriesId))
|
.Setup(j => j.Start(notification, series[1].SeriesId))
|
||||||
.Callback(() => series[1].LastInfoSync = DateTime.Now)
|
.Callback(() => series[1].LastInfoSync = DateTime.Now);
|
||||||
.AtMostOnce();
|
|
||||||
|
|
||||||
mocker.GetMock<SeriesProvider>()
|
mocker.GetMock<SeriesProvider>()
|
||||||
.Setup(s => s.GetSeries(series[0].SeriesId)).Returns(series[0]);
|
.Setup(s => s.GetSeries(series[0].SeriesId)).Returns(series[0]);
|
||||||
|
@ -63,13 +59,6 @@ public void import_new_series_succesfull()
|
||||||
mocker.GetMock<SeriesProvider>()
|
mocker.GetMock<SeriesProvider>()
|
||||||
.Setup(s => s.GetSeries(series[1].SeriesId)).Returns(series[1]);
|
.Setup(s => s.GetSeries(series[1].SeriesId)).Returns(series[1]);
|
||||||
|
|
||||||
|
|
||||||
mocker.GetMock<EpisodeProvider>()
|
|
||||||
.Setup(s => s.GetEpisodeBySeries(series[0].SeriesId)).Returns(episodes);
|
|
||||||
|
|
||||||
mocker.GetMock<EpisodeProvider>()
|
|
||||||
.Setup(s => s.GetEpisodeBySeries(series[1].SeriesId)).Returns(episodes);
|
|
||||||
|
|
||||||
mocker.GetMock<MediaFileProvider>()
|
mocker.GetMock<MediaFileProvider>()
|
||||||
.Setup(s => s.GetSeriesFiles(It.IsAny<int>())).Returns(new List<EpisodeFile>());
|
.Setup(s => s.GetSeriesFiles(It.IsAny<int>())).Returns(new List<EpisodeFile>());
|
||||||
|
|
||||||
|
@ -78,6 +67,13 @@ public void import_new_series_succesfull()
|
||||||
|
|
||||||
//Assert
|
//Assert
|
||||||
mocker.VerifyAllMocks();
|
mocker.VerifyAllMocks();
|
||||||
|
|
||||||
|
mocker.GetMock<DiskScanJob>().Verify(j => j.Start(notification, series[0].SeriesId), Times.Once());
|
||||||
|
mocker.GetMock<DiskScanJob>().Verify(j => j.Start(notification, series[1].SeriesId), Times.Once());
|
||||||
|
|
||||||
|
mocker.GetMock<UpdateInfoJob>().Verify(j => j.Start(notification, series[0].SeriesId), Times.Once());
|
||||||
|
mocker.GetMock<UpdateInfoJob>().Verify(j => j.Start(notification, series[1].SeriesId), Times.Once());
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -93,8 +89,6 @@ public void failed_import_should_not_be_stuck_in_loop()
|
||||||
.AndTheNext(1).Has(s => s.SeriesId = 15)
|
.AndTheNext(1).Has(s => s.SeriesId = 15)
|
||||||
.Build();
|
.Build();
|
||||||
|
|
||||||
var episodes = Builder<Episode>.CreateListOfSize(10).Build();
|
|
||||||
|
|
||||||
var notification = new ProgressNotification("Test");
|
var notification = new ProgressNotification("Test");
|
||||||
|
|
||||||
var mocker = new AutoMoqer(MockBehavior.Strict);
|
var mocker = new AutoMoqer(MockBehavior.Strict);
|
||||||
|
@ -105,18 +99,15 @@ public void failed_import_should_not_be_stuck_in_loop()
|
||||||
|
|
||||||
mocker.GetMock<UpdateInfoJob>()
|
mocker.GetMock<UpdateInfoJob>()
|
||||||
.Setup(j => j.Start(notification, series[0].SeriesId))
|
.Setup(j => j.Start(notification, series[0].SeriesId))
|
||||||
.Callback(() => series[0].LastInfoSync = DateTime.Now)
|
.Callback(() => series[0].LastInfoSync = DateTime.Now);
|
||||||
.AtMostOnce();
|
|
||||||
|
|
||||||
mocker.GetMock<UpdateInfoJob>()
|
mocker.GetMock<UpdateInfoJob>()
|
||||||
.Setup(j => j.Start(notification, series[1].SeriesId))
|
.Setup(j => j.Start(notification, series[1].SeriesId))
|
||||||
.Throws(new InvalidOperationException())
|
.Throws(new InvalidOperationException());
|
||||||
.AtMostOnce();
|
|
||||||
|
|
||||||
mocker.GetMock<DiskScanJob>()
|
mocker.GetMock<DiskScanJob>()
|
||||||
.Setup(j => j.Start(notification, series[0].SeriesId))
|
.Setup(j => j.Start(notification, series[0].SeriesId))
|
||||||
.Callback(() => series[0].LastDiskSync = DateTime.Now)
|
.Callback(() => series[0].LastDiskSync = DateTime.Now);
|
||||||
.AtMostOnce();
|
|
||||||
|
|
||||||
|
|
||||||
mocker.GetMock<SeriesProvider>()
|
mocker.GetMock<SeriesProvider>()
|
||||||
|
@ -125,17 +116,98 @@ public void failed_import_should_not_be_stuck_in_loop()
|
||||||
mocker.GetMock<MediaFileProvider>()
|
mocker.GetMock<MediaFileProvider>()
|
||||||
.Setup(s => s.GetSeriesFiles(It.IsAny<int>())).Returns(new List<EpisodeFile>());
|
.Setup(s => s.GetSeriesFiles(It.IsAny<int>())).Returns(new List<EpisodeFile>());
|
||||||
|
|
||||||
mocker.GetMock<EpisodeProvider>()
|
|
||||||
.Setup(s => s.GetEpisodeBySeries(It.IsAny<long>())).Returns(episodes);
|
|
||||||
|
|
||||||
//Act
|
//Act
|
||||||
mocker.Resolve<ImportNewSeriesJob>().Start(notification, 0);
|
mocker.Resolve<ImportNewSeriesJob>().Start(notification, 0);
|
||||||
|
|
||||||
//Assert
|
//Assert
|
||||||
mocker.VerifyAllMocks();
|
mocker.VerifyAllMocks();
|
||||||
|
|
||||||
|
mocker.GetMock<UpdateInfoJob>().Verify(j => j.Start(notification, series[0].SeriesId), Times.Once());
|
||||||
|
mocker.GetMock<UpdateInfoJob>().Verify(j => j.Start(notification, series[1].SeriesId), Times.Once());
|
||||||
|
|
||||||
|
mocker.GetMock<DiskScanJob>().Verify(j => j.Start(notification, series[0].SeriesId), Times.Once());
|
||||||
|
|
||||||
ExceptionVerification.ExcpectedErrors(1);
|
ExceptionVerification.ExcpectedErrors(1);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
[Test]
|
||||||
|
public void AutoIgnoreSeason_new_series_should_not_ignore_any()
|
||||||
|
{
|
||||||
|
int seriesId = 12;
|
||||||
|
|
||||||
|
var mocker = new AutoMoqer(MockBehavior.Strict);
|
||||||
|
mocker.GetMock<MediaFileProvider>()
|
||||||
|
.Setup(p => p.GetSeriesFiles(seriesId))
|
||||||
|
.Returns(new List<EpisodeFile>());
|
||||||
|
|
||||||
|
mocker.GetMock<EpisodeProvider>()
|
||||||
|
.Setup(p => p.GetSeasons(seriesId))
|
||||||
|
.Returns(new List<int> { 0, 1, 2, 3, 4 });
|
||||||
|
|
||||||
|
mocker.Resolve<ImportNewSeriesJob>().AutoIgnoreSeasons(seriesId);
|
||||||
|
|
||||||
|
|
||||||
|
mocker.GetMock<EpisodeProvider>().Verify(p => p.SetSeasonIgnore(seriesId, It.IsAny<int>(), It.IsAny<Boolean>()), Times.Never());
|
||||||
|
}
|
||||||
|
|
||||||
|
[Test]
|
||||||
|
public void AutoIgnoreSeason_existing_should_not_ignore_currentseason()
|
||||||
|
{
|
||||||
|
int seriesId = 12;
|
||||||
|
|
||||||
|
var episodesFiles = Builder<EpisodeFile>.CreateListOfSize(2)
|
||||||
|
.WhereAll().Have(e => e.SeriesId = seriesId)
|
||||||
|
.Build();
|
||||||
|
|
||||||
|
episodesFiles[0].SeasonNumber = 0;
|
||||||
|
episodesFiles[1].SeasonNumber = 1;
|
||||||
|
|
||||||
|
var mocker = new AutoMoqer(MockBehavior.Strict);
|
||||||
|
|
||||||
|
mocker.GetMock<MediaFileProvider>()
|
||||||
|
.Setup(p => p.GetSeriesFiles(seriesId))
|
||||||
|
.Returns(episodesFiles);
|
||||||
|
|
||||||
|
mocker.GetMock<EpisodeProvider>()
|
||||||
|
.Setup(p => p.GetSeasons(seriesId))
|
||||||
|
.Returns(new List<int> { 0, 1, 2 });
|
||||||
|
|
||||||
|
mocker.Resolve<ImportNewSeriesJob>().AutoIgnoreSeasons(seriesId);
|
||||||
|
|
||||||
|
mocker.GetMock<EpisodeProvider>().Verify(p => p.SetSeasonIgnore(seriesId, 2, It.IsAny<Boolean>()), Times.Never());
|
||||||
|
}
|
||||||
|
|
||||||
|
[Test]
|
||||||
|
public void AutoIgnoreSeason_existing_should_ignore_seasons_with_no_file()
|
||||||
|
{
|
||||||
|
int seriesId = 12;
|
||||||
|
|
||||||
|
var episodesFiles = Builder<EpisodeFile>.CreateListOfSize(2)
|
||||||
|
.WhereAll().Have(e => e.SeriesId = seriesId)
|
||||||
|
.Build();
|
||||||
|
|
||||||
|
episodesFiles[0].SeasonNumber = 1;
|
||||||
|
|
||||||
|
var mocker = new AutoMoqer();
|
||||||
|
|
||||||
|
mocker.GetMock<MediaFileProvider>()
|
||||||
|
.Setup(p => p.GetSeriesFiles(seriesId))
|
||||||
|
.Returns(episodesFiles);
|
||||||
|
|
||||||
|
mocker.GetMock<EpisodeProvider>()
|
||||||
|
.Setup(p => p.GetSeasons(seriesId))
|
||||||
|
.Returns(new List<int> { 0, 1, 2 });
|
||||||
|
|
||||||
|
mocker.Resolve<ImportNewSeriesJob>().AutoIgnoreSeasons(seriesId);
|
||||||
|
|
||||||
|
mocker.GetMock<EpisodeProvider>().Verify(p => p.SetSeasonIgnore(seriesId, 0, true), Times.Once());
|
||||||
|
mocker.GetMock<EpisodeProvider>().Verify(p => p.SetSeasonIgnore(seriesId, 1, true), Times.Never());
|
||||||
|
mocker.GetMock<EpisodeProvider>().Verify(p => p.SetSeasonIgnore(seriesId, 2, It.IsAny<Boolean>()), Times.Never());
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
|
@ -71,7 +71,7 @@ private void ScanSeries(ProgressNotification notification)
|
||||||
_diskScanJob.Start(notification, currentSeries.SeriesId);
|
_diskScanJob.Start(notification, currentSeries.SeriesId);
|
||||||
|
|
||||||
var updatedSeries = _seriesProvider.GetSeries(currentSeries.SeriesId);
|
var updatedSeries = _seriesProvider.GetSeries(currentSeries.SeriesId);
|
||||||
AutoIgnoreSeasons(updatedSeries);
|
AutoIgnoreSeasons(updatedSeries.SeriesId);
|
||||||
|
|
||||||
}
|
}
|
||||||
catch (Exception e)
|
catch (Exception e)
|
||||||
|
@ -84,20 +84,20 @@ private void ScanSeries(ProgressNotification notification)
|
||||||
ScanSeries(notification);
|
ScanSeries(notification);
|
||||||
}
|
}
|
||||||
|
|
||||||
private void AutoIgnoreSeasons(Series updatedSeries)
|
public void AutoIgnoreSeasons(int seriesId)
|
||||||
{
|
{
|
||||||
var episodeFiles = _mediaFileProvider.GetSeriesFiles(updatedSeries.SeriesId);
|
var episodeFiles = _mediaFileProvider.GetSeriesFiles(seriesId);
|
||||||
var episodes = _episodeProvider.GetEpisodeBySeries(updatedSeries.SeriesId);
|
|
||||||
if (episodeFiles.Count() != 0)
|
if (episodeFiles.Count() != 0)
|
||||||
{
|
{
|
||||||
var seasons = episodes.Select(c => c.SeasonNumber).Distinct();
|
var seasons = _episodeProvider.GetSeasons(seriesId);
|
||||||
var currentSeasons = seasons.Max();
|
var currentSeasons = seasons.Max();
|
||||||
|
|
||||||
foreach (var season in seasons)
|
foreach (var season in seasons)
|
||||||
{
|
{
|
||||||
if (season != currentSeasons)
|
if (season != currentSeasons && !episodeFiles.Any(e => e.SeasonNumber == season))
|
||||||
{
|
{
|
||||||
|
_episodeProvider.SetSeasonIgnore(seriesId, season, true);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -204,7 +204,7 @@ public virtual List<EpisodeFile> GetEpisodeFiles()
|
||||||
return _database.Fetch<EpisodeFile>();
|
return _database.Fetch<EpisodeFile>();
|
||||||
}
|
}
|
||||||
|
|
||||||
public virtual List<EpisodeFile> GetSeriesFiles(int seriesId)
|
public virtual IList<EpisodeFile> GetSeriesFiles(int seriesId)
|
||||||
{
|
{
|
||||||
return _database.Fetch<EpisodeFile>("WHERE seriesId= @0", seriesId);
|
return _database.Fetch<EpisodeFile>("WHERE seriesId= @0", seriesId);
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue