2011-10-23 02:31:28 +00:00
|
|
|
// ReSharper disable InconsistentNaming
|
|
|
|
using System;
|
|
|
|
using System.Collections.Generic;
|
|
|
|
using System.IO;
|
|
|
|
using System.Linq;
|
|
|
|
using AutoMoq;
|
|
|
|
using FizzWare.NBuilder;
|
|
|
|
using Moq;
|
|
|
|
using NUnit.Framework;
|
2011-11-13 04:07:06 +00:00
|
|
|
using NzbDrone.Common;
|
2011-10-23 02:31:28 +00:00
|
|
|
using NzbDrone.Core.Model;
|
|
|
|
using NzbDrone.Core.Providers;
|
|
|
|
using NzbDrone.Core.Providers.Core;
|
|
|
|
using NzbDrone.Core.Repository;
|
|
|
|
using NzbDrone.Core.Test.Framework;
|
2011-10-24 05:54:09 +00:00
|
|
|
using NzbDrone.Test.Common;
|
2011-10-23 02:31:28 +00:00
|
|
|
|
|
|
|
namespace NzbDrone.Core.Test.ProviderTests.PostDownloadProviderTests
|
|
|
|
{
|
|
|
|
[TestFixture]
|
|
|
|
public class ProcessDownloadFixture : TestBase
|
|
|
|
{
|
|
|
|
[Test]
|
|
|
|
public void should_skip_if_folder_is_tagged_and_too_fresh()
|
|
|
|
{
|
|
|
|
var mocker = new AutoMoqer(MockBehavior.Strict);
|
|
|
|
|
|
|
|
var droppedFolder = new DirectoryInfo(TempFolder + "\\_test\\");
|
|
|
|
droppedFolder.Create();
|
|
|
|
|
|
|
|
mocker.Resolve<PostDownloadProvider>().ProcessDownload(droppedFolder);
|
|
|
|
}
|
|
|
|
|
|
|
|
[Test]
|
|
|
|
public void should_continue_processing_if_folder_is_tagged_and_not_fresh()
|
|
|
|
{
|
|
|
|
var mocker = new AutoMoqer(MockBehavior.Loose);
|
|
|
|
|
|
|
|
var droppedFolder = new DirectoryInfo(TempFolder + "\\_test\\");
|
|
|
|
droppedFolder.Create();
|
|
|
|
|
|
|
|
droppedFolder.LastWriteTime = DateTime.Now.AddMinutes(-2);
|
|
|
|
|
|
|
|
//Act
|
|
|
|
mocker.GetMock<SeriesProvider>().Setup(s => s.FindSeries(It.IsAny<String>())).Returns<Series>(null).Verifiable();
|
|
|
|
mocker.Resolve<PostDownloadProvider>().ProcessDownload(droppedFolder);
|
|
|
|
|
|
|
|
//Assert
|
|
|
|
mocker.VerifyAllMocks();
|
|
|
|
ExceptionVerification.ExcpectedWarns(1);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
[Test]
|
|
|
|
public void should_search_for_series_using_title_without_status()
|
|
|
|
{
|
|
|
|
//Setup
|
|
|
|
var mocker = new AutoMoqer(MockBehavior.Loose);
|
|
|
|
var droppedFolder = new DirectoryInfo(@"C:\Test\Unsorted TV\_unpack_The Office - S01E01 - Episode Title");
|
|
|
|
|
|
|
|
mocker.GetMock<SeriesProvider>().Setup(s => s.FindSeries("office")).Returns<Series>(null).Verifiable();
|
|
|
|
|
|
|
|
//Act
|
|
|
|
mocker.Resolve<PostDownloadProvider>().ProcessDownload(droppedFolder);
|
|
|
|
|
|
|
|
//Assert
|
|
|
|
mocker.VerifyAllMocks();
|
|
|
|
ExceptionVerification.ExcpectedWarns(1);
|
|
|
|
}
|
|
|
|
|
|
|
|
[Test]
|
|
|
|
public void when_series_isnt_found_folder_should_be_tagged_as_unknown_series()
|
|
|
|
{
|
|
|
|
//Setup
|
|
|
|
var mocker = new AutoMoqer(MockBehavior.Strict);
|
|
|
|
var droppedFolder = new DirectoryInfo(@"C:\Test\Unsorted TV\The Office - S01E01 - Episode Title");
|
|
|
|
|
|
|
|
var taggedFolder = @"C:\Test\Unsorted TV\_UnknownSeries_The Office - S01E01 - Episode Title";
|
|
|
|
|
|
|
|
//Act
|
|
|
|
mocker.GetMock<SeriesProvider>().Setup(s => s.FindSeries("office")).Returns<Series>(null);
|
|
|
|
mocker.GetMock<DiskProvider>().Setup(s => s.MoveDirectory(droppedFolder.FullName, taggedFolder));
|
|
|
|
|
|
|
|
mocker.Resolve<PostDownloadProvider>().ProcessDownload(droppedFolder);
|
|
|
|
|
|
|
|
//Assert
|
|
|
|
mocker.VerifyAllMocks();
|
|
|
|
ExceptionVerification.ExcpectedWarns(1);
|
|
|
|
}
|
|
|
|
|
|
|
|
[Test]
|
|
|
|
public void when_no_files_are_imported_folder_should_be_tagged_with_parse_error()
|
|
|
|
{
|
|
|
|
//Setup
|
|
|
|
var mocker = new AutoMoqer(MockBehavior.Strict);
|
|
|
|
var droppedFolder = new DirectoryInfo(@"C:\Test\Unsorted TV\The Office - S01E01 - Episode Title");
|
|
|
|
|
|
|
|
var taggedFolder = @"C:\Test\Unsorted TV\_ParseError_The Office - S01E01 - Episode Title";
|
|
|
|
|
|
|
|
var fakeSeries = Builder<Series>.CreateNew()
|
|
|
|
.With(s => s.Title = "The Office")
|
|
|
|
.Build();
|
|
|
|
|
|
|
|
//Act
|
|
|
|
mocker.GetMock<SeriesProvider>().Setup(s => s.FindSeries("office")).Returns(fakeSeries);
|
|
|
|
mocker.GetMock<DiskScanProvider>().Setup(s => s.Scan(fakeSeries, droppedFolder.FullName)).Returns(new List<EpisodeFile>());
|
|
|
|
mocker.GetMock<DiskProvider>().Setup(s => s.MoveDirectory(droppedFolder.FullName, taggedFolder));
|
2011-10-25 05:15:20 +00:00
|
|
|
mocker.GetMock<DiskProvider>().Setup(s => s.GetDirectorySize(droppedFolder.FullName)).Returns(Constants.IgnoreFileSize + 10.Megabytes());
|
2011-10-23 02:31:28 +00:00
|
|
|
|
|
|
|
|
|
|
|
mocker.Resolve<PostDownloadProvider>().ProcessDownload(droppedFolder);
|
|
|
|
|
|
|
|
//Assert
|
|
|
|
mocker.VerifyAllMocks();
|
|
|
|
ExceptionVerification.ExcpectedWarns(1);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
[Test]
|
|
|
|
public void when_no_file_are_imported_and_folder_size_isnt_small_enought_folder_should_be_tagged_unknown()
|
|
|
|
{
|
|
|
|
//Setup
|
|
|
|
var mocker = new AutoMoqer(MockBehavior.Strict);
|
|
|
|
var droppedFolder = new DirectoryInfo(@"C:\Test\Unsorted TV\The Office - Season 01");
|
|
|
|
|
2011-10-25 04:34:48 +00:00
|
|
|
var taggedFolder = PostDownloadProvider.GetTaggedFolderName(droppedFolder, PostDownloadStatusType.Unknown);
|
2011-10-23 02:31:28 +00:00
|
|
|
|
|
|
|
var fakeSeries = Builder<Series>.CreateNew()
|
|
|
|
.With(s => s.Title = "The Office")
|
|
|
|
.Build();
|
|
|
|
|
|
|
|
var fakeEpisodeFiles = Builder<EpisodeFile>.CreateListOfSize(2)
|
|
|
|
.All()
|
|
|
|
.With(f => f.SeriesId = fakeSeries.SeriesId)
|
|
|
|
.Build().ToList();
|
|
|
|
|
|
|
|
//Act
|
|
|
|
mocker.GetMock<SeriesProvider>().Setup(s => s.FindSeries("office")).Returns(fakeSeries);
|
|
|
|
mocker.GetMock<DiskProvider>().Setup(s => s.MoveDirectory(droppedFolder.FullName, taggedFolder));
|
2011-10-25 05:15:20 +00:00
|
|
|
mocker.GetMock<DiskProvider>().Setup(s => s.GetDirectorySize(droppedFolder.FullName)).Returns(Constants.IgnoreFileSize + 10.Megabytes());
|
2011-10-23 02:31:28 +00:00
|
|
|
mocker.GetMock<DiskScanProvider>().Setup(s => s.Scan(fakeSeries, droppedFolder.FullName)).Returns(fakeEpisodeFiles);
|
|
|
|
mocker.GetMock<DiskScanProvider>().Setup(s => s.MoveEpisodeFile(It.IsAny<EpisodeFile>(), true)).Returns(true);
|
|
|
|
|
|
|
|
mocker.Resolve<PostDownloadProvider>().ProcessDownload(droppedFolder);
|
|
|
|
|
|
|
|
//Assert
|
|
|
|
mocker.VerifyAllMocks();
|
|
|
|
ExceptionVerification.ExcpectedWarns(1);
|
|
|
|
}
|
|
|
|
|
2011-10-25 04:34:48 +00:00
|
|
|
[TestCase(@"\_UnknownSeries_The Office - S01E01 - Episode Title")]
|
|
|
|
[TestCase(@"\_UnknownSeries_The Office - S01E01 - Episode Title\")]
|
|
|
|
[TestCase("\\Test\\_UnknownSeries_The Office - S01E01 - Episode Title\\")]
|
|
|
|
[TestCase("\\Test\\_UnknownSeries_The Office - S01E01 - Episode Title")]
|
|
|
|
public void folder_shouldnt_be_tagged_with_same_tag_again(string path)
|
|
|
|
{
|
|
|
|
//Setup
|
|
|
|
var mocker = new AutoMoqer();
|
|
|
|
var droppedFolder = new DirectoryInfo(TempFolder + path);
|
|
|
|
droppedFolder.Create();
|
|
|
|
droppedFolder.LastWriteTime = DateTime.Now.AddHours(-1);
|
|
|
|
|
|
|
|
//Act
|
|
|
|
mocker.GetMock<SeriesProvider>().Setup(s => s.FindSeries(It.IsAny<String>())).Returns<Series>(null);
|
|
|
|
mocker.Resolve<PostDownloadProvider>().ProcessDownload(droppedFolder);
|
|
|
|
|
|
|
|
//Assert
|
|
|
|
mocker.VerifyAllMocks();
|
|
|
|
mocker.GetMock<DiskProvider>().Verify(c => c.MoveDirectory(It.IsAny<string>(), It.IsAny<string>()), Times.Never());
|
|
|
|
ExceptionVerification.ExcpectedWarns(1);
|
|
|
|
}
|
|
|
|
|
|
|
|
[Test]
|
|
|
|
public void folder_should_be_tagged_if_existing_tag_is_diffrent()
|
|
|
|
{
|
|
|
|
//Setup
|
|
|
|
var mocker = new AutoMoqer();
|
|
|
|
var droppedFolder = new DirectoryInfo(TempFolder + @"\_UnknownEpisode_The Office - S01E01 - Episode Title");
|
|
|
|
droppedFolder.Create();
|
|
|
|
droppedFolder.LastWriteTime = DateTime.Now.AddHours(-1);
|
|
|
|
|
|
|
|
var taggedFolder = TempFolder + @"\_UnknownSeries_The Office - S01E01 - Episode Title";
|
|
|
|
|
|
|
|
mocker.GetMock<SeriesProvider>().Setup(s => s.FindSeries(It.IsAny<String>())).Returns<Series>(null);
|
|
|
|
|
|
|
|
//Act
|
|
|
|
mocker.Resolve<PostDownloadProvider>().ProcessDownload(droppedFolder);
|
|
|
|
|
|
|
|
//Assert
|
|
|
|
mocker.VerifyAllMocks();
|
|
|
|
mocker.GetMock<DiskProvider>().Verify(c => c.MoveDirectory(droppedFolder.FullName, taggedFolder), Times.Once());
|
|
|
|
ExceptionVerification.ExcpectedWarns(1);
|
|
|
|
}
|
|
|
|
|
2011-10-23 02:31:28 +00:00
|
|
|
[Test]
|
|
|
|
public void when_files_are_imported_and_folder_is_small_enought_dir_should_be_deleted()
|
|
|
|
{
|
|
|
|
//Setup
|
|
|
|
var mocker = new AutoMoqer(MockBehavior.Strict);
|
|
|
|
var droppedFolder = new DirectoryInfo(@"C:\Test\Unsorted TV\The Office - Season 01");
|
|
|
|
|
|
|
|
var fakeSeries = Builder<Series>.CreateNew()
|
|
|
|
.With(s => s.Title = "The Office")
|
|
|
|
.Build();
|
|
|
|
|
|
|
|
var fakeEpisodeFiles = Builder<EpisodeFile>.CreateListOfSize(2)
|
|
|
|
.All()
|
|
|
|
.With(f => f.SeriesId = fakeSeries.SeriesId)
|
|
|
|
.Build().ToList();
|
|
|
|
|
|
|
|
mocker.GetMock<SeriesProvider>().Setup(s => s.FindSeries("office")).Returns(fakeSeries);
|
|
|
|
mocker.GetMock<DiskScanProvider>().Setup(s => s.Scan(fakeSeries, droppedFolder.FullName)).Returns(fakeEpisodeFiles);
|
|
|
|
mocker.GetMock<DiskScanProvider>().Setup(s => s.MoveEpisodeFile(It.IsAny<EpisodeFile>(), true)).Returns(true);
|
2011-10-25 05:15:20 +00:00
|
|
|
mocker.GetMock<DiskProvider>().Setup(s => s.GetDirectorySize(droppedFolder.FullName)).Returns(Constants.IgnoreFileSize - 1.Megabytes());
|
2011-10-23 02:31:28 +00:00
|
|
|
mocker.GetMock<DiskProvider>().Setup(s => s.DeleteFolder(droppedFolder.FullName, true));
|
|
|
|
|
|
|
|
//Act
|
|
|
|
mocker.Resolve<PostDownloadProvider>().ProcessDownload(droppedFolder);
|
|
|
|
|
|
|
|
//Assert
|
|
|
|
mocker.VerifyAllMocks();
|
|
|
|
}
|
|
|
|
|
|
|
|
[Test]
|
|
|
|
public void all_imported_files_should_be_moved()
|
|
|
|
{
|
|
|
|
//Setup
|
|
|
|
var mocker = new AutoMoqer(MockBehavior.Loose);
|
|
|
|
var droppedFolder = new DirectoryInfo(TempFolder);
|
|
|
|
|
|
|
|
var fakeSeries = Builder<Series>.CreateNew()
|
|
|
|
.Build();
|
|
|
|
|
|
|
|
var fakeEpisodeFiles = Builder<EpisodeFile>.CreateListOfSize(2)
|
|
|
|
.Build().ToList();
|
|
|
|
|
|
|
|
mocker.GetMock<SeriesProvider>().Setup(s => s.FindSeries(It.IsAny<string>())).Returns(fakeSeries);
|
|
|
|
mocker.GetMock<DiskScanProvider>().Setup(s => s.Scan(fakeSeries, droppedFolder.FullName)).Returns(fakeEpisodeFiles);
|
|
|
|
|
|
|
|
//Act
|
|
|
|
mocker.Resolve<PostDownloadProvider>().ProcessDownload(droppedFolder);
|
|
|
|
|
|
|
|
//Assert
|
|
|
|
mocker.GetMock<DiskScanProvider>().Verify(c => c.MoveEpisodeFile(It.IsAny<EpisodeFile>(), true),
|
|
|
|
Times.Exactly(fakeEpisodeFiles.Count));
|
|
|
|
mocker.VerifyAllMocks();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|