You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
378 lines
14 KiB
378 lines
14 KiB
7 years ago
|
using System.Collections.Generic;
|
||
12 years ago
|
using System.IO;
|
||
10 years ago
|
using System.Linq;
|
||
12 years ago
|
using FizzWare.NBuilder;
|
||
|
using Moq;
|
||
|
using NUnit.Framework;
|
||
11 years ago
|
using NzbDrone.Common.Disk;
|
||
12 years ago
|
using NzbDrone.Core.MediaFiles;
|
||
7 years ago
|
using NzbDrone.Core.MediaFiles.TrackImport;
|
||
12 years ago
|
using NzbDrone.Core.Parser;
|
||
11 years ago
|
using NzbDrone.Core.Parser.Model;
|
||
11 years ago
|
using NzbDrone.Core.Qualities;
|
||
12 years ago
|
using NzbDrone.Core.Test.Framework;
|
||
7 years ago
|
using NzbDrone.Core.Music;
|
||
11 years ago
|
using NzbDrone.Test.Common;
|
||
10 years ago
|
using FluentAssertions;
|
||
12 years ago
|
|
||
11 years ago
|
namespace NzbDrone.Core.Test.MediaFiles
|
||
12 years ago
|
{
|
||
|
[TestFixture]
|
||
7 years ago
|
public class DownloadedTracksImportServiceFixture : CoreTest<DownloadedTracksImportService>
|
||
12 years ago
|
{
|
||
10 years ago
|
private string _droneFactory = "c:\\drop\\".AsOsAgnostic();
|
||
11 years ago
|
private string[] _subFolders = new[] { "c:\\root\\foldername".AsOsAgnostic() };
|
||
11 years ago
|
private string[] _videoFiles = new[] { "c:\\root\\foldername\\30.rock.s01e01.ext".AsOsAgnostic() };
|
||
12 years ago
|
|
||
|
[SetUp]
|
||
|
public void Setup()
|
||
|
{
|
||
7 years ago
|
Mocker.GetMock<IDiskScanService>().Setup(c => c.GetAudioFiles(It.IsAny<string>(), It.IsAny<bool>()))
|
||
12 years ago
|
.Returns(_videoFiles);
|
||
|
|
||
12 years ago
|
Mocker.GetMock<IDiskProvider>().Setup(c => c.GetDirectories(It.IsAny<string>()))
|
||
12 years ago
|
.Returns(_subFolders);
|
||
12 years ago
|
|
||
11 years ago
|
Mocker.GetMock<IDiskProvider>().Setup(c => c.FolderExists(It.IsAny<string>()))
|
||
|
.Returns(true);
|
||
|
|
||
7 years ago
|
Mocker.GetMock<IImportApprovedTracks>()
|
||
8 years ago
|
.Setup(s => s.Import(It.IsAny<List<ImportDecision>>(), true, null, ImportMode.Auto))
|
||
10 years ago
|
.Returns(new List<ImportResult>());
|
||
12 years ago
|
}
|
||
|
|
||
7 years ago
|
private void GivenValidArtist()
|
||
12 years ago
|
{
|
||
11 years ago
|
Mocker.GetMock<IParsingService>()
|
||
7 years ago
|
.Setup(s => s.GetArtist(It.IsAny<string>()))
|
||
|
.Returns(Builder<Artist>.CreateNew().Build());
|
||
12 years ago
|
}
|
||
|
|
||
|
[Test]
|
||
7 years ago
|
public void should_search_for_artist_using_folder_name()
|
||
12 years ago
|
{
|
||
10 years ago
|
Subject.ProcessRootFolder(new DirectoryInfo(_droneFactory));
|
||
12 years ago
|
|
||
7 years ago
|
Mocker.GetMock<IParsingService>().Verify(c => c.GetArtist("foldername"), Times.Once());
|
||
11 years ago
|
}
|
||
|
|
||
12 years ago
|
[Test]
|
||
11 years ago
|
public void should_skip_if_file_is_in_use_by_another_process()
|
||
12 years ago
|
{
|
||
7 years ago
|
GivenValidArtist();
|
||
11 years ago
|
|
||
11 years ago
|
Mocker.GetMock<IDiskProvider>().Setup(c => c.IsFileLocked(It.IsAny<string>()))
|
||
12 years ago
|
.Returns(true);
|
||
|
|
||
10 years ago
|
Subject.ProcessRootFolder(new DirectoryInfo(_droneFactory));
|
||
8 years ago
|
|
||
11 years ago
|
VerifyNoImport();
|
||
|
}
|
||
|
|
||
|
[Test]
|
||
7 years ago
|
public void should_skip_if_no_artist_found()
|
||
11 years ago
|
{
|
||
7 years ago
|
Mocker.GetMock<IParsingService>().Setup(c => c.GetArtist("foldername")).Returns((Artist)null);
|
||
11 years ago
|
|
||
10 years ago
|
Subject.ProcessRootFolder(new DirectoryInfo(_droneFactory));
|
||
11 years ago
|
|
||
|
Mocker.GetMock<IMakeImportDecision>()
|
||
7 years ago
|
.Verify(c => c.GetImportDecisions(It.IsAny<List<string>>(), It.IsAny<Artist>(), It.IsAny<ParsedTrackInfo>()),
|
||
11 years ago
|
Times.Never());
|
||
11 years ago
|
|
||
12 years ago
|
VerifyNoImport();
|
||
|
}
|
||
|
|
||
11 years ago
|
[Test]
|
||
7 years ago
|
public void should_not_import_if_folder_is_a_artist_path()
|
||
11 years ago
|
{
|
||
7 years ago
|
GivenValidArtist();
|
||
10 years ago
|
|
||
7 years ago
|
Mocker.GetMock<IArtistService>()
|
||
|
.Setup(s => s.ArtistPathExists(It.IsAny<string>()))
|
||
11 years ago
|
.Returns(true);
|
||
|
|
||
|
Mocker.GetMock<IDiskScanService>()
|
||
7 years ago
|
.Setup(c => c.GetAudioFiles(It.IsAny<string>(), It.IsAny<bool>()))
|
||
11 years ago
|
.Returns(new string[0]);
|
||
|
|
||
10 years ago
|
Subject.ProcessRootFolder(new DirectoryInfo(_droneFactory));
|
||
11 years ago
|
|
||
10 years ago
|
Mocker.GetMock<IDiskScanService>()
|
||
7 years ago
|
.Verify(v => v.GetAudioFiles(It.IsAny<string>(), true), Times.Never());
|
||
11 years ago
|
|
||
|
ExceptionVerification.ExpectedWarns(1);
|
||
11 years ago
|
}
|
||
|
|
||
|
[Test]
|
||
|
public void should_not_delete_folder_if_no_files_were_imported()
|
||
|
{
|
||
7 years ago
|
Mocker.GetMock<IImportApprovedTracks>()
|
||
8 years ago
|
.Setup(s => s.Import(It.IsAny<List<ImportDecision>>(), false, null, ImportMode.Auto))
|
||
10 years ago
|
.Returns(new List<ImportResult>());
|
||
11 years ago
|
|
||
10 years ago
|
Subject.ProcessRootFolder(new DirectoryInfo(_droneFactory));
|
||
11 years ago
|
|
||
11 years ago
|
Mocker.GetMock<IDiskProvider>()
|
||
9 years ago
|
.Verify(v => v.GetFolderSize(It.IsAny<string>()), Times.Never());
|
||
11 years ago
|
}
|
||
|
|
||
|
[Test]
|
||
11 years ago
|
public void should_not_delete_folder_if_files_were_imported_and_video_files_remain()
|
||
11 years ago
|
{
|
||
7 years ago
|
GivenValidArtist();
|
||
11 years ago
|
|
||
7 years ago
|
var localTrack = new LocalTrack();
|
||
11 years ago
|
|
||
|
var imported = new List<ImportDecision>();
|
||
7 years ago
|
imported.Add(new ImportDecision(localTrack));
|
||
11 years ago
|
|
||
|
Mocker.GetMock<IMakeImportDecision>()
|
||
7 years ago
|
.Setup(s => s.GetImportDecisions(It.IsAny<List<string>>(), It.IsAny<Artist>(), null))
|
||
11 years ago
|
.Returns(imported);
|
||
|
|
||
7 years ago
|
Mocker.GetMock<IImportApprovedTracks>()
|
||
8 years ago
|
.Setup(s => s.Import(It.IsAny<List<ImportDecision>>(), true, null, ImportMode.Auto))
|
||
10 years ago
|
.Returns(imported.Select(i => new ImportResult(i)).ToList());
|
||
11 years ago
|
|
||
10 years ago
|
Subject.ProcessRootFolder(new DirectoryInfo(_droneFactory));
|
||
11 years ago
|
|
||
|
Mocker.GetMock<IDiskProvider>()
|
||
9 years ago
|
.Verify(v => v.DeleteFolder(It.IsAny<string>(), true), Times.Never());
|
||
11 years ago
|
|
||
|
ExceptionVerification.ExpectedWarns(1);
|
||
|
}
|
||
|
|
||
|
[Test]
|
||
|
public void should_delete_folder_if_files_were_imported_and_only_sample_files_remain()
|
||
11 years ago
|
{
|
||
7 years ago
|
GivenValidArtist();
|
||
11 years ago
|
|
||
7 years ago
|
var localEpisode = new LocalTrack();
|
||
11 years ago
|
|
||
|
var imported = new List<ImportDecision>();
|
||
|
imported.Add(new ImportDecision(localEpisode));
|
||
|
|
||
|
Mocker.GetMock<IMakeImportDecision>()
|
||
7 years ago
|
.Setup(s => s.GetImportDecisions(It.IsAny<List<string>>(), It.IsAny<Artist>(), null))
|
||
11 years ago
|
.Returns(imported);
|
||
|
|
||
7 years ago
|
Mocker.GetMock<IImportApprovedTracks>()
|
||
8 years ago
|
.Setup(s => s.Import(It.IsAny<List<ImportDecision>>(), true, null, ImportMode.Auto))
|
||
10 years ago
|
.Returns(imported.Select(i => new ImportResult(i)).ToList());
|
||
11 years ago
|
|
||
7 years ago
|
//Mocker.GetMock<IDetectSample>()
|
||
|
// .Setup(s => s.IsSample(It.IsAny<Artist>(),
|
||
|
// It.IsAny<QualityModel>(),
|
||
|
// It.IsAny<string>(),
|
||
|
// It.IsAny<long>(),
|
||
|
// It.IsAny<bool>()))
|
||
|
// .Returns(true);
|
||
11 years ago
|
|
||
10 years ago
|
Subject.ProcessRootFolder(new DirectoryInfo(_droneFactory));
|
||
11 years ago
|
|
||
|
Mocker.GetMock<IDiskProvider>()
|
||
9 years ago
|
.Verify(v => v.DeleteFolder(It.IsAny<string>(), true), Times.Once());
|
||
11 years ago
|
}
|
||
|
|
||
11 years ago
|
[TestCase("_UNPACK_")]
|
||
|
[TestCase("_FAILED_")]
|
||
|
public void should_remove_unpack_from_folder_name(string prefix)
|
||
|
{
|
||
|
var folderName = "30.rock.s01e01.pilot.hdtv-lol";
|
||
9 years ago
|
var folders = new[] { string.Format(@"C:\Test\Unsorted\{0}{1}", prefix, folderName).AsOsAgnostic() };
|
||
11 years ago
|
|
||
|
Mocker.GetMock<IDiskProvider>()
|
||
|
.Setup(c => c.GetDirectories(It.IsAny<string>()))
|
||
|
.Returns(folders);
|
||
|
|
||
10 years ago
|
Subject.ProcessRootFolder(new DirectoryInfo(_droneFactory));
|
||
11 years ago
|
|
||
|
Mocker.GetMock<IParsingService>()
|
||
7 years ago
|
.Verify(v => v.GetArtist(folderName), Times.Once());
|
||
11 years ago
|
|
||
|
Mocker.GetMock<IParsingService>()
|
||
7 years ago
|
.Verify(v => v.GetArtist(It.Is<string>(s => s.StartsWith(prefix))), Times.Never());
|
||
11 years ago
|
}
|
||
|
|
||
10 years ago
|
[Test]
|
||
7 years ago
|
public void should_return_importresult_on_unknown_artist()
|
||
10 years ago
|
{
|
||
10 years ago
|
Mocker.GetMock<IDiskProvider>().Setup(c => c.FolderExists(It.IsAny<string>()))
|
||
|
.Returns(false);
|
||
|
|
||
10 years ago
|
Mocker.GetMock<IDiskProvider>().Setup(c => c.FileExists(It.IsAny<string>()))
|
||
|
.Returns(true);
|
||
|
|
||
10 years ago
|
var fileName = @"C:\folder\file.mkv".AsOsAgnostic();
|
||
|
|
||
10 years ago
|
var result = Subject.ProcessPath(fileName);
|
||
10 years ago
|
|
||
|
result.Should().HaveCount(1);
|
||
|
result.First().ImportDecision.Should().NotBeNull();
|
||
7 years ago
|
result.First().ImportDecision.LocalTrack.Should().NotBeNull();
|
||
|
result.First().ImportDecision.LocalTrack.Path.Should().Be(fileName);
|
||
10 years ago
|
result.First().Result.Should().Be(ImportResultType.Rejected);
|
||
|
}
|
||
|
|
||
10 years ago
|
[Test]
|
||
|
public void should_not_delete_if_there_is_large_rar_file()
|
||
|
{
|
||
7 years ago
|
GivenValidArtist();
|
||
10 years ago
|
|
||
7 years ago
|
var localEpisode = new LocalTrack();
|
||
10 years ago
|
|
||
|
var imported = new List<ImportDecision>();
|
||
|
imported.Add(new ImportDecision(localEpisode));
|
||
|
|
||
|
Mocker.GetMock<IMakeImportDecision>()
|
||
7 years ago
|
.Setup(s => s.GetImportDecisions(It.IsAny<List<string>>(), It.IsAny<Artist>(), null))
|
||
10 years ago
|
.Returns(imported);
|
||
|
|
||
7 years ago
|
Mocker.GetMock<IImportApprovedTracks>()
|
||
8 years ago
|
.Setup(s => s.Import(It.IsAny<List<ImportDecision>>(), true, null, ImportMode.Auto))
|
||
10 years ago
|
.Returns(imported.Select(i => new ImportResult(i)).ToList());
|
||
|
|
||
7 years ago
|
//Mocker.GetMock<IDetectSample>()
|
||
|
// .Setup(s => s.IsSample(It.IsAny<Artist>(),
|
||
|
// It.IsAny<QualityModel>(),
|
||
|
// It.IsAny<string>(),
|
||
|
// It.IsAny<long>(),
|
||
|
// It.IsAny<bool>()))
|
||
|
// .Returns(true);
|
||
10 years ago
|
|
||
|
Mocker.GetMock<IDiskProvider>()
|
||
|
.Setup(s => s.GetFiles(It.IsAny<string>(), SearchOption.AllDirectories))
|
||
|
.Returns(new []{ _videoFiles.First().Replace(".ext", ".rar") });
|
||
|
|
||
|
Mocker.GetMock<IDiskProvider>()
|
||
|
.Setup(s => s.GetFileSize(It.IsAny<string>()))
|
||
|
.Returns(15.Megabytes());
|
||
|
|
||
|
Subject.ProcessRootFolder(new DirectoryInfo(_droneFactory));
|
||
|
|
||
|
Mocker.GetMock<IDiskProvider>()
|
||
9 years ago
|
.Verify(v => v.DeleteFolder(It.IsAny<string>(), true), Times.Never());
|
||
10 years ago
|
|
||
|
ExceptionVerification.ExpectedWarns(1);
|
||
|
}
|
||
|
|
||
10 years ago
|
[Test]
|
||
|
public void should_use_folder_if_folder_import()
|
||
|
{
|
||
7 years ago
|
GivenValidArtist();
|
||
10 years ago
|
|
||
|
var folderName = @"C:\media\ba09030e-1234-1234-1234-123456789abc\[HorribleSubs] Maria the Virgin Witch - 09 [720p]".AsOsAgnostic();
|
||
|
var fileName = @"C:\media\ba09030e-1234-1234-1234-123456789abc\[HorribleSubs] Maria the Virgin Witch - 09 [720p]\[HorribleSubs] Maria the Virgin Witch - 09 [720p].mkv".AsOsAgnostic();
|
||
|
|
||
|
Mocker.GetMock<IDiskProvider>().Setup(c => c.FolderExists(folderName))
|
||
|
.Returns(true);
|
||
|
|
||
|
Mocker.GetMock<IDiskProvider>().Setup(c => c.GetFiles(folderName, SearchOption.TopDirectoryOnly))
|
||
|
.Returns(new[] { fileName });
|
||
|
|
||
7 years ago
|
var localEpisode = new LocalTrack();
|
||
10 years ago
|
|
||
|
var imported = new List<ImportDecision>();
|
||
|
imported.Add(new ImportDecision(localEpisode));
|
||
|
|
||
|
|
||
10 years ago
|
Subject.ProcessPath(fileName);
|
||
10 years ago
|
|
||
|
Mocker.GetMock<IMakeImportDecision>()
|
||
7 years ago
|
.Verify(s => s.GetImportDecisions(It.IsAny<List<string>>(), It.IsAny<Artist>(), It.Is<ParsedTrackInfo>(v => v.TrackNumbers.First() == 9)), Times.Once());
|
||
10 years ago
|
}
|
||
|
|
||
|
[Test]
|
||
|
public void should_not_use_folder_if_file_import()
|
||
|
{
|
||
7 years ago
|
GivenValidArtist();
|
||
10 years ago
|
|
||
|
var fileName = @"C:\media\ba09030e-1234-1234-1234-123456789abc\Torrents\[HorribleSubs] Maria the Virgin Witch - 09 [720p].mkv".AsOsAgnostic();
|
||
|
|
||
|
Mocker.GetMock<IDiskProvider>().Setup(c => c.FolderExists(fileName))
|
||
|
.Returns(false);
|
||
|
|
||
10 years ago
|
Mocker.GetMock<IDiskProvider>().Setup(c => c.FileExists(fileName))
|
||
|
.Returns(true);
|
||
|
|
||
7 years ago
|
var localEpisode = new LocalTrack();
|
||
10 years ago
|
|
||
|
var imported = new List<ImportDecision>();
|
||
|
imported.Add(new ImportDecision(localEpisode));
|
||
|
|
||
|
var result = Subject.ProcessPath(fileName);
|
||
|
|
||
|
Mocker.GetMock<IMakeImportDecision>()
|
||
7 years ago
|
.Verify(s => s.GetImportDecisions(It.IsAny<List<string>>(), It.IsAny<Artist>(), null), Times.Once());
|
||
10 years ago
|
}
|
||
|
|
||
10 years ago
|
[Test]
|
||
|
public void should_not_process_if_file_and_folder_do_not_exist()
|
||
|
{
|
||
|
var folderName = @"C:\media\ba09030e-1234-1234-1234-123456789abc\[HorribleSubs] Maria the Virgin Witch - 09 [720p]".AsOsAgnostic();
|
||
|
|
||
|
Mocker.GetMock<IDiskProvider>().Setup(c => c.FolderExists(folderName))
|
||
|
.Returns(false);
|
||
|
|
||
|
Mocker.GetMock<IDiskProvider>().Setup(c => c.FileExists(folderName))
|
||
|
.Returns(false);
|
||
|
|
||
|
Subject.ProcessPath(folderName).Should().BeEmpty();
|
||
|
|
||
|
Mocker.GetMock<IParsingService>()
|
||
7 years ago
|
.Verify(v => v.GetArtist(It.IsAny<string>()), Times.Never());
|
||
10 years ago
|
|
||
|
ExceptionVerification.ExpectedErrors(1);
|
||
|
}
|
||
|
|
||
10 years ago
|
[Test]
|
||
|
public void should_not_delete_if_no_files_were_imported()
|
||
|
{
|
||
7 years ago
|
GivenValidArtist();
|
||
10 years ago
|
|
||
7 years ago
|
var localEpisode = new LocalTrack();
|
||
10 years ago
|
|
||
|
var imported = new List<ImportDecision>();
|
||
|
imported.Add(new ImportDecision(localEpisode));
|
||
|
|
||
|
Mocker.GetMock<IMakeImportDecision>()
|
||
7 years ago
|
.Setup(s => s.GetImportDecisions(It.IsAny<List<string>>(), It.IsAny<Artist>(), null))
|
||
10 years ago
|
.Returns(imported);
|
||
|
|
||
7 years ago
|
Mocker.GetMock<IImportApprovedTracks>()
|
||
8 years ago
|
.Setup(s => s.Import(It.IsAny<List<ImportDecision>>(), true, null, ImportMode.Auto))
|
||
10 years ago
|
.Returns(new List<ImportResult>());
|
||
|
|
||
7 years ago
|
//Mocker.GetMock<IDetectSample>()
|
||
|
// .Setup(s => s.IsSample(It.IsAny<Artist>(),
|
||
|
// It.IsAny<QualityModel>(),
|
||
|
// It.IsAny<string>(),
|
||
|
// It.IsAny<long>(),
|
||
|
// It.IsAny<bool>()))
|
||
|
// .Returns(true);
|
||
10 years ago
|
|
||
|
Mocker.GetMock<IDiskProvider>()
|
||
|
.Setup(s => s.GetFileSize(It.IsAny<string>()))
|
||
|
.Returns(15.Megabytes());
|
||
|
|
||
|
Subject.ProcessRootFolder(new DirectoryInfo(_droneFactory));
|
||
|
|
||
|
Mocker.GetMock<IDiskProvider>()
|
||
9 years ago
|
.Verify(v => v.DeleteFolder(It.IsAny<string>(), true), Times.Never());
|
||
10 years ago
|
}
|
||
|
|
||
12 years ago
|
private void VerifyNoImport()
|
||
|
{
|
||
7 years ago
|
Mocker.GetMock<IImportApprovedTracks>().Verify(c => c.Import(It.IsAny<List<ImportDecision>>(), true, null, ImportMode.Auto),
|
||
12 years ago
|
Times.Never());
|
||
|
}
|
||
|
|
||
|
private void VerifyImport()
|
||
|
{
|
||
7 years ago
|
Mocker.GetMock<IImportApprovedTracks>().Verify(c => c.Import(It.IsAny<List<ImportDecision>>(), true, null, ImportMode.Auto),
|
||
12 years ago
|
Times.Once());
|
||
|
}
|
||
|
}
|
||
7 years ago
|
}
|