|
|
|
@ -9,7 +9,6 @@ using NzbDrone.Core.Download;
|
|
|
|
|
using NzbDrone.Core.Download.TrackedDownloads;
|
|
|
|
|
using NzbDrone.Core.History;
|
|
|
|
|
using NzbDrone.Core.MediaFiles;
|
|
|
|
|
using NzbDrone.Core.MediaFiles.Events;
|
|
|
|
|
using NzbDrone.Core.MediaFiles.TrackImport;
|
|
|
|
|
using NzbDrone.Core.Messaging.Events;
|
|
|
|
|
using NzbDrone.Core.Music;
|
|
|
|
@ -18,10 +17,10 @@ using NzbDrone.Core.Parser.Model;
|
|
|
|
|
using NzbDrone.Core.Test.Framework;
|
|
|
|
|
using NzbDrone.Test.Common;
|
|
|
|
|
|
|
|
|
|
namespace NzbDrone.Core.Test.Download
|
|
|
|
|
namespace NzbDrone.Core.Test.Download.CompletedDownloadServiceTests
|
|
|
|
|
{
|
|
|
|
|
[TestFixture]
|
|
|
|
|
public class CompletedDownloadServiceFixture : CoreTest<CompletedDownloadService>
|
|
|
|
|
public class ImportFixture : CoreTest<CompletedDownloadService>
|
|
|
|
|
{
|
|
|
|
|
private TrackedDownload _trackedDownload;
|
|
|
|
|
|
|
|
|
@ -37,7 +36,7 @@ namespace NzbDrone.Core.Test.Download
|
|
|
|
|
var remoteAlbum = BuildRemoteAlbum();
|
|
|
|
|
|
|
|
|
|
_trackedDownload = Builder<TrackedDownload>.CreateNew()
|
|
|
|
|
.With(c => c.State = TrackedDownloadStage.Downloading)
|
|
|
|
|
.With(c => c.State = TrackedDownloadState.Downloading)
|
|
|
|
|
.With(c => c.DownloadItem = completed)
|
|
|
|
|
.With(c => c.RemoteAlbum = remoteAlbum)
|
|
|
|
|
.Build();
|
|
|
|
@ -84,23 +83,6 @@ namespace NzbDrone.Core.Test.Download
|
|
|
|
|
};
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private void GivenNoGrabbedHistory()
|
|
|
|
|
{
|
|
|
|
|
Mocker.GetMock<IHistoryService>()
|
|
|
|
|
.Setup(s => s.MostRecentForDownloadId(_trackedDownload.DownloadItem.DownloadId))
|
|
|
|
|
.Returns((History.History)null);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private void GivenSuccessfulImport()
|
|
|
|
|
{
|
|
|
|
|
Mocker.GetMock<IDownloadedTracksImportService>()
|
|
|
|
|
.Setup(v => v.ProcessPath(It.IsAny<string>(), It.IsAny<ImportMode>(), It.IsAny<Artist>(), It.IsAny<DownloadClientItem>()))
|
|
|
|
|
.Returns(new List<ImportResult>
|
|
|
|
|
{
|
|
|
|
|
new ImportResult(new ImportDecision<LocalTrack>(new LocalTrack { Path = @"C:\TestPath\Droned.S01E01.mkv".AsOsAgnostic() }))
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private void GivenABadlyNamedDownload()
|
|
|
|
|
{
|
|
|
|
|
_trackedDownload.RemoteAlbum.Artist = null;
|
|
|
|
@ -126,116 +108,6 @@ namespace NzbDrone.Core.Test.Download
|
|
|
|
|
.Returns(_trackedDownload.RemoteAlbum.Artist);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
[TestCase(DownloadItemStatus.Downloading)]
|
|
|
|
|
[TestCase(DownloadItemStatus.Failed)]
|
|
|
|
|
[TestCase(DownloadItemStatus.Queued)]
|
|
|
|
|
[TestCase(DownloadItemStatus.Paused)]
|
|
|
|
|
[TestCase(DownloadItemStatus.Warning)]
|
|
|
|
|
public void should_not_process_if_download_status_isnt_completed(DownloadItemStatus status)
|
|
|
|
|
{
|
|
|
|
|
_trackedDownload.DownloadItem.Status = status;
|
|
|
|
|
|
|
|
|
|
Subject.Process(_trackedDownload);
|
|
|
|
|
|
|
|
|
|
AssertNoAttemptedImport();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
[Test]
|
|
|
|
|
public void should_not_process_if_matching_history_is_not_found_and_no_category_specified()
|
|
|
|
|
{
|
|
|
|
|
_trackedDownload.DownloadItem.Category = null;
|
|
|
|
|
GivenNoGrabbedHistory();
|
|
|
|
|
|
|
|
|
|
Subject.Process(_trackedDownload);
|
|
|
|
|
|
|
|
|
|
AssertNoAttemptedImport();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
[Test]
|
|
|
|
|
public void should_process_if_matching_history_is_not_found_but_category_specified()
|
|
|
|
|
{
|
|
|
|
|
_trackedDownload.DownloadItem.Category = "tv";
|
|
|
|
|
GivenNoGrabbedHistory();
|
|
|
|
|
GivenArtistMatch();
|
|
|
|
|
GivenSuccessfulImport();
|
|
|
|
|
|
|
|
|
|
Subject.Process(_trackedDownload);
|
|
|
|
|
|
|
|
|
|
AssertCompletedDownload();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
[Test]
|
|
|
|
|
public void should_not_process_if_output_path_is_empty()
|
|
|
|
|
{
|
|
|
|
|
_trackedDownload.DownloadItem.OutputPath = default(OsPath);
|
|
|
|
|
|
|
|
|
|
Subject.Process(_trackedDownload);
|
|
|
|
|
|
|
|
|
|
AssertNoAttemptedImport();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
[Test]
|
|
|
|
|
public void should_not_throw_if_remotealbum_is_null()
|
|
|
|
|
{
|
|
|
|
|
_trackedDownload.RemoteAlbum = null;
|
|
|
|
|
|
|
|
|
|
Subject.Process(_trackedDownload);
|
|
|
|
|
|
|
|
|
|
AssertNoAttemptedImport();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
[Test]
|
|
|
|
|
public void should_mark_as_imported_if_all_tracks_were_imported()
|
|
|
|
|
{
|
|
|
|
|
_trackedDownload.RemoteAlbum.Albums = new List<Album>
|
|
|
|
|
{
|
|
|
|
|
CreateAlbum(1, 2)
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
Mocker.GetMock<IDownloadedTracksImportService>()
|
|
|
|
|
.Setup(v => v.ProcessPath(It.IsAny<string>(), It.IsAny<ImportMode>(), It.IsAny<Artist>(), It.IsAny<DownloadClientItem>()))
|
|
|
|
|
.Returns(new List<ImportResult>
|
|
|
|
|
{
|
|
|
|
|
new ImportResult(
|
|
|
|
|
new ImportDecision<LocalTrack>(
|
|
|
|
|
new LocalTrack { Path = @"C:\TestPath\Droned.S01E01.mkv".AsOsAgnostic() })),
|
|
|
|
|
|
|
|
|
|
new ImportResult(
|
|
|
|
|
new ImportDecision<LocalTrack>(
|
|
|
|
|
new LocalTrack { Path = @"C:\TestPath\Droned.S01E02.mkv".AsOsAgnostic() }))
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
Subject.Process(_trackedDownload);
|
|
|
|
|
|
|
|
|
|
AssertCompletedDownload();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
[Test]
|
|
|
|
|
public void should_mark_as_imported_if_all_tracks_were_imported_but_album_incomplete()
|
|
|
|
|
{
|
|
|
|
|
_trackedDownload.RemoteAlbum.Albums = new List<Album>
|
|
|
|
|
{
|
|
|
|
|
CreateAlbum(1, 3)
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
Mocker.GetMock<IDownloadedTracksImportService>()
|
|
|
|
|
.Setup(v => v.ProcessPath(It.IsAny<string>(), It.IsAny<ImportMode>(), It.IsAny<Artist>(), It.IsAny<DownloadClientItem>()))
|
|
|
|
|
.Returns(new List<ImportResult>
|
|
|
|
|
{
|
|
|
|
|
new ImportResult(
|
|
|
|
|
new ImportDecision<LocalTrack>(
|
|
|
|
|
new LocalTrack { Path = @"C:\TestPath\Droned.S01E01.mkv".AsOsAgnostic() })),
|
|
|
|
|
|
|
|
|
|
new ImportResult(
|
|
|
|
|
new ImportDecision<LocalTrack>(
|
|
|
|
|
new LocalTrack { Path = @"C:\TestPath\Droned.S01E02.mkv".AsOsAgnostic() }))
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
Subject.Process(_trackedDownload);
|
|
|
|
|
|
|
|
|
|
AssertCompletedDownload();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
[Test]
|
|
|
|
|
public void should_not_mark_as_imported_if_all_files_were_rejected()
|
|
|
|
|
{
|
|
|
|
@ -252,12 +124,12 @@ namespace NzbDrone.Core.Test.Download
|
|
|
|
|
new LocalTrack { Path = @"C:\TestPath\Droned.S01E02.mkv".AsOsAgnostic() }, new Rejection("Rejected!")), "Test Failure")
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
Subject.Process(_trackedDownload);
|
|
|
|
|
Subject.Import(_trackedDownload);
|
|
|
|
|
|
|
|
|
|
Mocker.GetMock<IEventAggregator>()
|
|
|
|
|
.Verify(v => v.PublishEvent<DownloadCompletedEvent>(It.IsAny<DownloadCompletedEvent>()), Times.Never());
|
|
|
|
|
|
|
|
|
|
AssertImportIncomplete();
|
|
|
|
|
AssertNotImported();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
[Test]
|
|
|
|
@ -278,9 +150,9 @@ namespace NzbDrone.Core.Test.Download
|
|
|
|
|
|
|
|
|
|
_trackedDownload.RemoteAlbum.Albums.Clear();
|
|
|
|
|
|
|
|
|
|
Subject.Process(_trackedDownload);
|
|
|
|
|
Subject.Import(_trackedDownload);
|
|
|
|
|
|
|
|
|
|
AssertImportIncomplete();
|
|
|
|
|
AssertNotImported();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
[Test]
|
|
|
|
@ -290,10 +162,9 @@ namespace NzbDrone.Core.Test.Download
|
|
|
|
|
.Setup(v => v.ProcessPath(It.IsAny<string>(), It.IsAny<ImportMode>(), It.IsAny<Artist>(), It.IsAny<DownloadClientItem>()))
|
|
|
|
|
.Returns(new List<ImportResult>());
|
|
|
|
|
|
|
|
|
|
Subject.Process(_trackedDownload);
|
|
|
|
|
Subject.Import(_trackedDownload);
|
|
|
|
|
|
|
|
|
|
AssertNoCompletedDownload();
|
|
|
|
|
_trackedDownload.State.Should().NotBe(TrackedDownloadStage.ImportFailed);
|
|
|
|
|
_trackedDownload.State.Should().Be(TrackedDownloadState.Importing);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
[Test]
|
|
|
|
@ -307,9 +178,9 @@ namespace NzbDrone.Core.Test.Download
|
|
|
|
|
new ImportResult(new ImportDecision<LocalTrack>(new LocalTrack { Path = @"C:\TestPath\Droned.S01E01.mkv".AsOsAgnostic() }), "Test Failure")
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
Subject.Process(_trackedDownload);
|
|
|
|
|
Subject.Import(_trackedDownload);
|
|
|
|
|
|
|
|
|
|
AssertImportIncomplete();
|
|
|
|
|
AssertNotImported();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
[Test]
|
|
|
|
@ -332,13 +203,13 @@ namespace NzbDrone.Core.Test.Download
|
|
|
|
|
new ImportResult(new ImportDecision<LocalTrack>(new LocalTrack { Path = @"C:\TestPath\Droned.S01E01.mkv".AsOsAgnostic() }), "Test Failure")
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
Subject.Process(_trackedDownload);
|
|
|
|
|
Subject.Import(_trackedDownload);
|
|
|
|
|
|
|
|
|
|
AssertCompletedDownload();
|
|
|
|
|
AssertImported();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
[Test]
|
|
|
|
|
public void should_mark_as_failed_if_some_tracks_were_not_imported()
|
|
|
|
|
public void should_not_mark_as_imported_if_some_tracks_were_not_imported()
|
|
|
|
|
{
|
|
|
|
|
_trackedDownload.RemoteAlbum.Albums = new List<Album>
|
|
|
|
|
{
|
|
|
|
@ -358,134 +229,163 @@ namespace NzbDrone.Core.Test.Download
|
|
|
|
|
new ImportResult(new ImportDecision<LocalTrack>(new LocalTrack { Path = @"C:\TestPath\Droned.S01E01.mkv".AsOsAgnostic() }), "Test Failure")
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
Subject.Process(_trackedDownload);
|
|
|
|
|
var history = Builder<History.History>.CreateListOfSize(2)
|
|
|
|
|
.BuildList();
|
|
|
|
|
|
|
|
|
|
Mocker.GetMock<IHistoryService>()
|
|
|
|
|
.Setup(s => s.FindByDownloadId(It.IsAny<string>()))
|
|
|
|
|
.Returns(history);
|
|
|
|
|
|
|
|
|
|
Mocker.GetMock<ITrackedDownloadAlreadyImported>()
|
|
|
|
|
.Setup(s => s.IsImported(_trackedDownload, history))
|
|
|
|
|
.Returns(true);
|
|
|
|
|
|
|
|
|
|
Subject.Import(_trackedDownload);
|
|
|
|
|
|
|
|
|
|
AssertImportIncomplete();
|
|
|
|
|
AssertNotImported();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
[Test]
|
|
|
|
|
public void should_mark_as_imported_if_the_download_can_be_tracked_using_the_source_seriesid()
|
|
|
|
|
public void should_not_mark_as_imported_if_some_of_episodes_were_not_imported_including_history()
|
|
|
|
|
{
|
|
|
|
|
GivenABadlyNamedDownload();
|
|
|
|
|
var tracks = Builder<Track>.CreateListOfSize(3).BuildList();
|
|
|
|
|
|
|
|
|
|
Mocker.GetMock<IDownloadedTracksImportService>()
|
|
|
|
|
.Setup(v => v.ProcessPath(It.IsAny<string>(), It.IsAny<ImportMode>(), It.IsAny<Artist>(), It.IsAny<DownloadClientItem>()))
|
|
|
|
|
.Returns(new List<ImportResult>
|
|
|
|
|
{
|
|
|
|
|
new ImportResult(new ImportDecision<LocalTrack>(new LocalTrack { Path = @"C:\TestPath\Droned.S01E01.mkv".AsOsAgnostic() }))
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
Mocker.GetMock<IArtistService>()
|
|
|
|
|
.Setup(v => v.GetArtist(It.IsAny<int>()))
|
|
|
|
|
.Returns(BuildRemoteAlbum().Artist);
|
|
|
|
|
var releases = Builder<AlbumRelease>.CreateListOfSize(3).All().With(x => x.Monitored = true).With(x => x.TrackCount = 1).BuildList();
|
|
|
|
|
releases[0].Tracks = new List<Track> { tracks[0] };
|
|
|
|
|
releases[1].Tracks = new List<Track> { tracks[1] };
|
|
|
|
|
releases[2].Tracks = new List<Track> { tracks[2] };
|
|
|
|
|
|
|
|
|
|
Subject.Process(_trackedDownload);
|
|
|
|
|
var albums = Builder<Album>.CreateListOfSize(3).BuildList();
|
|
|
|
|
|
|
|
|
|
AssertCompletedDownload();
|
|
|
|
|
}
|
|
|
|
|
albums[0].AlbumReleases = new List<AlbumRelease> { releases[0] };
|
|
|
|
|
albums[1].AlbumReleases = new List<AlbumRelease> { releases[1] };
|
|
|
|
|
albums[2].AlbumReleases = new List<AlbumRelease> { releases[2] };
|
|
|
|
|
|
|
|
|
|
[Test]
|
|
|
|
|
public void should_not_mark_as_imported_if_the_download_cannot_be_tracked_using_the_source_title_as_it_was_initiated_externally()
|
|
|
|
|
{
|
|
|
|
|
GivenABadlyNamedDownload();
|
|
|
|
|
_trackedDownload.RemoteAlbum.Albums = albums;
|
|
|
|
|
|
|
|
|
|
Mocker.GetMock<IDownloadedTracksImportService>()
|
|
|
|
|
.Setup(v => v.ProcessPath(It.IsAny<string>(), It.IsAny<ImportMode>(), It.IsAny<Artist>(), It.IsAny<DownloadClientItem>()))
|
|
|
|
|
.Returns(new List<ImportResult>
|
|
|
|
|
{
|
|
|
|
|
new ImportResult(new ImportDecision<LocalTrack>(new LocalTrack { Path = @"C:\TestPath\Droned.S01E01.mkv".AsOsAgnostic() }))
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
Mocker.GetMock<IHistoryService>()
|
|
|
|
|
.Setup(s => s.MostRecentForDownloadId(It.Is<string>(i => i == "1234")));
|
|
|
|
|
.Setup(v => v.ProcessPath(It.IsAny<string>(), It.IsAny<ImportMode>(), It.IsAny<Artist>(), It.IsAny<DownloadClientItem>()))
|
|
|
|
|
.Returns(new List<ImportResult>
|
|
|
|
|
{
|
|
|
|
|
new ImportResult(new ImportDecision<LocalTrack>(new LocalTrack { Path = @"C:\TestPath\Droned.S01E01.mkv" })),
|
|
|
|
|
new ImportResult(new ImportDecision<LocalTrack>(new LocalTrack { Path = @"C:\TestPath\Droned.S01E01.mkv" }), "Test Failure"),
|
|
|
|
|
new ImportResult(new ImportDecision<LocalTrack>(new LocalTrack { Path = @"C:\TestPath\Droned.S01E01.mkv" }), "Test Failure")
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
Subject.Process(_trackedDownload);
|
|
|
|
|
var history = Builder<History.History>.CreateListOfSize(2)
|
|
|
|
|
.BuildList();
|
|
|
|
|
|
|
|
|
|
AssertNoCompletedDownload();
|
|
|
|
|
}
|
|
|
|
|
Mocker.GetMock<IHistoryService>()
|
|
|
|
|
.Setup(s => s.FindByDownloadId(It.IsAny<string>()))
|
|
|
|
|
.Returns(history);
|
|
|
|
|
|
|
|
|
|
[Test]
|
|
|
|
|
public void should_not_import_when_there_is_a_title_mismatch()
|
|
|
|
|
{
|
|
|
|
|
_trackedDownload.RemoteAlbum.Artist = null;
|
|
|
|
|
Mocker.GetMock<IParsingService>()
|
|
|
|
|
.Setup(s => s.GetArtist("Drone.S01E01.HDTV"))
|
|
|
|
|
.Returns((Artist)null);
|
|
|
|
|
Mocker.GetMock<ITrackedDownloadAlreadyImported>()
|
|
|
|
|
.Setup(s => s.IsImported(It.IsAny<TrackedDownload>(), It.IsAny<List<History.History>>()))
|
|
|
|
|
.Returns(false);
|
|
|
|
|
|
|
|
|
|
Subject.Process(_trackedDownload);
|
|
|
|
|
Subject.Import(_trackedDownload);
|
|
|
|
|
|
|
|
|
|
AssertNoCompletedDownload();
|
|
|
|
|
AssertNotImported();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
[Test]
|
|
|
|
|
public void should_mark_as_import_title_mismatch_if_ignore_warnings_is_true()
|
|
|
|
|
public void should_mark_as_imported_if_all_tracks_were_imported()
|
|
|
|
|
{
|
|
|
|
|
_trackedDownload.RemoteAlbum.Albums = new List<Album>
|
|
|
|
|
{
|
|
|
|
|
CreateAlbum(0, 1)
|
|
|
|
|
CreateAlbum(1, 2)
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
Mocker.GetMock<IDownloadedTracksImportService>()
|
|
|
|
|
.Setup(v => v.ProcessPath(It.IsAny<string>(), It.IsAny<ImportMode>(), It.IsAny<Artist>(), It.IsAny<DownloadClientItem>()))
|
|
|
|
|
.Returns(new List<ImportResult>
|
|
|
|
|
{
|
|
|
|
|
new ImportResult(new ImportDecision<LocalTrack>(new LocalTrack { Path = @"C:\TestPath\Droned.S01E01.mkv".AsOsAgnostic() }))
|
|
|
|
|
new ImportResult(
|
|
|
|
|
new ImportDecision<LocalTrack>(
|
|
|
|
|
new LocalTrack { Path = @"C:\TestPath\Droned.S01E01.mkv".AsOsAgnostic() })),
|
|
|
|
|
|
|
|
|
|
new ImportResult(
|
|
|
|
|
new ImportDecision<LocalTrack>(
|
|
|
|
|
new LocalTrack { Path = @"C:\TestPath\Droned.S01E02.mkv".AsOsAgnostic() }))
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
Subject.Process(_trackedDownload, true);
|
|
|
|
|
Subject.Import(_trackedDownload);
|
|
|
|
|
|
|
|
|
|
AssertCompletedDownload();
|
|
|
|
|
AssertImported();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
[Test]
|
|
|
|
|
public void should_warn_if_path_is_not_valid_for_windows()
|
|
|
|
|
public void should_mark_as_imported_if_all_episodes_were_imported_including_history()
|
|
|
|
|
{
|
|
|
|
|
WindowsOnly();
|
|
|
|
|
var track1 = new Track { Id = 1 };
|
|
|
|
|
var track2 = new Track { Id = 2 };
|
|
|
|
|
|
|
|
|
|
_trackedDownload.DownloadItem.OutputPath = new OsPath(@"/invalid/Windows/Path");
|
|
|
|
|
var releases = Builder<AlbumRelease>.CreateListOfSize(2).All().With(x => x.Monitored = true).With(x => x.TrackCount = 1).BuildList();
|
|
|
|
|
releases[0].Tracks = new List<Track> { track1 };
|
|
|
|
|
releases[1].Tracks = new List<Track> { track2 };
|
|
|
|
|
|
|
|
|
|
Subject.Process(_trackedDownload);
|
|
|
|
|
var albums = Builder<Album>.CreateListOfSize(2).BuildList();
|
|
|
|
|
|
|
|
|
|
AssertNoAttemptedImport();
|
|
|
|
|
}
|
|
|
|
|
albums[0].AlbumReleases = new List<AlbumRelease> { releases[0] };
|
|
|
|
|
albums[1].AlbumReleases = new List<AlbumRelease> { releases[1] };
|
|
|
|
|
|
|
|
|
|
[Test]
|
|
|
|
|
public void should_warn_if_path_is_not_valid_for_linux()
|
|
|
|
|
{
|
|
|
|
|
PosixOnly();
|
|
|
|
|
_trackedDownload.RemoteAlbum.Albums = albums;
|
|
|
|
|
|
|
|
|
|
_trackedDownload.DownloadItem.OutputPath = new OsPath(@"C:\Invalid\Mono\Path");
|
|
|
|
|
Mocker.GetMock<IDownloadedTracksImportService>()
|
|
|
|
|
.Setup(v => v.ProcessPath(It.IsAny<string>(), It.IsAny<ImportMode>(), It.IsAny<Artist>(), It.IsAny<DownloadClientItem>()))
|
|
|
|
|
.Returns(new List<ImportResult>
|
|
|
|
|
{
|
|
|
|
|
new ImportResult(
|
|
|
|
|
new ImportDecision<LocalTrack>(
|
|
|
|
|
new LocalTrack { Path = @"C:\TestPath\Droned.S01E01.mkv", Tracks = new List<Track> { track1 } })),
|
|
|
|
|
|
|
|
|
|
Subject.Process(_trackedDownload);
|
|
|
|
|
new ImportResult(
|
|
|
|
|
new ImportDecision<LocalTrack>(
|
|
|
|
|
new LocalTrack { Path = @"C:\TestPath\Droned.S01E02.mkv", Tracks = new List<Track> { track2 } }), "Test Failure")
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
AssertNoAttemptedImport();
|
|
|
|
|
}
|
|
|
|
|
var history = Builder<History.History>.CreateListOfSize(2)
|
|
|
|
|
.BuildList();
|
|
|
|
|
|
|
|
|
|
private void AssertNoAttemptedImport()
|
|
|
|
|
{
|
|
|
|
|
Mocker.GetMock<IDownloadedTracksImportService>()
|
|
|
|
|
.Verify(v => v.ProcessPath(It.IsAny<string>(), It.IsAny<ImportMode>(), It.IsAny<Artist>(), It.IsAny<DownloadClientItem>()), Times.Never());
|
|
|
|
|
Mocker.GetMock<IHistoryService>()
|
|
|
|
|
.Setup(s => s.FindByDownloadId(It.IsAny<string>()))
|
|
|
|
|
.Returns(history);
|
|
|
|
|
|
|
|
|
|
AssertNoCompletedDownload();
|
|
|
|
|
Mocker.GetMock<ITrackedDownloadAlreadyImported>()
|
|
|
|
|
.Setup(s => s.IsImported(It.IsAny<TrackedDownload>(), It.IsAny<List<History.History>>()))
|
|
|
|
|
.Returns(true);
|
|
|
|
|
|
|
|
|
|
Subject.Import(_trackedDownload);
|
|
|
|
|
|
|
|
|
|
AssertImported();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private void AssertImportIncomplete()
|
|
|
|
|
[Test]
|
|
|
|
|
public void should_mark_as_imported_if_the_download_can_be_tracked_using_the_source_seriesid()
|
|
|
|
|
{
|
|
|
|
|
Mocker.GetMock<IEventAggregator>()
|
|
|
|
|
.Verify(v => v.PublishEvent(It.IsAny<AlbumImportIncompleteEvent>()), Times.Once());
|
|
|
|
|
GivenABadlyNamedDownload();
|
|
|
|
|
|
|
|
|
|
Mocker.GetMock<IDownloadedTracksImportService>()
|
|
|
|
|
.Setup(v => v.ProcessPath(It.IsAny<string>(), It.IsAny<ImportMode>(), It.IsAny<Artist>(), It.IsAny<DownloadClientItem>()))
|
|
|
|
|
.Returns(new List<ImportResult>
|
|
|
|
|
{
|
|
|
|
|
new ImportResult(new ImportDecision<LocalTrack>(new LocalTrack { Path = @"C:\TestPath\Droned.S01E01.mkv".AsOsAgnostic() }))
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
Subject.Import(_trackedDownload);
|
|
|
|
|
|
|
|
|
|
AssertNoCompletedDownload();
|
|
|
|
|
AssertImported();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private void AssertNoCompletedDownload()
|
|
|
|
|
private void AssertNotImported()
|
|
|
|
|
{
|
|
|
|
|
Mocker.GetMock<IEventAggregator>()
|
|
|
|
|
.Verify(v => v.PublishEvent(It.IsAny<DownloadCompletedEvent>()), Times.Never());
|
|
|
|
|
|
|
|
|
|
_trackedDownload.State.Should().NotBe(TrackedDownloadStage.Imported);
|
|
|
|
|
_trackedDownload.State.Should().Be(TrackedDownloadState.ImportFailed);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private void AssertCompletedDownload()
|
|
|
|
|
private void AssertImported()
|
|
|
|
|
{
|
|
|
|
|
Mocker.GetMock<IDownloadedTracksImportService>()
|
|
|
|
|
.Verify(v => v.ProcessPath(_trackedDownload.DownloadItem.OutputPath.FullPath, ImportMode.Auto, _trackedDownload.RemoteAlbum.Artist, _trackedDownload.DownloadItem), Times.Once());
|
|
|
|
@ -493,7 +393,7 @@ namespace NzbDrone.Core.Test.Download
|
|
|
|
|
Mocker.GetMock<IEventAggregator>()
|
|
|
|
|
.Verify(v => v.PublishEvent(It.IsAny<DownloadCompletedEvent>()), Times.Once());
|
|
|
|
|
|
|
|
|
|
_trackedDownload.State.Should().Be(TrackedDownloadStage.Imported);
|
|
|
|
|
_trackedDownload.State.Should().Be(TrackedDownloadState.Imported);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|