2011-11-24 04:09:09 +03:00
|
|
|
using System;
|
|
|
|
using System.Collections.Generic;
|
|
|
|
using System.Linq;
|
|
|
|
|
|
|
|
using FizzWare.NBuilder;
|
2012-01-24 09:29:32 +03:00
|
|
|
using FluentAssertions;
|
2011-11-24 04:09:09 +03:00
|
|
|
using Moq;
|
|
|
|
using NUnit.Framework;
|
2011-12-02 04:33:17 +03:00
|
|
|
using NzbDrone.Core.Jobs;
|
2012-01-24 09:29:32 +03:00
|
|
|
using NzbDrone.Core.Model;
|
2011-11-24 04:09:09 +03:00
|
|
|
using NzbDrone.Core.Model.Notification;
|
|
|
|
using NzbDrone.Core.Providers;
|
2012-01-15 05:05:05 +03:00
|
|
|
using NzbDrone.Core.Providers.Core;
|
2011-11-24 04:09:09 +03:00
|
|
|
using NzbDrone.Core.Repository;
|
|
|
|
using NzbDrone.Core.Test.Framework;
|
2012-09-11 09:35:25 +03:00
|
|
|
using NzbDrone.Test.Common;
|
2011-11-24 04:09:09 +03:00
|
|
|
using NzbDrone.Test.Common.AutoMoq;
|
|
|
|
|
|
|
|
namespace NzbDrone.Core.Test.JobTests
|
|
|
|
{
|
|
|
|
[TestFixture]
|
2013-02-17 08:44:06 +03:00
|
|
|
public class RecentBacklogSearchJobTest : CoreTest
|
2011-11-24 04:09:09 +03:00
|
|
|
{
|
2012-01-15 05:05:05 +03:00
|
|
|
private void WithEnableBacklogSearching()
|
|
|
|
{
|
|
|
|
Mocker.GetMock<ConfigProvider>().SetupGet(s => s.EnableBacklogSearching).Returns(true);
|
|
|
|
}
|
|
|
|
|
2011-11-24 04:09:09 +03:00
|
|
|
[SetUp]
|
|
|
|
public void Setup()
|
|
|
|
{
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
[Test]
|
|
|
|
public void no_missing_epsiodes_should_not_trigger_any_search()
|
|
|
|
{
|
|
|
|
//Setup
|
|
|
|
var episodes = new List<Episode>();
|
|
|
|
|
|
|
|
Mocker.GetMock<EpisodeProvider>()
|
|
|
|
.Setup(s => s.EpisodesWithoutFiles(true)).Returns(episodes);
|
|
|
|
|
|
|
|
//Act
|
2012-09-10 22:04:17 +03:00
|
|
|
Mocker.Resolve<RecentBacklogSearchJob>().Start(MockNotification, null);
|
2011-11-24 04:09:09 +03:00
|
|
|
|
|
|
|
//Assert
|
2012-09-10 22:04:17 +03:00
|
|
|
Mocker.GetMock<EpisodeSearchJob>().Verify(c => c.Start(MockNotification, new { EpisodeId = It.IsAny<int>() }),
|
2011-11-24 04:09:09 +03:00
|
|
|
Times.Never());
|
|
|
|
}
|
|
|
|
|
|
|
|
[Test]
|
|
|
|
public void should_only_process_missing_episodes_from_the_last_30_days()
|
|
|
|
{
|
2012-01-15 05:05:05 +03:00
|
|
|
WithEnableBacklogSearching();
|
|
|
|
|
2012-01-24 09:29:32 +03:00
|
|
|
var series = Builder<Series>.CreateNew()
|
|
|
|
.With(s => s.Monitored = true)
|
2012-01-26 04:02:21 +03:00
|
|
|
.With(s => s.BacklogSetting = BacklogSettingType.Enable)
|
2012-01-24 09:29:32 +03:00
|
|
|
.Build();
|
|
|
|
|
2011-11-24 04:09:09 +03:00
|
|
|
//Setup
|
|
|
|
var episodes = Builder<Episode>.CreateListOfSize(50)
|
2012-01-24 09:29:32 +03:00
|
|
|
.All()
|
|
|
|
.With(e => e.Series = series)
|
2011-11-24 04:09:09 +03:00
|
|
|
.TheFirst(5)
|
|
|
|
.With(e => e.AirDate = DateTime.Today)
|
|
|
|
.TheNext(5)
|
|
|
|
.With(e => e.AirDate = DateTime.Today.AddDays(-1)) //Today
|
|
|
|
.TheNext(5)
|
|
|
|
.With(e => e.AirDate = DateTime.Today.AddDays(-5)) //Yeserday
|
|
|
|
.TheNext(5)
|
|
|
|
.With(e => e.AirDate = DateTime.Today.AddDays(-10))
|
|
|
|
.TheNext(5)
|
|
|
|
.With(e => e.AirDate = DateTime.Today.AddDays(-15))
|
|
|
|
.TheNext(5)
|
|
|
|
.With(e => e.AirDate = DateTime.Today.AddDays(-20))
|
|
|
|
.TheNext(5)
|
|
|
|
.With(e => e.AirDate = DateTime.Today.AddDays(-25))
|
|
|
|
.TheNext(5)
|
|
|
|
.With(e => e.AirDate = DateTime.Today.AddDays(-30))
|
|
|
|
.TheNext(5)
|
|
|
|
.With(e => e.AirDate = DateTime.Today.AddDays(-31)) //31 Days
|
|
|
|
.TheNext(5)
|
|
|
|
.With(e => e.AirDate = DateTime.Today.AddDays(-35))
|
|
|
|
.Build();
|
|
|
|
|
|
|
|
Mocker.GetMock<EpisodeProvider>()
|
|
|
|
.Setup(s => s.EpisodesWithoutFiles(true)).Returns(episodes);
|
|
|
|
|
2012-09-11 09:35:25 +03:00
|
|
|
Mocker.GetMock<EpisodeSearchJob>().Setup(c => c.Start(It.IsAny<ProgressNotification>(), It.Is<object>(d => d.GetPropertyValue<int>("EpisodeId") >= 0)));
|
2011-11-24 04:09:09 +03:00
|
|
|
|
|
|
|
//Act
|
2012-09-10 22:04:17 +03:00
|
|
|
Mocker.Resolve<RecentBacklogSearchJob>().Start(MockNotification, null);
|
2011-11-24 04:09:09 +03:00
|
|
|
|
|
|
|
//Assert
|
2012-09-11 09:35:25 +03:00
|
|
|
Mocker.GetMock<EpisodeSearchJob>().Verify(c => c.Start(It.IsAny<ProgressNotification>(), It.Is<object>(d => d.GetPropertyValue<int>("EpisodeId") >= 0)),
|
2011-11-24 04:09:09 +03:00
|
|
|
Times.Exactly(40));
|
|
|
|
}
|
2012-01-24 09:29:32 +03:00
|
|
|
|
|
|
|
[Test]
|
|
|
|
public void GetMissingForEnabledSeries_should_only_return_episodes_for_monitored_series()
|
|
|
|
{
|
|
|
|
//Setup
|
|
|
|
var series = Builder<Series>.CreateListOfSize(2)
|
|
|
|
.TheFirst(1)
|
|
|
|
.With(s => s.Monitored = false)
|
2012-01-26 04:02:21 +03:00
|
|
|
.With(s => s.BacklogSetting = BacklogSettingType.Enable)
|
2012-01-24 09:29:32 +03:00
|
|
|
.TheNext(1)
|
|
|
|
.With(s => s.Monitored = true)
|
2012-01-26 04:02:21 +03:00
|
|
|
.With(s => s.BacklogSetting = BacklogSettingType.Enable)
|
2012-01-24 09:29:32 +03:00
|
|
|
.Build();
|
|
|
|
|
|
|
|
var episodes = Builder<Episode>.CreateListOfSize(11)
|
|
|
|
.TheFirst(5)
|
|
|
|
.With(e => e.Series = series[0])
|
|
|
|
.With(e => e.SeasonNumber = 1)
|
|
|
|
.TheLast(6)
|
|
|
|
.With(e => e.Series = series[1])
|
|
|
|
.Build();
|
|
|
|
|
|
|
|
WithEnableBacklogSearching();
|
|
|
|
|
|
|
|
Mocker.GetMock<EpisodeProvider>()
|
|
|
|
.Setup(s => s.EpisodesWithoutFiles(true)).Returns(episodes);
|
|
|
|
|
|
|
|
//Act
|
|
|
|
var result = Mocker.Resolve<RecentBacklogSearchJob>().GetMissingForEnabledSeries();
|
|
|
|
|
|
|
|
//Assert
|
|
|
|
result.Should().NotBeEmpty();
|
|
|
|
result.Should().Contain(s => s.Series.Monitored);
|
|
|
|
result.Should().NotContain(s => !s.Series.Monitored);
|
|
|
|
}
|
|
|
|
|
|
|
|
[Test]
|
|
|
|
public void GetMissingForEnabledSeries_should_only_return_explicity_enabled_series_when_backlog_searching_is_ignored()
|
|
|
|
{
|
|
|
|
//Setup
|
|
|
|
var series = Builder<Series>.CreateListOfSize(3)
|
|
|
|
.TheFirst(1)
|
|
|
|
.With(s => s.Monitored = true)
|
2012-01-26 04:02:21 +03:00
|
|
|
.With(s => s.BacklogSetting = BacklogSettingType.Disable)
|
2012-01-24 09:29:32 +03:00
|
|
|
.TheNext(1)
|
|
|
|
.With(s => s.Monitored = true)
|
2012-01-26 04:02:21 +03:00
|
|
|
.With(s => s.BacklogSetting = BacklogSettingType.Enable)
|
2012-01-24 09:29:32 +03:00
|
|
|
.TheNext(1)
|
|
|
|
.With(s => s.Monitored = true)
|
2012-01-26 04:02:21 +03:00
|
|
|
.With(s => s.BacklogSetting = BacklogSettingType.Inherit)
|
2012-01-24 09:29:32 +03:00
|
|
|
.Build();
|
|
|
|
|
|
|
|
var episodes = Builder<Episode>.CreateListOfSize(12)
|
|
|
|
.TheFirst(3)
|
|
|
|
.With(e => e.Series = series[0])
|
|
|
|
.TheNext(4)
|
|
|
|
.With(e => e.Series = series[1])
|
|
|
|
.TheNext(5)
|
|
|
|
.With(e => e.Series = series[2])
|
|
|
|
.Build();
|
|
|
|
|
|
|
|
//WithEnableBacklogSearching();
|
|
|
|
|
|
|
|
Mocker.GetMock<EpisodeProvider>()
|
|
|
|
.Setup(s => s.EpisodesWithoutFiles(true)).Returns(episodes);
|
|
|
|
|
|
|
|
//Act
|
|
|
|
var result = Mocker.Resolve<RecentBacklogSearchJob>().GetMissingForEnabledSeries();
|
|
|
|
|
|
|
|
//Assert
|
|
|
|
result.Should().NotBeEmpty();
|
2012-01-26 04:02:21 +03:00
|
|
|
result.Should().Contain(s => s.Series.BacklogSetting == BacklogSettingType.Enable);
|
|
|
|
result.Should().NotContain(s => s.Series.BacklogSetting == BacklogSettingType.Disable);
|
|
|
|
result.Should().NotContain(s => s.Series.BacklogSetting == BacklogSettingType.Inherit);
|
2012-01-24 09:29:32 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
[Test]
|
|
|
|
public void GetMissingForEnabledSeries_should_return_explicity_enabled_and_inherit_series_when_backlog_searching_is_enabled()
|
|
|
|
{
|
|
|
|
//Setup
|
|
|
|
var series = Builder<Series>.CreateListOfSize(3)
|
|
|
|
.TheFirst(1)
|
|
|
|
.With(s => s.Monitored = true)
|
2012-01-26 04:02:21 +03:00
|
|
|
.With(s => s.BacklogSetting = BacklogSettingType.Disable)
|
2012-01-24 09:29:32 +03:00
|
|
|
.TheNext(1)
|
|
|
|
.With(s => s.Monitored = true)
|
2012-01-26 04:02:21 +03:00
|
|
|
.With(s => s.BacklogSetting = BacklogSettingType.Enable)
|
2012-01-24 09:29:32 +03:00
|
|
|
.TheNext(1)
|
|
|
|
.With(s => s.Monitored = true)
|
2012-01-26 04:02:21 +03:00
|
|
|
.With(s => s.BacklogSetting = BacklogSettingType.Inherit)
|
2012-01-24 09:29:32 +03:00
|
|
|
.Build();
|
|
|
|
|
|
|
|
var episodes = Builder<Episode>.CreateListOfSize(12)
|
|
|
|
.TheFirst(3)
|
|
|
|
.With(e => e.Series = series[0])
|
|
|
|
.TheNext(4)
|
|
|
|
.With(e => e.Series = series[1])
|
|
|
|
.TheNext(5)
|
|
|
|
.With(e => e.Series = series[2])
|
|
|
|
.Build();
|
|
|
|
|
|
|
|
WithEnableBacklogSearching();
|
|
|
|
|
|
|
|
Mocker.GetMock<EpisodeProvider>()
|
|
|
|
.Setup(s => s.EpisodesWithoutFiles(true)).Returns(episodes);
|
|
|
|
|
|
|
|
//Act
|
|
|
|
var result = Mocker.Resolve<RecentBacklogSearchJob>().GetMissingForEnabledSeries();
|
|
|
|
|
|
|
|
//Assert
|
|
|
|
result.Should().NotBeEmpty();
|
2012-01-26 04:02:21 +03:00
|
|
|
result.Should().Contain(s => s.Series.BacklogSetting == BacklogSettingType.Enable);
|
|
|
|
result.Should().NotContain(s => s.Series.BacklogSetting == BacklogSettingType.Disable);
|
|
|
|
result.Should().Contain(s => s.Series.BacklogSetting == BacklogSettingType.Inherit);
|
2012-01-24 09:29:32 +03:00
|
|
|
}
|
|
|
|
|
2011-11-24 04:09:09 +03:00
|
|
|
}
|
|
|
|
}
|