mirror of
https://github.com/lidarr/lidarr.git
synced 2025-08-20 13:33:34 -07:00
Fixed: Map dsm shared folder to full path in status (#797)
* Fixed: Map dsm shared folder to full path in status * Add tests
This commit is contained in:
parent
add32ff9f3
commit
801ece337c
4 changed files with 105 additions and 5 deletions
|
@ -7,6 +7,7 @@ using NUnit.Framework;
|
|||
using NzbDrone.Common.Disk;
|
||||
using NzbDrone.Common.Http;
|
||||
using NzbDrone.Core.Download;
|
||||
using NzbDrone.Core.Download.Clients;
|
||||
using NzbDrone.Core.Download.Clients.DownloadStation;
|
||||
using NzbDrone.Core.Download.Clients.DownloadStation.Proxies;
|
||||
using NzbDrone.Core.MediaFiles.TorrentInfo;
|
||||
|
@ -296,6 +297,17 @@ namespace NzbDrone.Core.Test.Download.DownloadClientTests.DownloadStationTests
|
|||
.Returns<OsPath, DownloadStationSettings, string>((path, setttings, serial) => _physicalPath);
|
||||
}
|
||||
|
||||
protected void GivenSharedFolder(string share)
|
||||
{
|
||||
Mocker.GetMock<ISharedFolderResolver>()
|
||||
.Setup(s => s.RemapToFullPath(It.IsAny<OsPath>(), It.IsAny<DownloadStationSettings>(), It.IsAny<string>()))
|
||||
.Throws(new DownloadClientException("There is no matching shared folder"));
|
||||
|
||||
Mocker.GetMock<ISharedFolderResolver>()
|
||||
.Setup(s => s.RemapToFullPath(It.Is<OsPath>(x => x.FullPath == share), It.IsAny<DownloadStationSettings>(), It.IsAny<string>()))
|
||||
.Returns<OsPath, DownloadStationSettings, string>((path, setttings, serial) => _physicalPath);
|
||||
}
|
||||
|
||||
protected void GivenSerialNumber()
|
||||
{
|
||||
Mocker.GetMock<ISerialNumberProvider>()
|
||||
|
@ -495,6 +507,41 @@ namespace NzbDrone.Core.Test.Download.DownloadClientTests.DownloadStationTests
|
|||
.Verify(v => v.AddTaskFromUrl(It.IsAny<string>(), null, _settings), Times.Never());
|
||||
}
|
||||
|
||||
[Test]
|
||||
public void GetStatus_should_map_outputpath_when_using_default()
|
||||
{
|
||||
GivenSerialNumber();
|
||||
GivenSharedFolder("/somepath");
|
||||
|
||||
var status = Subject.GetStatus();
|
||||
|
||||
status.OutputRootFolders.First().Should().Be(_physicalPath);
|
||||
}
|
||||
|
||||
[Test]
|
||||
public void GetStatus_should_map_outputpath_when_using_destination()
|
||||
{
|
||||
GivenSerialNumber();
|
||||
GivenTvDirectory();
|
||||
GivenSharedFolder($"/{_musicDirectory}");
|
||||
|
||||
var status = Subject.GetStatus();
|
||||
|
||||
status.OutputRootFolders.First().Should().Be(_physicalPath);
|
||||
}
|
||||
|
||||
[Test]
|
||||
public void GetStatus_should_map_outputpath_when_using_category()
|
||||
{
|
||||
GivenSerialNumber();
|
||||
GivenMusicCategory();
|
||||
GivenSharedFolder($"/somepath/{_category}");
|
||||
|
||||
var status = Subject.GetStatus();
|
||||
|
||||
status.OutputRootFolders.First().Should().Be(_physicalPath);
|
||||
}
|
||||
|
||||
[Test]
|
||||
public void GetItems_should_set_outputPath_to_base_folder_when_single_file_non_finished_tasks()
|
||||
{
|
||||
|
|
|
@ -9,10 +9,10 @@ using NzbDrone.Common.Http;
|
|||
using NzbDrone.Core.Download;
|
||||
using NzbDrone.Core.Download.Clients.DownloadStation;
|
||||
using NzbDrone.Core.Download.Clients.DownloadStation.Proxies;
|
||||
using NzbDrone.Core.MediaFiles.TorrentInfo;
|
||||
using NzbDrone.Core.Parser.Model;
|
||||
using NzbDrone.Test.Common;
|
||||
using NzbDrone.Core.Organizer;
|
||||
using NzbDrone.Core.Download.Clients;
|
||||
|
||||
namespace NzbDrone.Core.Test.Download.DownloadClientTests.DownloadStationTests
|
||||
{
|
||||
|
@ -189,6 +189,18 @@ namespace NzbDrone.Core.Test.Download.DownloadClientTests.DownloadStationTests
|
|||
.Returns<OsPath, DownloadStationSettings, string>((path, setttings, serial) => _physicalPath);
|
||||
}
|
||||
|
||||
protected void GivenSharedFolder(string share)
|
||||
{
|
||||
Mocker.GetMock<ISharedFolderResolver>()
|
||||
.Setup(s => s.RemapToFullPath(It.IsAny<OsPath>(), It.IsAny<DownloadStationSettings>(), It.IsAny<string>()))
|
||||
.Throws(new DownloadClientException("There is no matching shared folder"));
|
||||
|
||||
Mocker.GetMock<ISharedFolderResolver>()
|
||||
.Setup(s => s.RemapToFullPath(It.Is<OsPath>(x => x.FullPath == share), It.IsAny<DownloadStationSettings>(), It.IsAny<string>()))
|
||||
.Returns<OsPath, DownloadStationSettings, string>((path, setttings, serial) => _physicalPath);
|
||||
}
|
||||
|
||||
|
||||
protected void GivenSerialNumber()
|
||||
{
|
||||
Mocker.GetMock<ISerialNumberProvider>()
|
||||
|
@ -373,6 +385,41 @@ namespace NzbDrone.Core.Test.Download.DownloadClientTests.DownloadStationTests
|
|||
Mocker.GetMock<IDownloadStationTaskProxy>()
|
||||
.Verify(v => v.AddTaskFromUrl(It.IsAny<string>(), null, _settings), Times.Never());
|
||||
}
|
||||
|
||||
[Test]
|
||||
public void GetStatus_should_map_outputpath_when_using_default()
|
||||
{
|
||||
GivenSerialNumber();
|
||||
GivenSharedFolder("/somepath");
|
||||
|
||||
var status = Subject.GetStatus();
|
||||
|
||||
status.OutputRootFolders.First().Should().Be(_physicalPath);
|
||||
}
|
||||
|
||||
[Test]
|
||||
public void GetStatus_should_map_outputpath_when_using_destination()
|
||||
{
|
||||
GivenSerialNumber();
|
||||
GivenTvDirectory();
|
||||
GivenSharedFolder($"/{_musicDirectory}");
|
||||
|
||||
var status = Subject.GetStatus();
|
||||
|
||||
status.OutputRootFolders.First().Should().Be(_physicalPath);
|
||||
}
|
||||
|
||||
[Test]
|
||||
public void GetStatus_should_map_outputpath_when_using_category()
|
||||
{
|
||||
GivenSerialNumber();
|
||||
GivenMusicCategory();
|
||||
GivenSharedFolder($"/somepath/{_category}");
|
||||
|
||||
var status = Subject.GetStatus();
|
||||
|
||||
status.OutputRootFolders.First().Should().Be(_physicalPath);
|
||||
}
|
||||
|
||||
[Test]
|
||||
public void GetItems_should_not_map_outputpath_for_queued_or_downloading_tasks()
|
||||
|
|
|
@ -113,12 +113,15 @@ namespace NzbDrone.Core.Download.Clients.DownloadStation
|
|||
{
|
||||
try
|
||||
{
|
||||
var path = GetDownloadDirectory();
|
||||
var serialNumber = _serialNumberProvider.GetSerialNumber(Settings);
|
||||
var sharedFolder = GetDownloadDirectory() ?? GetDefaultDir();
|
||||
var outputPath = new OsPath($"/{sharedFolder.TrimStart('/')}");
|
||||
var path = _sharedFolderResolver.RemapToFullPath(outputPath, Settings, serialNumber);
|
||||
|
||||
return new DownloadClientInfo
|
||||
{
|
||||
IsLocalhost = Settings.Host == "127.0.0.1" || Settings.Host == "localhost",
|
||||
OutputRootFolders = new List<OsPath> { _remotePathMappingService.RemapRemoteToLocal(Settings.Host, new OsPath(path)) }
|
||||
OutputRootFolders = new List<OsPath> { _remotePathMappingService.RemapRemoteToLocal(Settings.Host, path) }
|
||||
};
|
||||
}
|
||||
catch (DownloadClientException e)
|
||||
|
|
|
@ -138,12 +138,15 @@ namespace NzbDrone.Core.Download.Clients.DownloadStation
|
|||
{
|
||||
try
|
||||
{
|
||||
var path = GetDownloadDirectory();
|
||||
var serialNumber = _serialNumberProvider.GetSerialNumber(Settings);
|
||||
var sharedFolder = GetDownloadDirectory() ?? GetDefaultDir();
|
||||
var outputPath = new OsPath($"/{sharedFolder.TrimStart('/')}");
|
||||
var path = _sharedFolderResolver.RemapToFullPath(outputPath, Settings, serialNumber);
|
||||
|
||||
return new DownloadClientInfo
|
||||
{
|
||||
IsLocalhost = Settings.Host == "127.0.0.1" || Settings.Host == "localhost",
|
||||
OutputRootFolders = new List<OsPath> { _remotePathMappingService.RemapRemoteToLocal(Settings.Host, new OsPath(path)) }
|
||||
OutputRootFolders = new List<OsPath> { _remotePathMappingService.RemapRemoteToLocal(Settings.Host, path) }
|
||||
};
|
||||
}
|
||||
catch (DownloadClientException e)
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue