|
|
@ -1,31 +1,47 @@
|
|
|
|
using System.Collections.Generic;
|
|
|
|
using System;
|
|
|
|
|
|
|
|
using System.Collections.Generic;
|
|
|
|
using System.Linq;
|
|
|
|
using System.Linq;
|
|
|
|
|
|
|
|
using FizzWare.NBuilder;
|
|
|
|
using Moq;
|
|
|
|
using Moq;
|
|
|
|
using NUnit.Framework;
|
|
|
|
using NUnit.Framework;
|
|
|
|
|
|
|
|
using NzbDrone.Common.Crypto;
|
|
|
|
using NzbDrone.Core.Download.Pending;
|
|
|
|
using NzbDrone.Core.Download.Pending;
|
|
|
|
|
|
|
|
using NzbDrone.Core.Parser;
|
|
|
|
using NzbDrone.Core.Parser.Model;
|
|
|
|
using NzbDrone.Core.Parser.Model;
|
|
|
|
using NzbDrone.Core.Test.Framework;
|
|
|
|
using NzbDrone.Core.Test.Framework;
|
|
|
|
|
|
|
|
using NzbDrone.Core.Tv;
|
|
|
|
|
|
|
|
|
|
|
|
namespace NzbDrone.Core.Test.Download.Pending.PendingReleaseServiceTests
|
|
|
|
namespace NzbDrone.Core.Test.Download.Pending.PendingReleaseServiceTests
|
|
|
|
{
|
|
|
|
{
|
|
|
|
[TestFixture]
|
|
|
|
[TestFixture]
|
|
|
|
public class RemovePendingFixture : CoreTest<PendingReleaseService>
|
|
|
|
public class RemovePendingFixture : CoreTest<PendingReleaseService>
|
|
|
|
{
|
|
|
|
{
|
|
|
|
|
|
|
|
|
|
|
|
private List<PendingRelease> _pending;
|
|
|
|
private List<PendingRelease> _pending;
|
|
|
|
|
|
|
|
private Episode _episode;
|
|
|
|
|
|
|
|
|
|
|
|
[SetUp]
|
|
|
|
[SetUp]
|
|
|
|
public void Setup()
|
|
|
|
public void Setup()
|
|
|
|
{
|
|
|
|
{
|
|
|
|
_pending = new List<PendingRelease>();
|
|
|
|
_pending = new List<PendingRelease>();
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
_episode = Builder<Episode>.CreateNew()
|
|
|
|
|
|
|
|
.Build();
|
|
|
|
|
|
|
|
|
|
|
|
Mocker.GetMock<IPendingReleaseRepository>()
|
|
|
|
Mocker.GetMock<IPendingReleaseRepository>()
|
|
|
|
.Setup(s => s.AllBySeriesId(It.IsAny<int>()))
|
|
|
|
.Setup(s => s.AllBySeriesId(It.IsAny<int>()))
|
|
|
|
.Returns(_pending);
|
|
|
|
.Returns(_pending);
|
|
|
|
|
|
|
|
|
|
|
|
Mocker.GetMock<IPendingReleaseRepository>()
|
|
|
|
Mocker.GetMock<IPendingReleaseRepository>()
|
|
|
|
.Setup(s => s.Get(It.IsAny<int>()))
|
|
|
|
.Setup(s => s.All())
|
|
|
|
.Returns<int>(r => _pending.Single(c => c.Id == r));
|
|
|
|
.Returns( _pending);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
Mocker.GetMock<ISeriesService>()
|
|
|
|
|
|
|
|
.Setup(s => s.GetSeries(It.IsAny<int>()))
|
|
|
|
|
|
|
|
.Returns(new Series());
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
Mocker.GetMock<IParsingService>()
|
|
|
|
|
|
|
|
.Setup(s => s.GetEpisodes(It.IsAny<ParsedEpisodeInfo>(), It.IsAny<Series>(), It.IsAny<bool>(), null))
|
|
|
|
|
|
|
|
.Returns(new List<Episode>{ _episode });
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
private void AddPending(int id, int seasonNumber, int[] episodes)
|
|
|
|
private void AddPending(int id, int seasonNumber, int[] episodes)
|
|
|
@ -42,12 +58,13 @@ namespace NzbDrone.Core.Test.Download.Pending.PendingReleaseServiceTests
|
|
|
|
{
|
|
|
|
{
|
|
|
|
AddPending(id: 1, seasonNumber: 2, episodes: new[] { 3 });
|
|
|
|
AddPending(id: 1, seasonNumber: 2, episodes: new[] { 3 });
|
|
|
|
|
|
|
|
|
|
|
|
Subject.RemovePendingQueueItems(1);
|
|
|
|
var queueId = HashConverter.GetHashInt31(String.Format("pending-{0}-ep{1}", 1, _episode.Id));
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
Subject.RemovePendingQueueItems(queueId);
|
|
|
|
|
|
|
|
|
|
|
|
AssertRemoved(1);
|
|
|
|
AssertRemoved(1);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
[Test]
|
|
|
|
[Test]
|
|
|
|
public void should_remove_multiple_releases_release()
|
|
|
|
public void should_remove_multiple_releases_release()
|
|
|
|
{
|
|
|
|
{
|
|
|
@ -56,7 +73,9 @@ namespace NzbDrone.Core.Test.Download.Pending.PendingReleaseServiceTests
|
|
|
|
AddPending(id: 3, seasonNumber: 2, episodes: new[] { 3 });
|
|
|
|
AddPending(id: 3, seasonNumber: 2, episodes: new[] { 3 });
|
|
|
|
AddPending(id: 4, seasonNumber: 2, episodes: new[] { 3 });
|
|
|
|
AddPending(id: 4, seasonNumber: 2, episodes: new[] { 3 });
|
|
|
|
|
|
|
|
|
|
|
|
Subject.RemovePendingQueueItems(3);
|
|
|
|
var queueId = HashConverter.GetHashInt31(String.Format("pending-{0}-ep{1}", 3, _episode.Id));
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
Subject.RemovePendingQueueItems(queueId);
|
|
|
|
|
|
|
|
|
|
|
|
AssertRemoved(3, 4);
|
|
|
|
AssertRemoved(3, 4);
|
|
|
|
}
|
|
|
|
}
|
|
|
@ -69,7 +88,9 @@ namespace NzbDrone.Core.Test.Download.Pending.PendingReleaseServiceTests
|
|
|
|
AddPending(id: 3, seasonNumber: 3, episodes: new[] { 1 });
|
|
|
|
AddPending(id: 3, seasonNumber: 3, episodes: new[] { 1 });
|
|
|
|
AddPending(id: 4, seasonNumber: 3, episodes: new[] { 1 });
|
|
|
|
AddPending(id: 4, seasonNumber: 3, episodes: new[] { 1 });
|
|
|
|
|
|
|
|
|
|
|
|
Subject.RemovePendingQueueItems(1);
|
|
|
|
var queueId = HashConverter.GetHashInt31(String.Format("pending-{0}-ep{1}", 1, _episode.Id));
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
Subject.RemovePendingQueueItems(queueId);
|
|
|
|
|
|
|
|
|
|
|
|
AssertRemoved(1, 2);
|
|
|
|
AssertRemoved(1, 2);
|
|
|
|
}
|
|
|
|
}
|
|
|
@ -82,7 +103,9 @@ namespace NzbDrone.Core.Test.Download.Pending.PendingReleaseServiceTests
|
|
|
|
AddPending(id: 3, seasonNumber: 2, episodes: new[] { 2 });
|
|
|
|
AddPending(id: 3, seasonNumber: 2, episodes: new[] { 2 });
|
|
|
|
AddPending(id: 4, seasonNumber: 2, episodes: new[] { 3 });
|
|
|
|
AddPending(id: 4, seasonNumber: 2, episodes: new[] { 3 });
|
|
|
|
|
|
|
|
|
|
|
|
Subject.RemovePendingQueueItems(1);
|
|
|
|
var queueId = HashConverter.GetHashInt31(String.Format("pending-{0}-ep{1}", 1, _episode.Id));
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
Subject.RemovePendingQueueItems(queueId);
|
|
|
|
|
|
|
|
|
|
|
|
AssertRemoved(1, 2);
|
|
|
|
AssertRemoved(1, 2);
|
|
|
|
}
|
|
|
|
}
|
|
|
@ -93,7 +116,9 @@ namespace NzbDrone.Core.Test.Download.Pending.PendingReleaseServiceTests
|
|
|
|
AddPending(id: 1, seasonNumber: 2, episodes: new[] { 1 });
|
|
|
|
AddPending(id: 1, seasonNumber: 2, episodes: new[] { 1 });
|
|
|
|
AddPending(id: 2, seasonNumber: 2, episodes: new[] { 1, 2 });
|
|
|
|
AddPending(id: 2, seasonNumber: 2, episodes: new[] { 1, 2 });
|
|
|
|
|
|
|
|
|
|
|
|
Subject.RemovePendingQueueItems(1);
|
|
|
|
var queueId = HashConverter.GetHashInt31(String.Format("pending-{0}-ep{1}", 1, _episode.Id));
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
Subject.RemovePendingQueueItems(queueId);
|
|
|
|
|
|
|
|
|
|
|
|
AssertRemoved(1);
|
|
|
|
AssertRemoved(1);
|
|
|
|
}
|
|
|
|
}
|
|
|
@ -104,12 +129,13 @@ namespace NzbDrone.Core.Test.Download.Pending.PendingReleaseServiceTests
|
|
|
|
AddPending(id: 1, seasonNumber: 2, episodes: new[] { 1 });
|
|
|
|
AddPending(id: 1, seasonNumber: 2, episodes: new[] { 1 });
|
|
|
|
AddPending(id: 2, seasonNumber: 2, episodes: new[] { 1, 2 });
|
|
|
|
AddPending(id: 2, seasonNumber: 2, episodes: new[] { 1, 2 });
|
|
|
|
|
|
|
|
|
|
|
|
Subject.RemovePendingQueueItems(2);
|
|
|
|
var queueId = HashConverter.GetHashInt31(String.Format("pending-{0}-ep{1}", 2, _episode.Id));
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
Subject.RemovePendingQueueItems(queueId);
|
|
|
|
|
|
|
|
|
|
|
|
AssertRemoved(2);
|
|
|
|
AssertRemoved(2);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
private void AssertRemoved(params int[] ids)
|
|
|
|
private void AssertRemoved(params int[] ids)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
Mocker.GetMock<IPendingReleaseRepository>().Verify(c => c.DeleteMany(It.Is<IEnumerable<int>>(s => s.SequenceEqual(ids))));
|
|
|
|
Mocker.GetMock<IPendingReleaseRepository>().Verify(c => c.DeleteMany(It.Is<IEnumerable<int>>(s => s.SequenceEqual(ids))));
|
|
|
|