Auto adding of episodes is now disabled. (we should make it more conservative if we want to bring it back)

This commit is contained in:
kay.one 2012-01-06 13:25:27 -08:00
parent b1aeb0a973
commit 7ec89056af
2 changed files with 123 additions and 257 deletions

View File

@ -21,367 +21,231 @@ namespace NzbDrone.Core.Test.ProviderTests
// ReSharper disable InconsistentNaming // ReSharper disable InconsistentNaming
public class EpisodeProviderTest_GetEpisodesByParseResult : CoreTest public class EpisodeProviderTest_GetEpisodesByParseResult : CoreTest
{ {
[Test] private EpisodeProvider episodeProvider;
public void Single_GetSeason_Episode_Exists()
private Series fakeSeries;
private Series fakeDailySeries;
private Episode fakeEpisode;
private Episode fakeDailyEpisode;
private Episode fakeEpisode2;
[SetUp]
public void Setup()
{ {
fakeSeries = Builder<Series>.CreateNew().Build();
fakeDailySeries = Builder<Series>.CreateNew()
.With(c => c.IsDaily = true)
.Build();
fakeEpisode = Builder<Episode>.CreateNew()
.With(e => e.SeriesId = fakeSeries.SeriesId)
.With(e => e.Title = "Episode 1")
.Build();
fakeEpisode2 = Builder<Episode>.CreateNew()
.With(e => e.SeriesId = fakeSeries.SeriesId)
.With(e => e.SeasonNumber = fakeEpisode.SeasonNumber)
.With(e => e.EpisodeNumber = fakeEpisode.EpisodeNumber + 1)
.With(e => e.Title = "Episode 2")
.Build();
fakeDailyEpisode = Builder<Episode>.CreateNew()
.With(e => e.SeriesId = fakeSeries.SeriesId)
.With(e => e.AirDate = DateTime.Now.Date)
.With(e => e.Title = "Daily Episode 1")
.Build();
WithRealDb(); WithRealDb();
var fakeEpisode = Builder<Episode>.CreateNew() episodeProvider = Mocker.Resolve<EpisodeProvider>();
.With(e => e.SeriesId = 1) }
.With(e => e.SeasonNumber = 2)
.With(e => e.EpisodeNumber = 10)
.Build();
var fakeSeries = Builder<Series>.CreateNew().Build();
[Test]
public void existing_single_episode_should_return_single_existing_episode()
{
Db.Insert(fakeEpisode); Db.Insert(fakeEpisode);
Db.Insert(fakeSeries); Db.Insert(fakeSeries);
var parseResult = new EpisodeParseResult var parseResult = new EpisodeParseResult
{ {
Series = fakeSeries, Series = fakeSeries,
SeasonNumber = 2, SeasonNumber = fakeEpisode.SeasonNumber,
EpisodeNumbers = new List<int> { 10 } EpisodeNumbers = new List<int> { fakeEpisode.EpisodeNumber }
}; };
var ep = Mocker.Resolve<EpisodeProvider>().GetEpisodesByParseResult(parseResult); var ep = episodeProvider.GetEpisodesByParseResult(parseResult, true);
ep.Should().HaveCount(1); ep.Should().HaveCount(1);
parseResult.EpisodeTitle.Should().Be(fakeEpisode.Title); parseResult.EpisodeTitle.Should().Be(fakeEpisode.Title);
ep.First().ShouldHave().AllPropertiesBut(e => e.Series); VerifyEpisode(ep[0], fakeEpisode);
}
[Test]
public void Single_GetSeason_Episode_Doesnt_exists_should_not_add()
{
WithRealDb();
var fakeSeries = Builder<Series>.CreateNew().Build();
var parseResult = new EpisodeParseResult
{
Series = fakeSeries,
SeasonNumber = 2,
EpisodeNumbers = new List<int> { 10 }
};
var ep = Mocker.Resolve<EpisodeProvider>().GetEpisodesByParseResult(parseResult);
ep.Should().BeEmpty();
Db.Fetch<Episode>().Should().HaveCount(0);
}
[Test]
public void Single_GetSeason_Episode_Doesnt_exists_should_add()
{
WithRealDb();
var fakeSeries = Builder<Series>.CreateNew().Build();
var parseResult = new EpisodeParseResult
{
Series = fakeSeries,
SeasonNumber = 2,
EpisodeNumbers = new List<int> { 10 }
};
var ep = Mocker.Resolve<EpisodeProvider>().GetEpisodesByParseResult(parseResult, true);
ep.Should().HaveCount(1);
Db.Fetch<Episode>().Should().HaveCount(1); Db.Fetch<Episode>().Should().HaveCount(1);
} }
[Test] [Test]
public void Multi_GetSeason_Episode_Exists() public void single_none_existing_episode_should_return_nothing_and_add_nothing()
{ {
WithRealDb(); var parseResult = new EpisodeParseResult
{
Series = fakeSeries,
SeasonNumber = fakeEpisode.SeasonNumber,
EpisodeNumbers = new List<int> { 10 }
};
var fakeEpisode = Builder<Episode>.CreateNew() var episode = episodeProvider.GetEpisodesByParseResult(parseResult, true);
.With(e => e.SeriesId = 1)
.With(e => e.SeasonNumber = 2)
.With(e => e.EpisodeNumber = 10)
.Build();
var fakeEpisode2 = Builder<Episode>.CreateNew() episode.Should().BeEmpty();
.With(e => e.SeriesId = 1) Db.Fetch<Episode>().Should().HaveCount(0);
.With(e => e.SeasonNumber = 2) }
.With(e => e.EpisodeNumber = 11)
.Build();
var fakeSeries = Builder<Series>.CreateNew().Build(); [Test]
public void single_none_existing_series_should_return_nothing_and_add_nothing()
{
var parseResult = new EpisodeParseResult
{
Series = fakeSeries,
SeasonNumber = 10,
EpisodeNumbers = new List<int> { 10 }
};
var episode = episodeProvider.GetEpisodesByParseResult(parseResult, true);
episode.Should().BeEmpty();
Db.Fetch<Episode>().Should().HaveCount(0);
}
[Test]
public void existing_multi_episode_should_return_all_episodes()
{
Db.Insert(fakeSeries);
Db.Insert(fakeEpisode); Db.Insert(fakeEpisode);
Db.Insert(fakeEpisode2); Db.Insert(fakeEpisode2);
Db.Insert(fakeSeries);
var parseResult = new EpisodeParseResult var parseResult = new EpisodeParseResult
{ {
Series = fakeSeries, Series = fakeSeries,
SeasonNumber = 2, SeasonNumber = fakeEpisode.SeasonNumber,
EpisodeNumbers = new List<int> { 10, 11 } EpisodeNumbers = new List<int> { fakeEpisode.EpisodeNumber, fakeEpisode2.EpisodeNumber }
}; };
var ep = Mocker.Resolve<EpisodeProvider>().GetEpisodesByParseResult(parseResult); var ep = episodeProvider.GetEpisodesByParseResult(parseResult, true);
ep.Should().HaveCount(2); ep.Should().HaveCount(2);
Db.Fetch<Episode>().Should().HaveCount(2); Db.Fetch<Episode>().Should().HaveCount(2);
ep.First().ShouldHave().AllPropertiesBut(e => e.Series);
VerifyEpisode(ep[0], fakeEpisode);
VerifyEpisode(ep[1], fakeEpisode2);
} }
[Test] [Test]
public void Multi_GetSeason_Episode_Doesnt_exists_should_not_add() public void none_existing_multi_episode_should_not_return_or_add_anything()
{ {
WithRealDb();
var fakeSeries = Builder<Series>.CreateNew().Build();
var parseResult = new EpisodeParseResult var parseResult = new EpisodeParseResult
{ {
Series = fakeSeries, Series = fakeSeries,
SeasonNumber = 2, SeasonNumber = fakeEpisode.SeasonNumber,
EpisodeNumbers = new List<int> { 10, 11 } EpisodeNumbers = new List<int> { fakeEpisode.EpisodeNumber, fakeEpisode2.EpisodeNumber }
}; };
var ep = Mocker.Resolve<EpisodeProvider>().GetEpisodesByParseResult(parseResult); var ep = episodeProvider.GetEpisodesByParseResult(parseResult,true);
ep.Should().BeEmpty(); ep.Should().BeEmpty();
Db.Fetch<Episode>().Should().HaveCount(0); Db.Fetch<Episode>().Should().HaveCount(0);
} }
[Test]
public void Multi_GetSeason_Episode_Doesnt_exists_should_add()
{
WithRealDb();
var fakeSeries = Builder<Series>.CreateNew().Build();
var parseResult = new EpisodeParseResult
{
Series = fakeSeries,
SeasonNumber = 2,
EpisodeNumbers = new List<int> { 10, 11 }
};
var ep = Mocker.Resolve<EpisodeProvider>().GetEpisodesByParseResult(parseResult, true);
ep.Should().HaveCount(2);
Db.Fetch<Episode>().Should().HaveCount(2);
}
[Test] [Test]
public void Get_Episode_Zero_Doesnt_Exist_Should_add_ignored()
{
WithRealDb();
var fakeSeries = Builder<Series>.CreateNew().Build();
var parseResult = new EpisodeParseResult
{
Series = fakeSeries,
SeasonNumber = 2,
EpisodeNumbers = new List<int> { 0 }
};
var ep = Mocker.Resolve<EpisodeProvider>().GetEpisodesByParseResult(parseResult, true);
ep.Should().HaveCount(1);
Db.Fetch<Episode>().Should().HaveCount(1);
ep.First().Ignored.Should().BeTrue();
}
[Test]
public void Get_Multi_Episode_Zero_Doesnt_Exist_Should_not_add_ignored()
{
WithRealDb();
var fakeSeries = Builder<Series>.CreateNew().Build();
var parseResult = new EpisodeParseResult
{
Series = fakeSeries,
SeasonNumber = 2,
EpisodeNumbers = new List<int> { 0, 1 }
};
var ep = Mocker.Resolve<EpisodeProvider>().GetEpisodesByParseResult(parseResult, true);
ep.Should().HaveCount(2);
Db.Fetch<Episode>().Should().HaveCount(2);
ep.First().Ignored.Should().BeFalse();
}
[Test]
[Description("GetEpisodeParseResult should return empty list if episode list is null")]
public void GetEpisodeParseResult_should_return_empty_list_if_episode_list_is_null() public void GetEpisodeParseResult_should_return_empty_list_if_episode_list_is_null()
{ {
//Act //Act
var episodes = Mocker.Resolve<EpisodeProvider>().GetEpisodesByParseResult(new EpisodeParseResult()); var episodes = episodeProvider.GetEpisodesByParseResult(new EpisodeParseResult());
//Assert //Assert
episodes.Should().NotBeNull(); episodes.Should().NotBeNull();
episodes.Should().BeEmpty(); episodes.Should().BeEmpty();
} }
[Test] [Test]
[Description("GetEpisodeParseResult should return empty list if episode list is empty")]
public void GetEpisodeParseResult_should_return_empty_list_if_episode_list_is_empty() public void GetEpisodeParseResult_should_return_empty_list_if_episode_list_is_empty()
{ {
//Act //Act
var episodes = var episodes = episodeProvider.GetEpisodesByParseResult(new EpisodeParseResult { EpisodeNumbers = new List<int>() });
Mocker.Resolve<EpisodeProvider>().GetEpisodesByParseResult(new EpisodeParseResult { EpisodeNumbers = new List<int>() });
//Assert //Assert
episodes.Should().NotBeNull(); episodes.Should().NotBeNull();
episodes.Should().BeEmpty(); episodes.Should().BeEmpty();
} }
[Test] [Test]
public void GetEpisodeParseResult_should_return_single_episode_when_air_date_is_provided() public void should_return_single_episode_when_air_date_is_provided()
{ {
//Setup
var fakeEpisode = Builder<Episode>.CreateListOfSize(1)
.All()
.With(e => e.AirDate = DateTime.Today)
.Build()
.ToList();
var fakeSeries = Builder<Series>.CreateNew() Db.Insert(fakeSeries);
.With(s => s.SeriesId = 1) Db.Insert(fakeDailyEpisode);
.With(s => s.IsDaily = true)
.Build();
Mocker.GetMock<IDatabase>().Setup(
s =>
s.Fetch<Episode, Series, EpisodeFile>(It.IsAny<String>(),
It.IsAny<Object[]>()))
.Returns(fakeEpisode);
//Act //Act
var episodes = Mocker.Resolve<EpisodeProvider>() var episodes = episodeProvider.GetEpisodesByParseResult(new EpisodeParseResult { AirDate = DateTime.Today, Series = fakeDailySeries },true);
.GetEpisodesByParseResult(new EpisodeParseResult { AirDate = DateTime.Today, Series = fakeSeries },
true);
//Assert //Assert
episodes.Should().HaveCount(1); episodes.Should().HaveCount(1);
episodes.First().AirDate.Should().Be(DateTime.Today); VerifyEpisode(episodes[0], fakeDailyEpisode);
Mocker.GetMock<IDatabase>().Verify(v => v.Insert(It.IsAny<Episode>()), Times.Never()); Db.Fetch<Episode>().Should().HaveCount(1);
} }
[Test] [Test]
public void GetEpisodeParseResult_get_daily_should_add_new_episode() public void should_not_add_episode_when_episode_doesnt_exist()
{ {
//Setup var episodes = episodeProvider.GetEpisodesByParseResult(new EpisodeParseResult { AirDate = DateTime.Today, Series = fakeDailySeries }, true);
WithRealDb();
var fakeSeries = Builder<Series>.CreateNew()
.With(s => s.SeriesId = 1)
.With(s => s.IsDaily = true)
.Build();
//Act
var episodes = Mocker.Resolve<EpisodeProvider>()
.GetEpisodesByParseResult(new EpisodeParseResult { AirDate = DateTime.Today, Series = fakeSeries },
true);
//Assert //Assert
episodes.Should().HaveCount(1); episodes.Should().HaveCount(0);
episodes.First().AirDate.Should().Be(DateTime.Today); Db.Fetch<Episode>().Should().HaveCount(0);
var episodesInDb = Db.Fetch<Episode>();
episodesInDb.Should().HaveCount(1);
} }
[Test]
public void GetEpisodeParseResult_get_daily_should_not_add_new_episode_when_auto_add_is_false()
{
//Setup
WithRealDb();
var fakeSeries = Builder<Series>.CreateNew()
.With(s => s.SeriesId = 1)
.With(s => s.IsDaily = true)
.Build();
//Act
var episodes = Mocker.Resolve<EpisodeProvider>()
.GetEpisodesByParseResult(new EpisodeParseResult { AirDate = DateTime.Today, Series = fakeSeries }, false);
//Assert
episodes.Should().BeEmpty();
Db.Fetch<Episode>().Should().BeEmpty();
}
[Test] [Test]
public void GetEpisodeParseResult_should_return_multiple_titles_for_multiple_episodes() public void GetEpisodeParseResult_should_return_multiple_titles_for_multiple_episodes()
{ {
WithRealDb(); Db.Insert(fakeSeries);
var fakeEpisode = Builder<Episode>.CreateNew()
.With(e => e.SeriesId = 1)
.With(e => e.SeasonNumber = 2)
.With(e => e.EpisodeNumber = 10)
.With(e => e.Title = "Title1")
.Build();
var fakeEpisode2 = Builder<Episode>.CreateNew()
.With(e => e.SeriesId = 1)
.With(e => e.SeasonNumber = 2)
.With(e => e.EpisodeNumber = 11)
.With(e => e.Title = "Title2")
.Build();
var fakeSeries = Builder<Series>.CreateNew().Build();
Db.Insert(fakeEpisode); Db.Insert(fakeEpisode);
Db.Insert(fakeEpisode2); Db.Insert(fakeEpisode2);
Db.Insert(fakeSeries);
var parseResult = new EpisodeParseResult var parseResult = new EpisodeParseResult
{ {
Series = fakeSeries, Series = fakeSeries,
SeasonNumber = 2, SeasonNumber = fakeEpisode.SeasonNumber,
EpisodeNumbers = new List<int> { fakeEpisode.EpisodeNumber, fakeEpisode2.EpisodeNumber } EpisodeNumbers = new List<int> { fakeEpisode.EpisodeNumber, fakeEpisode2.EpisodeNumber }
}; };
var ep = Mocker.Resolve<EpisodeProvider>().GetEpisodesByParseResult(parseResult); var ep = episodeProvider.GetEpisodesByParseResult(parseResult);
ep.Should().HaveCount(2); ep.Should().HaveCount(2);
Db.Fetch<Episode>().Should().HaveCount(2); Db.Fetch<Episode>().Should().HaveCount(2);
ep.First().ShouldHave().AllPropertiesBut(e => e.Series);
VerifyEpisode(ep[0], fakeEpisode);
VerifyEpisode(ep[1], fakeEpisode2);
parseResult.EpisodeTitle.Should().Be(fakeEpisode.Title + " + " + fakeEpisode2.Title); parseResult.EpisodeTitle.Should().Be(fakeEpisode.Title + " + " + fakeEpisode2.Title);
} }
[Test] [Test]
public void GetEpisodeParseResult_should_return_single_title_for_single_episode() public void GetEpisodeParseResult_should_return_single_title_for_single_episode()
{ {
WithRealDb();
var fakeEpisode = Builder<Episode>.CreateNew()
.With(e => e.SeriesId = 1)
.With(e => e.SeasonNumber = 2)
.With(e => e.EpisodeNumber = 10)
.With(e => e.Title = "Title1")
.Build();
var fakeSeries = Builder<Series>.CreateNew().Build();
Db.Insert(fakeEpisode); Db.Insert(fakeEpisode);
Db.Insert(fakeSeries); Db.Insert(fakeSeries);
var parseResult = new EpisodeParseResult var parseResult = new EpisodeParseResult
{ {
Series = fakeSeries, Series = fakeSeries,
SeasonNumber = 2, SeasonNumber = fakeEpisode.SeasonNumber,
EpisodeNumbers = new List<int> { fakeEpisode.EpisodeNumber } EpisodeNumbers = new List<int> { fakeEpisode.EpisodeNumber }
}; };
var ep = Mocker.Resolve<EpisodeProvider>().GetEpisodesByParseResult(parseResult); var ep = episodeProvider.GetEpisodesByParseResult(parseResult);
ep.Should().HaveCount(1); ep.Should().HaveCount(1);
Db.Fetch<Episode>().Should().HaveCount(1); Db.Fetch<Episode>().Should().HaveCount(1);
@ -390,14 +254,8 @@ namespace NzbDrone.Core.Test.ProviderTests
} }
[Test] [Test]
public void GetEpisodeParseResult_should_log_warning_when_series_is_not_dailt_but_parsed_daily() public void GetEpisodeParseResult_should_return_nothing_when_series_is_not_daily_but_parsed_daily()
{ {
WithRealDb();
var fakeSeries = Builder<Series>.CreateNew()
.With(s => s.IsDaily = false)
.Build();
Db.Insert(fakeSeries); Db.Insert(fakeSeries);
var parseResult = new EpisodeParseResult var parseResult = new EpisodeParseResult
@ -406,10 +264,15 @@ namespace NzbDrone.Core.Test.ProviderTests
AirDate = DateTime.Today AirDate = DateTime.Today
}; };
var ep = Mocker.Resolve<EpisodeProvider>().GetEpisodesByParseResult(parseResult); var ep = episodeProvider.GetEpisodesByParseResult(parseResult);
ep.Should().BeEmpty(); ep.Should().BeEmpty();
ExceptionVerification.ExpectedWarns(1); ExceptionVerification.ExpectedWarns(1);
} }
private void VerifyEpisode(Episode actual, Episode excpected)
{
actual.ShouldHave().AllProperties().But(e => e.Series).But(e => e.EpisodeFile).EqualTo(excpected);
}
} }
} }

View File

@ -123,6 +123,9 @@ namespace NzbDrone.Core.Providers
public virtual IList<Episode> GetEpisodesByParseResult(EpisodeParseResult parseResult, Boolean autoAddNew = false) public virtual IList<Episode> GetEpisodesByParseResult(EpisodeParseResult parseResult, Boolean autoAddNew = false)
{ {
//Disabling auto add, need to make it a lot more conservative.
autoAddNew = false;
var result = new List<Episode>(); var result = new List<Episode>();
if (parseResult.AirDate.HasValue) if (parseResult.AirDate.HasValue)