mirror of https://github.com/lidarr/Lidarr
PerformSearchFixture refactoring
This commit is contained in:
parent
80df59c8e7
commit
5f2762d608
|
@ -1,90 +1,49 @@
|
||||||
using System;
|
using System;
|
||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
using System.Linq;
|
using System.Linq;
|
||||||
using System.Text;
|
|
||||||
using FizzWare.NBuilder;
|
using FizzWare.NBuilder;
|
||||||
using FluentAssertions;
|
using FluentAssertions;
|
||||||
using Moq;
|
using Moq;
|
||||||
using NUnit.Framework;
|
using NUnit.Framework;
|
||||||
using NzbDrone.Core.Model;
|
using NzbDrone.Core.Model;
|
||||||
using NzbDrone.Core.Model.Notification;
|
|
||||||
using NzbDrone.Core.Providers;
|
using NzbDrone.Core.Providers;
|
||||||
using NzbDrone.Core.Providers.Indexer;
|
using NzbDrone.Core.Providers.Indexer;
|
||||||
using NzbDrone.Core.Repository;
|
using NzbDrone.Core.Repository;
|
||||||
using NzbDrone.Core.Test.Framework;
|
using NzbDrone.Core.Test.Framework;
|
||||||
using NzbDrone.Test.Common;
|
using NzbDrone.Test.Common;
|
||||||
using NzbDrone.Test.Common.AutoMoq;
|
|
||||||
|
|
||||||
namespace NzbDrone.Core.Test.ProviderTests.SearchProviderTests
|
namespace NzbDrone.Core.Test.ProviderTests.SearchProviderTests
|
||||||
{
|
{
|
||||||
public class PerformSearchFixture : CoreTest
|
public class PerformSearchFixture : CoreTest
|
||||||
{
|
{
|
||||||
private Mock<IndexerBase> _episodeIndexer1 = null;
|
private const string SCENE_NAME = "Scene Name";
|
||||||
private Mock<IndexerBase> _episodeIndexer2 = null;
|
private const int SEASON_NUMBER = 5;
|
||||||
private Mock<IndexerBase> _seasonIndexer1 = null;
|
private const int PARSE_RESULT_COUNT = 10;
|
||||||
private Mock<IndexerBase> _seasonIndexer2 = null;
|
|
||||||
private Mock<IndexerBase> _partialSeasonIndexer1 = null;
|
private Mock<IndexerBase> _episodeIndexer1;
|
||||||
private Mock<IndexerBase> _partialSeasonIndexer2 = null;
|
private Mock<IndexerBase> _episodeIndexer2;
|
||||||
private Mock<IndexerBase> _brokenIndexer = null;
|
private Mock<IndexerBase> _brokenIndexer;
|
||||||
private Mock<IndexerBase> _nullIndexer = null;
|
private Mock<IndexerBase> _nullIndexer;
|
||||||
|
|
||||||
private List<IndexerBase> _indexers;
|
private List<IndexerBase> _indexers;
|
||||||
|
|
||||||
private IList<EpisodeParseResult> _parseResults;
|
|
||||||
private Series _series;
|
private Series _series;
|
||||||
private IList<Episode> _episodes = null;
|
private IList<Episode> _episodes;
|
||||||
|
|
||||||
[SetUp]
|
[SetUp]
|
||||||
public void Setup()
|
public void Setup()
|
||||||
{
|
{
|
||||||
_parseResults = Builder<EpisodeParseResult>.CreateListOfSize(10)
|
var parseResults = Builder<EpisodeParseResult>.CreateListOfSize(PARSE_RESULT_COUNT)
|
||||||
.Build();
|
.Build();
|
||||||
|
|
||||||
_series = Builder<Series>.CreateNew()
|
_series = Builder<Series>.CreateNew()
|
||||||
.Build();
|
.Build();
|
||||||
|
|
||||||
BuildIndexers();
|
_episodes = Builder<Episode>.CreateListOfSize(1)
|
||||||
}
|
.Build();
|
||||||
|
|
||||||
private void BuildIndexers()
|
BuildIndexers(parseResults);
|
||||||
{
|
|
||||||
_episodeIndexer1 = new Mock<IndexerBase>();
|
|
||||||
_episodeIndexer1.Setup(c => c.FetchEpisode(It.IsAny<string>(), It.IsAny<int>(), It.IsAny<int>()))
|
|
||||||
.Returns(_parseResults);
|
|
||||||
|
|
||||||
_episodeIndexer2 = new Mock<IndexerBase>();
|
|
||||||
_episodeIndexer2.Setup(c => c.FetchEpisode(It.IsAny<string>(), It.IsAny<int>(), It.IsAny<int>()))
|
|
||||||
.Returns(_parseResults);
|
|
||||||
|
|
||||||
_seasonIndexer1 = new Mock<IndexerBase>();
|
|
||||||
_seasonIndexer1.Setup(c => c.FetchSeason(It.IsAny<string>(), It.IsAny<int>()))
|
|
||||||
.Returns(_parseResults);
|
|
||||||
|
|
||||||
_seasonIndexer2 = new Mock<IndexerBase>();
|
|
||||||
_seasonIndexer2.Setup(c => c.FetchSeason(It.IsAny<string>(), It.IsAny<int>()))
|
|
||||||
.Returns(_parseResults);
|
|
||||||
|
|
||||||
_partialSeasonIndexer1 = new Mock<IndexerBase>();
|
|
||||||
_partialSeasonIndexer1.Setup(c => c.FetchPartialSeason(It.IsAny<string>(), It.IsAny<int>(), It.IsAny<int>()))
|
|
||||||
.Returns(_parseResults);
|
|
||||||
|
|
||||||
_partialSeasonIndexer2 = new Mock<IndexerBase>();
|
|
||||||
_partialSeasonIndexer2.Setup(c => c.FetchPartialSeason(It.IsAny<string>(), It.IsAny<int>(), It.IsAny<int>()))
|
|
||||||
.Returns(_parseResults);
|
|
||||||
|
|
||||||
_brokenIndexer = new Mock<IndexerBase>();
|
|
||||||
_brokenIndexer.Setup(c => c.FetchEpisode(It.IsAny<string>(), It.IsAny<int>(), It.IsAny<int>()))
|
|
||||||
.Throws(new Exception());
|
|
||||||
|
|
||||||
List<EpisodeParseResult> nullResult = null;
|
|
||||||
|
|
||||||
_nullIndexer = new Mock<IndexerBase>();
|
|
||||||
_nullIndexer.Setup(c => c.FetchEpisode(It.IsAny<string>(), It.IsAny<int>(), It.IsAny<int>()))
|
|
||||||
.Returns(nullResult);
|
|
||||||
}
|
|
||||||
|
|
||||||
private void WithEpisodeIndexers()
|
|
||||||
{
|
|
||||||
_indexers = new List<IndexerBase> { _episodeIndexer1.Object, _episodeIndexer2.Object };
|
_indexers = new List<IndexerBase> { _episodeIndexer1.Object, _episodeIndexer2.Object };
|
||||||
|
|
||||||
Mocker.GetMock<IndexerProvider>()
|
Mocker.GetMock<IndexerProvider>()
|
||||||
|
@ -92,25 +51,35 @@ namespace NzbDrone.Core.Test.ProviderTests.SearchProviderTests
|
||||||
.Returns(_indexers);
|
.Returns(_indexers);
|
||||||
}
|
}
|
||||||
|
|
||||||
private void WithPartialSeasonIndexers()
|
private void BuildIndexers(IList<EpisodeParseResult> parseResults)
|
||||||
{
|
{
|
||||||
_indexers = new List<IndexerBase> { _partialSeasonIndexer1.Object, _partialSeasonIndexer2.Object };
|
_episodeIndexer1 = new Mock<IndexerBase>();
|
||||||
|
_episodeIndexer1.Setup(c => c.FetchEpisode(It.IsAny<string>(), It.IsAny<int>(), It.IsAny<int>()))
|
||||||
|
.Returns(parseResults);
|
||||||
|
_episodeIndexer1.Setup(c => c.FetchSeason(It.IsAny<string>(), It.IsAny<int>()))
|
||||||
|
.Returns(parseResults);
|
||||||
|
_episodeIndexer1.Setup(c => c.FetchPartialSeason(It.IsAny<string>(), It.IsAny<int>(), It.IsAny<int>()))
|
||||||
|
.Returns(parseResults);
|
||||||
|
|
||||||
Mocker.GetMock<IndexerProvider>()
|
|
||||||
.Setup(c => c.GetEnabledIndexers())
|
_episodeIndexer2 = new Mock<IndexerBase>();
|
||||||
.Returns(_indexers);
|
_episodeIndexer2.Setup(c => c.FetchEpisode(It.IsAny<string>(), It.IsAny<int>(), It.IsAny<int>()))
|
||||||
|
.Returns(parseResults);
|
||||||
|
_episodeIndexer2.Setup(c => c.FetchSeason(It.IsAny<string>(), It.IsAny<int>()))
|
||||||
|
.Returns(parseResults);
|
||||||
|
_episodeIndexer2.Setup(c => c.FetchPartialSeason(It.IsAny<string>(), It.IsAny<int>(), It.IsAny<int>()))
|
||||||
|
.Returns(parseResults);
|
||||||
|
|
||||||
|
_brokenIndexer = new Mock<IndexerBase>();
|
||||||
|
_brokenIndexer.Setup(c => c.FetchEpisode(It.IsAny<string>(), It.IsAny<int>(), It.IsAny<int>()))
|
||||||
|
.Throws(new Exception());
|
||||||
|
|
||||||
|
_nullIndexer = new Mock<IndexerBase>();
|
||||||
|
_nullIndexer.Setup(c => c.FetchEpisode(It.IsAny<string>(), It.IsAny<int>(), It.IsAny<int>()))
|
||||||
|
.Returns<List<EpisodeParseResult>>(null);
|
||||||
}
|
}
|
||||||
|
|
||||||
private void WithSeasonIndexers()
|
private void WithTwoGoodOneBrokenIndexer()
|
||||||
{
|
|
||||||
_indexers = new List<IndexerBase> { _seasonIndexer1.Object, _seasonIndexer2.Object };
|
|
||||||
|
|
||||||
Mocker.GetMock<IndexerProvider>()
|
|
||||||
.Setup(c => c.GetEnabledIndexers())
|
|
||||||
.Returns(_indexers);
|
|
||||||
}
|
|
||||||
|
|
||||||
private void WithBrokenIndexer()
|
|
||||||
{
|
{
|
||||||
_indexers = new List<IndexerBase> { _episodeIndexer1.Object, _brokenIndexer.Object, _episodeIndexer2.Object };
|
_indexers = new List<IndexerBase> { _episodeIndexer1.Object, _brokenIndexer.Object, _episodeIndexer2.Object };
|
||||||
|
|
||||||
|
@ -131,16 +100,10 @@ namespace NzbDrone.Core.Test.ProviderTests.SearchProviderTests
|
||||||
private void WithSceneName()
|
private void WithSceneName()
|
||||||
{
|
{
|
||||||
Mocker.GetMock<SceneMappingProvider>()
|
Mocker.GetMock<SceneMappingProvider>()
|
||||||
.Setup(s => s.GetSceneName(It.IsAny<int>())).Returns("Scene Name");
|
.Setup(s => s.GetSceneName(_series.SeriesId)).Returns(SCENE_NAME);
|
||||||
}
|
}
|
||||||
|
|
||||||
private void WithSingleEpisode()
|
private void With30Episodes()
|
||||||
{
|
|
||||||
_episodes = Builder<Episode>.CreateListOfSize(1)
|
|
||||||
.Build();
|
|
||||||
}
|
|
||||||
|
|
||||||
private void WithMultipleEpisodes()
|
|
||||||
{
|
{
|
||||||
_episodes = Builder<Episode>.CreateListOfSize(30)
|
_episodes = Builder<Episode>.CreateListOfSize(30)
|
||||||
.Build();
|
.Build();
|
||||||
|
@ -153,100 +116,96 @@ namespace NzbDrone.Core.Test.ProviderTests.SearchProviderTests
|
||||||
|
|
||||||
private void VerifyFetchEpisode(Times times)
|
private void VerifyFetchEpisode(Times times)
|
||||||
{
|
{
|
||||||
_episodeIndexer1.Verify(v => v.FetchEpisode(It.IsAny<string>(), It.IsAny<int>(), It.IsAny<int>())
|
_episodeIndexer1.Verify(v => v.FetchEpisode(_series.Title, SEASON_NUMBER, It.IsAny<int>())
|
||||||
, times);
|
, times);
|
||||||
|
|
||||||
_episodeIndexer2.Verify(v => v.FetchEpisode(It.IsAny<string>(), It.IsAny<int>(), It.IsAny<int>())
|
_episodeIndexer2.Verify(v => v.FetchEpisode(_series.Title, SEASON_NUMBER, It.IsAny<int>())
|
||||||
|
, times);
|
||||||
|
}
|
||||||
|
|
||||||
|
private void VerifyFetchEpisodeWithSceneName(Times times)
|
||||||
|
{
|
||||||
|
_episodeIndexer1.Verify(v => v.FetchEpisode(SCENE_NAME, SEASON_NUMBER, It.IsAny<int>())
|
||||||
|
, times);
|
||||||
|
|
||||||
|
_episodeIndexer2.Verify(v => v.FetchEpisode(SCENE_NAME, SEASON_NUMBER, It.IsAny<int>())
|
||||||
, times);
|
, times);
|
||||||
}
|
}
|
||||||
|
|
||||||
private void VerifyFetchEpisodeBrokenIndexer(Times times)
|
private void VerifyFetchEpisodeBrokenIndexer(Times times)
|
||||||
{
|
{
|
||||||
_brokenIndexer.Verify(v => v.FetchEpisode(It.IsAny<string>(), It.IsAny<int>(), It.IsAny<int>())
|
_brokenIndexer.Verify(v => v.FetchEpisode(It.IsAny<string>(), SEASON_NUMBER, It.IsAny<int>())
|
||||||
, times);
|
, times);
|
||||||
}
|
}
|
||||||
|
|
||||||
private void VerifyFetchPartialSeason(Times times)
|
private void VerifyFetchPartialSeason(Times times)
|
||||||
{
|
{
|
||||||
_partialSeasonIndexer1.Verify(v => v.FetchPartialSeason(It.IsAny<string>(), It.IsAny<int>(), It.IsAny<int>())
|
_episodeIndexer1.Verify(v => v.FetchPartialSeason(_series.Title, SEASON_NUMBER, It.IsAny<int>())
|
||||||
, times);
|
, times);
|
||||||
|
|
||||||
_partialSeasonIndexer2.Verify(v => v.FetchPartialSeason(It.IsAny<string>(), It.IsAny<int>(), It.IsAny<int>())
|
_episodeIndexer2.Verify(v => v.FetchPartialSeason(_series.Title, SEASON_NUMBER, It.IsAny<int>())
|
||||||
, times);
|
, times);
|
||||||
}
|
}
|
||||||
|
|
||||||
private void VerifyFetchSeason(Times times)
|
private void VerifyFetchSeason(Times times)
|
||||||
{
|
{
|
||||||
_seasonIndexer1.Verify(v => v.FetchSeason(It.IsAny<string>(), It.IsAny<int>())
|
_episodeIndexer1.Verify(v => v.FetchSeason(_series.Title, SEASON_NUMBER), times);
|
||||||
, times);
|
_episodeIndexer1.Verify(v => v.FetchSeason(_series.Title, SEASON_NUMBER), times);
|
||||||
|
|
||||||
_seasonIndexer1.Verify(v => v.FetchSeason(It.IsAny<string>(), It.IsAny<int>())
|
|
||||||
, times);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
[Test]
|
[Test]
|
||||||
public void PerformSearch_should_search_all_enabled_providers()
|
public void PerformSearch_should_search_all_enabled_providers()
|
||||||
{
|
{
|
||||||
//Setup
|
|
||||||
WithEpisodeIndexers();
|
|
||||||
WithSingleEpisode();
|
|
||||||
|
|
||||||
//Act
|
//Act
|
||||||
var result = Mocker.Resolve<SearchProvider>().PerformSearch(new ProgressNotification("Test"), _series, 1, _episodes);
|
var result = Mocker.Resolve<SearchProvider>().PerformSearch(MockNotification, _series, SEASON_NUMBER, _episodes);
|
||||||
|
|
||||||
//Assert
|
//Assert
|
||||||
VerifyFetchEpisode(Times.Once());
|
VerifyFetchEpisode(Times.Once());
|
||||||
result.Should().HaveCount(20);
|
result.Should().HaveCount(PARSE_RESULT_COUNT * 2);
|
||||||
}
|
}
|
||||||
|
|
||||||
[Test]
|
[Test]
|
||||||
public void PerformSearch_should_look_for_scene_name_to_search()
|
public void PerformSearch_should_look_for_scene_name_to_search()
|
||||||
{
|
{
|
||||||
//Setup
|
|
||||||
WithSceneName();
|
WithSceneName();
|
||||||
WithEpisodeIndexers();
|
|
||||||
WithSingleEpisode();
|
|
||||||
|
|
||||||
//Act
|
//Act
|
||||||
var result = Mocker.Resolve<SearchProvider>().PerformSearch(new ProgressNotification("Test"), _series, 1, _episodes);
|
Mocker.Resolve<SearchProvider>().PerformSearch(MockNotification, _series, 1, _episodes);
|
||||||
|
|
||||||
//Assert
|
//Assert
|
||||||
Mocker.GetMock<SceneMappingProvider>().Verify(c => c.GetSceneName(It.IsAny<int>()),
|
Mocker.GetMock<SceneMappingProvider>().Verify(c => c.GetSceneName(_series.SeriesId),
|
||||||
Times.Once());
|
Times.Once());
|
||||||
}
|
}
|
||||||
|
|
||||||
[Test]
|
[Test]
|
||||||
public void PerformSearch_broken_indexer_should_not_break_job()
|
public void broken_indexer_should_not_block_other_indexers()
|
||||||
{
|
{
|
||||||
//Setup
|
//Setup
|
||||||
WithBrokenIndexer();
|
WithTwoGoodOneBrokenIndexer();
|
||||||
WithSingleEpisode();
|
|
||||||
|
|
||||||
//Act
|
//Act
|
||||||
var result = Mocker.Resolve<SearchProvider>().PerformSearch(new ProgressNotification("Test"), _series, 1, _episodes);
|
var result = Mocker.Resolve<SearchProvider>().PerformSearch(MockNotification, _series, SEASON_NUMBER, _episodes);
|
||||||
|
|
||||||
//Assert
|
//Assert
|
||||||
result.Should().HaveCount(20);
|
result.Should().HaveCount(PARSE_RESULT_COUNT * 2);
|
||||||
ExceptionVerification.ExcpectedErrors(1);
|
|
||||||
VerifyFetchEpisode(Times.Once());
|
VerifyFetchEpisode(Times.Once());
|
||||||
VerifyFetchEpisodeBrokenIndexer(Times.Once());
|
VerifyFetchEpisodeBrokenIndexer(Times.Once());
|
||||||
|
|
||||||
Mocker.GetMock<SceneMappingProvider>().Verify(c => c.GetSceneName(It.IsAny<int>()),
|
Mocker.GetMock<SceneMappingProvider>().Verify(c => c.GetSceneName(_series.SeriesId),
|
||||||
Times.Once());
|
Times.Once());
|
||||||
|
|
||||||
|
ExceptionVerification.ExcpectedErrors(1);
|
||||||
}
|
}
|
||||||
|
|
||||||
[Test]
|
[Test]
|
||||||
public void PerformSearch_for_episode_should_call_FetchEpisode()
|
public void PerformSearch_for_episode_should_call_FetchEpisode()
|
||||||
{
|
{
|
||||||
//Setup
|
|
||||||
WithEpisodeIndexers();
|
|
||||||
WithSingleEpisode();
|
|
||||||
|
|
||||||
//Act
|
//Act
|
||||||
var result = Mocker.Resolve<SearchProvider>().PerformSearch(new ProgressNotification("Test"), _series, 1, _episodes);
|
var result = Mocker.Resolve<SearchProvider>().PerformSearch(MockNotification, _series, SEASON_NUMBER, _episodes);
|
||||||
|
|
||||||
//Assert
|
//Assert
|
||||||
result.Should().HaveCount(20);
|
result.Should().HaveCount(PARSE_RESULT_COUNT * 2);
|
||||||
|
|
||||||
VerifyFetchEpisode(Times.Once());
|
VerifyFetchEpisode(Times.Once());
|
||||||
}
|
}
|
||||||
|
@ -254,12 +213,10 @@ namespace NzbDrone.Core.Test.ProviderTests.SearchProviderTests
|
||||||
[Test]
|
[Test]
|
||||||
public void PerformSearch_for_partial_season_should_call_FetchPartialSeason()
|
public void PerformSearch_for_partial_season_should_call_FetchPartialSeason()
|
||||||
{
|
{
|
||||||
//Setup
|
With30Episodes();
|
||||||
WithPartialSeasonIndexers();
|
|
||||||
WithMultipleEpisodes();
|
|
||||||
|
|
||||||
//Act
|
//Act
|
||||||
var result = Mocker.Resolve<SearchProvider>().PerformSearch(new ProgressNotification("Test"), _series, 1, _episodes);
|
var result = Mocker.Resolve<SearchProvider>().PerformSearch(MockNotification, _series, SEASON_NUMBER, _episodes);
|
||||||
|
|
||||||
//Assert
|
//Assert
|
||||||
result.Should().HaveCount(80);
|
result.Should().HaveCount(80);
|
||||||
|
@ -269,12 +226,10 @@ namespace NzbDrone.Core.Test.ProviderTests.SearchProviderTests
|
||||||
[Test]
|
[Test]
|
||||||
public void PerformSearch_for_season_should_call_FetchSeason()
|
public void PerformSearch_for_season_should_call_FetchSeason()
|
||||||
{
|
{
|
||||||
//Setup
|
|
||||||
WithSeasonIndexers();
|
|
||||||
WithNullEpisodes();
|
WithNullEpisodes();
|
||||||
|
|
||||||
//Act
|
//Act
|
||||||
var result = Mocker.Resolve<SearchProvider>().PerformSearch(new ProgressNotification("Test"), _series, 1, _episodes);
|
var result = Mocker.Resolve<SearchProvider>().PerformSearch(MockNotification, _series, SEASON_NUMBER, _episodes);
|
||||||
|
|
||||||
//Assert
|
//Assert
|
||||||
result.Should().HaveCount(20);
|
result.Should().HaveCount(20);
|
||||||
|
@ -286,14 +241,24 @@ namespace NzbDrone.Core.Test.ProviderTests.SearchProviderTests
|
||||||
{
|
{
|
||||||
//Setup
|
//Setup
|
||||||
WithNullIndexers();
|
WithNullIndexers();
|
||||||
WithSingleEpisode();
|
|
||||||
|
|
||||||
//Act
|
//Act
|
||||||
var result = Mocker.Resolve<SearchProvider>().PerformSearch(new ProgressNotification("Test"), _series, 1, _episodes);
|
var result = Mocker.Resolve<SearchProvider>().PerformSearch(MockNotification, _series, SEASON_NUMBER, _episodes);
|
||||||
|
|
||||||
//Assert
|
//Assert
|
||||||
ExceptionVerification.ExcpectedErrors(2);
|
|
||||||
result.Should().HaveCount(0);
|
result.Should().HaveCount(0);
|
||||||
}
|
ExceptionVerification.ExcpectedErrors(2);
|
||||||
|
}
|
||||||
|
|
||||||
|
[Test]
|
||||||
|
public void should_use_scene_name_to_search_for_episode_when_avilable()
|
||||||
|
{
|
||||||
|
WithSceneName();
|
||||||
|
|
||||||
|
Mocker.Resolve<SearchProvider>().PerformSearch(MockNotification, _series, SEASON_NUMBER, _episodes);
|
||||||
|
|
||||||
|
VerifyFetchEpisodeWithSceneName(Times.Once());
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue