Fixed: Checks full path for _UNPACK_ prefix so that full season downloads are properly checked for unpacking.

This commit is contained in:
Taloth Saldono 2014-05-30 19:38:52 +02:00
parent c04ae9f1d0
commit 50303ce470
2 changed files with 16 additions and 10 deletions

View File

@ -36,7 +36,7 @@ namespace NzbDrone.Core.Test.MediaFiles.EpisodeImport.Specifications
private void GivenInWorkingFolder() private void GivenInWorkingFolder()
{ {
_localEpisode.Path = @"C:\Test\Unsorted TV\_UNPACK_30.rock\30.rock.s01e01.avi".AsOsAgnostic(); _localEpisode.Path = @"C:\Test\Unsorted TV\_UNPACK_30.rock\someSubFolder\30.rock.s01e01.avi".AsOsAgnostic();
} }
private void GivenLastWriteTimeUtc(DateTime time) private void GivenLastWriteTimeUtc(DateTime time)

View File

@ -34,19 +34,25 @@ namespace NzbDrone.Core.MediaFiles.EpisodeImport.Specifications
foreach (var workingFolder in _configService.DownloadClientWorkingFolders.Split('|')) foreach (var workingFolder in _configService.DownloadClientWorkingFolders.Split('|'))
{ {
if (Directory.GetParent(localEpisode.Path).Name.StartsWith(workingFolder)) DirectoryInfo parent = Directory.GetParent(localEpisode.Path);
while (parent != null)
{ {
if (OsInfo.IsMono) if (parent.Name.StartsWith(workingFolder))
{ {
_logger.Debug("{0} is still being unpacked", localEpisode.Path); if (OsInfo.IsMono)
return false; {
_logger.Debug("{0} is still being unpacked", localEpisode.Path);
return false;
}
if (_diskProvider.FileGetLastWriteUtc(localEpisode.Path) > DateTime.UtcNow.AddMinutes(-5))
{
_logger.Debug("{0} appears to be unpacking still", localEpisode.Path);
return false;
}
} }
if (_diskProvider.FileGetLastWriteUtc(localEpisode.Path) > DateTime.UtcNow.AddMinutes(-5)) parent = parent.Parent;
{
_logger.Debug("{0} appears to be unpacking still", localEpisode.Path);
return false;
}
} }
} }