diff --git a/NzbDrone.Core.Test/EpisodeProviderTest_GetEpisodesByParseResult.cs b/NzbDrone.Core.Test/EpisodeProviderTest_GetEpisodesByParseResult.cs index 1b7e5648f..c46af9eb7 100644 --- a/NzbDrone.Core.Test/EpisodeProviderTest_GetEpisodesByParseResult.cs +++ b/NzbDrone.Core.Test/EpisodeProviderTest_GetEpisodesByParseResult.cs @@ -234,69 +234,5 @@ public void Get_Multi_Episode_Zero_Doesnt_Exist_Should_not_add_ignored() db.Fetch().Should().HaveCount(2); ep.First().Ignored.Should().BeFalse(); } - - [Test] - public void Full_Season_return_all_episodes_for_season() - { - var mocker = new AutoMoqer(); - var db = MockLib.GetEmptyDatabase(); - mocker.SetConstant(db); - - var fakeSeries = Builder.CreateNew().Build(); - - var fakeEpisodes = Builder.CreateListOfSize(10) - .WhereAll() - .Have(e => e.SeriesId = fakeSeries.SeriesId) - .Have(e => e.SeasonNumber = 2) - .Build(); - - db.Insert(fakeSeries); - db.InsertMany(fakeEpisodes); - - var parseResult = new EpisodeParseResult - { - Series = fakeSeries, - SeasonNumber = 2, - EpisodeNumbers = new List(), - FullSeason = true - }; - - var ep = mocker.Resolve().GetEpisodesByParseResult(parseResult); - - ep.Should().HaveCount(10); - db.Fetch().Should().HaveCount(10); - } - - [Test] - public void No_Episodes_Not_a_proper_full_season_release() - { - var mocker = new AutoMoqer(); - var db = MockLib.GetEmptyDatabase(); - mocker.SetConstant(db); - - var fakeSeries = Builder.CreateNew().Build(); - - var fakeEpisodes = Builder.CreateListOfSize(10) - .WhereAll() - .Have(e => e.SeriesId = fakeSeries.SeriesId) - .Have(e => e.SeasonNumber = 2) - .Build(); - - db.Insert(fakeSeries); - db.InsertMany(fakeEpisodes); - - var parseResult = new EpisodeParseResult - { - Series = fakeSeries, - SeasonNumber = 2, - EpisodeNumbers = new List(), - FullSeason = false - }; - - var ep = mocker.Resolve().GetEpisodesByParseResult(parseResult); - - ep.Should().HaveCount(0); - db.Fetch().Should().HaveCount(10); - } } } \ No newline at end of file diff --git a/NzbDrone.Core/Providers/EpisodeProvider.cs b/NzbDrone.Core/Providers/EpisodeProvider.cs index 547c0aa64..d8ce7c1dc 100644 --- a/NzbDrone.Core/Providers/EpisodeProvider.cs +++ b/NzbDrone.Core/Providers/EpisodeProvider.cs @@ -125,14 +125,6 @@ public virtual IList GetEpisodesByParseResult(EpisodeParseResult parseR { var result = new List(); - if (parseResult.EpisodeNumbers.Count == 0 && parseResult.FullSeason) - { - result.AddRange(GetEpisodesBySeason(parseResult.Series.SeriesId, parseResult.SeasonNumber)); - - //Return now as no further processing is required - return result; - } - foreach (var episodeNumber in parseResult.EpisodeNumbers) { var episodeInfo = GetEpisode(parseResult.Series.SeriesId, parseResult.SeasonNumber, episodeNumber); diff --git a/NzbDrone.Core/Providers/PostDownloadProvider.cs b/NzbDrone.Core/Providers/PostDownloadProvider.cs index f592f9d83..3d964dd6f 100644 --- a/NzbDrone.Core/Providers/PostDownloadProvider.cs +++ b/NzbDrone.Core/Providers/PostDownloadProvider.cs @@ -180,7 +180,15 @@ public virtual void ProcessFailedOrUnpackingDownload(DirectoryInfo directoryInfo var parseResult = Parser.ParseTitle(directoryInfo.Name.Substring(8)); parseResult.Series = _seriesProvider.FindSeries(parseResult.CleanTitle); - var episodeIds = _episodeProvider.GetEpisodesByParseResult(parseResult).Select(e => e.EpisodeId); + var episodeIds = new List(); + + if (parseResult.EpisodeNumbers.Count == 0 && parseResult.FullSeason) + episodeIds = + _episodeProvider.GetEpisodesBySeason(parseResult.Series.SeriesId, parseResult.SeasonNumber) + .Select(e => e.EpisodeId).ToList(); + + else + episodeIds = _episodeProvider.GetEpisodesByParseResult(parseResult).Select(e => e.EpisodeId).ToList(); _episodeProvider.SetPostDownloadStatus(episodeIds, postDownloadStatus); } diff --git a/NzbDrone.Core/packages.config b/NzbDrone.Core/packages.config index 15b7af0e6..f34d83bf2 100644 --- a/NzbDrone.Core/packages.config +++ b/NzbDrone.Core/packages.config @@ -1,6 +1,6 @@  + - \ No newline at end of file