mirror of
https://github.com/Sonarr/Sonarr.git
synced 2025-01-17 10:45:49 +02:00
Fixed: Use file name when importing batch release when renaming is disabled
Closes #3056
This commit is contained in:
parent
8876c9194d
commit
cbc4295f28
@ -44,7 +44,7 @@ public void should_not_use_folder_for_full_season()
|
||||
Series = _series
|
||||
};
|
||||
|
||||
Subject.Aggregate(localEpisode, null, false);
|
||||
Subject.Aggregate(localEpisode, null);
|
||||
|
||||
Mocker.GetMock<IParsingService>()
|
||||
.Verify(v => v.GetEpisodes(fileEpisodeInfo, _series, localEpisode.SceneSource, null), Times.Once());
|
||||
@ -60,10 +60,11 @@ public void should_not_use_folder_when_it_contains_more_than_one_valid_video_fil
|
||||
FileEpisodeInfo = fileEpisodeInfo,
|
||||
FolderEpisodeInfo = folderEpisodeInfo,
|
||||
Path = @"C:\Test\Unsorted TV\Series.Title.S01\Series.Title.S01E01.mkv".AsOsAgnostic(),
|
||||
Series = _series
|
||||
Series = _series,
|
||||
OtherVideoFiles = true
|
||||
};
|
||||
|
||||
Subject.Aggregate(localEpisode, null, true);
|
||||
Subject.Aggregate(localEpisode, null);
|
||||
|
||||
Mocker.GetMock<IParsingService>()
|
||||
.Verify(v => v.GetEpisodes(fileEpisodeInfo, _series, localEpisode.SceneSource, null), Times.Once());
|
||||
@ -82,7 +83,7 @@ public void should_not_use_folder_name_if_file_name_is_scene_name()
|
||||
Series = _series
|
||||
};
|
||||
|
||||
Subject.Aggregate(localEpisode, null, false);
|
||||
Subject.Aggregate(localEpisode, null);
|
||||
|
||||
Mocker.GetMock<IParsingService>()
|
||||
.Verify(v => v.GetEpisodes(fileEpisodeInfo, _series, localEpisode.SceneSource, null), Times.Once());
|
||||
@ -101,7 +102,7 @@ public void should_use_folder_when_only_one_video_file()
|
||||
Series = _series
|
||||
};
|
||||
|
||||
Subject.Aggregate(localEpisode, null, false);
|
||||
Subject.Aggregate(localEpisode, null);
|
||||
|
||||
Mocker.GetMock<IParsingService>()
|
||||
.Verify(v => v.GetEpisodes(folderEpisodeInfo, _series, localEpisode.SceneSource, null), Times.Once());
|
||||
@ -120,7 +121,7 @@ public void should_use_file_when_folder_is_absolute_and_file_is_not()
|
||||
Series = _series
|
||||
};
|
||||
|
||||
Subject.Aggregate(localEpisode, null, false);
|
||||
Subject.Aggregate(localEpisode, null);
|
||||
|
||||
Mocker.GetMock<IParsingService>()
|
||||
.Verify(v => v.GetEpisodes(fileEpisodeInfo, _series, localEpisode.SceneSource, null), Times.Once());
|
||||
@ -143,7 +144,7 @@ public void should_use_special_info_when_not_null()
|
||||
.Setup(s => s.ParseSpecialEpisodeTitle(fileEpisodeInfo, It.IsAny<string>(), _series))
|
||||
.Returns(specialEpisodeInfo);
|
||||
|
||||
Subject.Aggregate(localEpisode, null, false);
|
||||
Subject.Aggregate(localEpisode, null);
|
||||
|
||||
Mocker.GetMock<IParsingService>()
|
||||
.Verify(v => v.GetEpisodes(specialEpisodeInfo, _series, localEpisode.SceneSource, null), Times.Once());
|
||||
|
@ -44,7 +44,7 @@ public void should_return_file_language_when_only_file_info_is_known()
|
||||
{
|
||||
_localEpisode.FileEpisodeInfo = GetParsedEpisodeInfo(Language.English, _simpleReleaseTitle);
|
||||
|
||||
Subject.Aggregate(_localEpisode, null, false).Language.Should().Be(_localEpisode.FileEpisodeInfo.Language);
|
||||
Subject.Aggregate(_localEpisode, null).Language.Should().Be(_localEpisode.FileEpisodeInfo.Language);
|
||||
}
|
||||
|
||||
[Test]
|
||||
@ -53,7 +53,7 @@ public void should_return_folder_language_when_folder_info_is_known()
|
||||
_localEpisode.FolderEpisodeInfo = GetParsedEpisodeInfo(Language.English, _simpleReleaseTitle);
|
||||
_localEpisode.FileEpisodeInfo = GetParsedEpisodeInfo(Language.English, _simpleReleaseTitle);
|
||||
|
||||
Subject.Aggregate(_localEpisode, null, false).Language.Should().Be(_localEpisode.FolderEpisodeInfo.Language);
|
||||
Subject.Aggregate(_localEpisode, null).Language.Should().Be(_localEpisode.FolderEpisodeInfo.Language);
|
||||
}
|
||||
|
||||
[Test]
|
||||
@ -63,7 +63,7 @@ public void should_return_download_client_item_language_when_download_client_ite
|
||||
_localEpisode.FolderEpisodeInfo = GetParsedEpisodeInfo(Language.English, _simpleReleaseTitle);
|
||||
_localEpisode.FileEpisodeInfo = GetParsedEpisodeInfo(Language.English, _simpleReleaseTitle);
|
||||
|
||||
Subject.Aggregate(_localEpisode, null, false).Language.Should().Be(_localEpisode.DownloadClientEpisodeInfo.Language);
|
||||
Subject.Aggregate(_localEpisode, null).Language.Should().Be(_localEpisode.DownloadClientEpisodeInfo.Language);
|
||||
|
||||
}
|
||||
|
||||
@ -74,7 +74,7 @@ public void should_return_file_language_when_file_language_is_higher_than_others
|
||||
_localEpisode.FolderEpisodeInfo = GetParsedEpisodeInfo(Language.English, _simpleReleaseTitle);
|
||||
_localEpisode.FileEpisodeInfo = GetParsedEpisodeInfo(Language.French, _simpleReleaseTitle);
|
||||
|
||||
Subject.Aggregate(_localEpisode, null, false).Language.Should().Be(_localEpisode.FileEpisodeInfo.Language);
|
||||
Subject.Aggregate(_localEpisode, null).Language.Should().Be(_localEpisode.FileEpisodeInfo.Language);
|
||||
}
|
||||
|
||||
[Test]
|
||||
@ -83,7 +83,7 @@ public void should_return_english_if_parsed_language_is_in_episode_title_and_rel
|
||||
_localEpisode.Episodes.First().Title = "The Swedish Job";
|
||||
_localEpisode.FileEpisodeInfo = GetParsedEpisodeInfo(Language.Swedish, "Series.Title.S01E01.The.Swedish.Job.720p.WEB-DL-RlsGrp");
|
||||
|
||||
Subject.Aggregate(_localEpisode, null, false).Language.Should().Be(Language.English);
|
||||
Subject.Aggregate(_localEpisode, null).Language.Should().Be(Language.English);
|
||||
|
||||
}
|
||||
|
||||
@ -93,7 +93,7 @@ public void should_return_parsed_if_parsed_language_is_not_episode_title_and_rel
|
||||
_localEpisode.Episodes.First().Title = "The Swedish Job";
|
||||
_localEpisode.FileEpisodeInfo = GetParsedEpisodeInfo(Language.French, "Series.Title.S01E01.The.Swedish.Job.720p.WEB-DL-RlsGrp");
|
||||
|
||||
Subject.Aggregate(_localEpisode, null, false).Language.Should().Be(_localEpisode.FileEpisodeInfo.Language);
|
||||
Subject.Aggregate(_localEpisode, null).Language.Should().Be(_localEpisode.FileEpisodeInfo.Language);
|
||||
|
||||
}
|
||||
}
|
||||
|
@ -60,7 +60,7 @@ public void should_return_HDTV720_from_extension_when_other_augments_are_null()
|
||||
|
||||
GivenAugmenters(_fileExtensionAugmenter, nullMock);
|
||||
|
||||
var result = Subject.Aggregate(new LocalEpisode(), null, false);
|
||||
var result = Subject.Aggregate(new LocalEpisode(), null);
|
||||
|
||||
result.Quality.SourceDetectionSource.Should().Be(QualityDetectionSource.Extension);
|
||||
result.Quality.ResolutionDetectionSource.Should().Be(QualityDetectionSource.Extension);
|
||||
@ -72,7 +72,7 @@ public void should_return_SDTV_when_HDTV720_came_from_extension()
|
||||
{
|
||||
GivenAugmenters(_fileExtensionAugmenter, _nameAugmenter);
|
||||
|
||||
var result = Subject.Aggregate(new LocalEpisode(), null, false);
|
||||
var result = Subject.Aggregate(new LocalEpisode(), null);
|
||||
|
||||
result.Quality.SourceDetectionSource.Should().Be(QualityDetectionSource.Name);
|
||||
result.Quality.ResolutionDetectionSource.Should().Be(QualityDetectionSource.Name);
|
||||
@ -84,7 +84,7 @@ public void should_return_HDTV1080p_when_HDTV720_came_from_extension_and_mediain
|
||||
{
|
||||
GivenAugmenters(_fileExtensionAugmenter, _mediaInfoAugmenter);
|
||||
|
||||
var result = Subject.Aggregate(new LocalEpisode(), null, false);
|
||||
var result = Subject.Aggregate(new LocalEpisode(), null);
|
||||
|
||||
result.Quality.SourceDetectionSource.Should().Be(QualityDetectionSource.Extension);
|
||||
result.Quality.ResolutionDetectionSource.Should().Be(QualityDetectionSource.MediaInfo);
|
||||
@ -96,7 +96,7 @@ public void should_return_HDTV1080p_when_SDTV_came_from_name_and_mediainfo_indic
|
||||
{
|
||||
GivenAugmenters(_nameAugmenter, _mediaInfoAugmenter);
|
||||
|
||||
var result = Subject.Aggregate(new LocalEpisode(), null, false);
|
||||
var result = Subject.Aggregate(new LocalEpisode(), null);
|
||||
|
||||
result.Quality.SourceDetectionSource.Should().Be(QualityDetectionSource.Name);
|
||||
result.Quality.ResolutionDetectionSource.Should().Be(QualityDetectionSource.MediaInfo);
|
||||
@ -108,7 +108,7 @@ public void should_return_WEBDL480p_when_file_name_has_HDTV480p_but_release_name
|
||||
{
|
||||
GivenAugmenters(_nameAugmenter, _releaseNameAugmenter);
|
||||
|
||||
var result = Subject.Aggregate(new LocalEpisode(), new DownloadClientItem(), false);
|
||||
var result = Subject.Aggregate(new LocalEpisode(), new DownloadClientItem());
|
||||
|
||||
result.Quality.SourceDetectionSource.Should().Be(QualityDetectionSource.Name);
|
||||
result.Quality.ResolutionDetectionSource.Should().Be(QualityDetectionSource.Name);
|
||||
@ -120,7 +120,7 @@ public void should_return_version_1_when_no_version_specified()
|
||||
{
|
||||
GivenAugmenters(_nameAugmenter, _releaseNameAugmenter);
|
||||
|
||||
var result = Subject.Aggregate(new LocalEpisode(), new DownloadClientItem(), false);
|
||||
var result = Subject.Aggregate(new LocalEpisode(), new DownloadClientItem());
|
||||
|
||||
result.Quality.Revision.Version.Should().Be(1);
|
||||
result.Quality.RevisionDetectionSource.Should().Be(QualityDetectionSource.Unknown);
|
||||
@ -134,7 +134,7 @@ public void should_return_version_2_when_name_indicates_proper()
|
||||
|
||||
GivenAugmenters(_nameAugmenter, _releaseNameAugmenter);
|
||||
|
||||
var result = Subject.Aggregate(new LocalEpisode(), new DownloadClientItem(), false);
|
||||
var result = Subject.Aggregate(new LocalEpisode(), new DownloadClientItem());
|
||||
|
||||
result.Quality.Revision.Version.Should().Be(2);
|
||||
result.Quality.RevisionDetectionSource.Should().Be(QualityDetectionSource.Name);
|
||||
@ -148,7 +148,7 @@ public void should_return_version_0_when_file_name_indicates_v0()
|
||||
|
||||
GivenAugmenters(_nameAugmenter, _releaseNameAugmenter);
|
||||
|
||||
var result = Subject.Aggregate(new LocalEpisode(), new DownloadClientItem(), false);
|
||||
var result = Subject.Aggregate(new LocalEpisode(), new DownloadClientItem());
|
||||
|
||||
result.Quality.Revision.Version.Should().Be(0);
|
||||
result.Quality.RevisionDetectionSource.Should().Be(QualityDetectionSource.Name);
|
||||
@ -165,7 +165,7 @@ public void should_return_version_2_when_file_name_indicates_v0_and_release_name
|
||||
|
||||
GivenAugmenters(_nameAugmenter, _releaseNameAugmenter);
|
||||
|
||||
var result = Subject.Aggregate(new LocalEpisode(), new DownloadClientItem(), false);
|
||||
var result = Subject.Aggregate(new LocalEpisode(), new DownloadClientItem());
|
||||
|
||||
result.Quality.Revision.Version.Should().Be(2);
|
||||
result.Quality.RevisionDetectionSource.Should().Be(QualityDetectionSource.Name);
|
||||
|
@ -34,7 +34,7 @@ public void should_not_use_downloadclient_for_full_season()
|
||||
Series = _series
|
||||
};
|
||||
|
||||
Subject.Aggregate(localEpisode, null, false);
|
||||
Subject.Aggregate(localEpisode, null);
|
||||
|
||||
localEpisode.ReleaseGroup.Should().Be("Wizzy");
|
||||
}
|
||||
@ -52,7 +52,7 @@ public void should_not_use_folder_for_full_season()
|
||||
Series = _series
|
||||
};
|
||||
|
||||
Subject.Aggregate(localEpisode, null, false);
|
||||
Subject.Aggregate(localEpisode, null);
|
||||
|
||||
localEpisode.ReleaseGroup.Should().Be("Wizzy");
|
||||
}
|
||||
@ -72,7 +72,7 @@ public void should_prefer_downloadclient()
|
||||
Series = _series
|
||||
};
|
||||
|
||||
Subject.Aggregate(localEpisode, null, false);
|
||||
Subject.Aggregate(localEpisode, null);
|
||||
|
||||
localEpisode.ReleaseGroup.Should().Be("Viva");
|
||||
}
|
||||
@ -92,7 +92,7 @@ public void should_prefer_folder()
|
||||
Series = _series
|
||||
};
|
||||
|
||||
Subject.Aggregate(localEpisode, null, false);
|
||||
Subject.Aggregate(localEpisode, null);
|
||||
|
||||
localEpisode.ReleaseGroup.Should().Be("Drone");
|
||||
}
|
||||
@ -112,7 +112,7 @@ public void should_fallback_to_file()
|
||||
Series = _series
|
||||
};
|
||||
|
||||
Subject.Aggregate(localEpisode, null, false);
|
||||
Subject.Aggregate(localEpisode, null);
|
||||
|
||||
localEpisode.ReleaseGroup.Should().Be("Wizzy");
|
||||
}
|
||||
|
@ -93,8 +93,8 @@ private void GivenVideoFiles(IEnumerable<string> videoFiles)
|
||||
private void GivenAugmentationSuccess()
|
||||
{
|
||||
Mocker.GetMock<IAggregationService>()
|
||||
.Setup(s => s.Augment(It.IsAny<LocalEpisode>(), It.IsAny<DownloadClientItem>(), It.IsAny<bool>()))
|
||||
.Callback<LocalEpisode, DownloadClientItem, bool>((localEpisode, downloadClientItem, otherFiles) =>
|
||||
.Setup(s => s.Augment(It.IsAny<LocalEpisode>(), It.IsAny<DownloadClientItem>()))
|
||||
.Callback<LocalEpisode, DownloadClientItem>((localEpisode, downloadClientItem) =>
|
||||
{
|
||||
localEpisode.Episodes = _localEpisode.Episodes;
|
||||
});
|
||||
@ -164,7 +164,7 @@ public void should_not_blowup_the_process_due_to_failed_parse()
|
||||
GivenSpecifications(_pass1);
|
||||
|
||||
Mocker.GetMock<IAggregationService>()
|
||||
.Setup(c => c.Augment(It.IsAny<LocalEpisode>(), It.IsAny<DownloadClientItem>(), It.IsAny<bool>()))
|
||||
.Setup(c => c.Augment(It.IsAny<LocalEpisode>(), It.IsAny<DownloadClientItem>()))
|
||||
.Throws<TestException>();
|
||||
|
||||
_videoFiles = new List<string>
|
||||
@ -179,7 +179,7 @@ public void should_not_blowup_the_process_due_to_failed_parse()
|
||||
Subject.GetImportDecisions(_videoFiles, _series);
|
||||
|
||||
Mocker.GetMock<IAggregationService>()
|
||||
.Verify(c => c.Augment(It.IsAny<LocalEpisode>(), It.IsAny<DownloadClientItem>(), It.IsAny<bool>()), Times.Exactly(_videoFiles.Count));
|
||||
.Verify(c => c.Augment(It.IsAny<LocalEpisode>(), It.IsAny<DownloadClientItem>()), Times.Exactly(_videoFiles.Count));
|
||||
|
||||
ExceptionVerification.ExpectedErrors(3);
|
||||
}
|
||||
@ -200,7 +200,7 @@ public void should_not_throw_if_episodes_are_not_found()
|
||||
var decisions = Subject.GetImportDecisions(_videoFiles, _series);
|
||||
|
||||
Mocker.GetMock<IAggregationService>()
|
||||
.Verify(c => c.Augment(It.IsAny<LocalEpisode>(), It.IsAny<DownloadClientItem>(), It.IsAny<bool>()), Times.Exactly(_videoFiles.Count));
|
||||
.Verify(c => c.Augment(It.IsAny<LocalEpisode>(), It.IsAny<DownloadClientItem>()), Times.Exactly(_videoFiles.Count));
|
||||
|
||||
decisions.Should().HaveCount(3);
|
||||
decisions.First().Rejections.Should().NotBeEmpty();
|
||||
@ -210,7 +210,7 @@ public void should_not_throw_if_episodes_are_not_found()
|
||||
public void should_return_a_decision_when_exception_is_caught()
|
||||
{
|
||||
Mocker.GetMock<IAggregationService>()
|
||||
.Setup(c => c.Augment(It.IsAny<LocalEpisode>(), It.IsAny<DownloadClientItem>(), It.IsAny<bool>()))
|
||||
.Setup(c => c.Augment(It.IsAny<LocalEpisode>(), It.IsAny<DownloadClientItem>()))
|
||||
.Throws<TestException>();
|
||||
|
||||
_videoFiles = new List<string>
|
||||
|
@ -71,7 +71,7 @@ public override IEnumerable<ExtraFile> ProcessFiles(Series series, List<string>
|
||||
|
||||
try
|
||||
{
|
||||
_aggregationService.Augment(localEpisode, null, false);
|
||||
_aggregationService.Augment(localEpisode, null);
|
||||
}
|
||||
catch (AugmentingFailedException)
|
||||
{
|
||||
|
@ -56,7 +56,7 @@ public override IEnumerable<ExtraFile> ProcessFiles(Series series, List<string>
|
||||
|
||||
try
|
||||
{
|
||||
_aggregationService.Augment(localEpisode, null, false);
|
||||
_aggregationService.Augment(localEpisode, null);
|
||||
}
|
||||
catch (AugmentingFailedException)
|
||||
{
|
||||
|
@ -51,7 +51,7 @@ public override IEnumerable<ExtraFile> ProcessFiles(Series series, List<string>
|
||||
|
||||
try
|
||||
{
|
||||
_aggregationService.Augment(localEpisode, null, false);
|
||||
_aggregationService.Augment(localEpisode, null);
|
||||
}
|
||||
catch (AugmentingFailedException)
|
||||
{
|
||||
|
@ -15,7 +15,7 @@ namespace NzbDrone.Core.MediaFiles.EpisodeImport.Aggregation
|
||||
{
|
||||
public interface IAggregationService
|
||||
{
|
||||
LocalEpisode Augment(LocalEpisode localEpisode, DownloadClientItem downloadClientItem, bool otherFiles);
|
||||
LocalEpisode Augment(LocalEpisode localEpisode, DownloadClientItem downloadClientItem);
|
||||
}
|
||||
|
||||
public class AggregationService : IAggregationService
|
||||
@ -39,7 +39,7 @@ public AggregationService(IEnumerable<IAggregateLocalEpisode> augmenters,
|
||||
_logger = logger;
|
||||
}
|
||||
|
||||
public LocalEpisode Augment(LocalEpisode localEpisode, DownloadClientItem downloadClientItem, bool otherFiles)
|
||||
public LocalEpisode Augment(LocalEpisode localEpisode, DownloadClientItem downloadClientItem)
|
||||
{
|
||||
var isMediaFile = MediaFileExtensions.Extensions.Contains(Path.GetExtension(localEpisode.Path));
|
||||
|
||||
@ -65,7 +65,7 @@ public LocalEpisode Augment(LocalEpisode localEpisode, DownloadClientItem downlo
|
||||
{
|
||||
try
|
||||
{
|
||||
augmenter.Aggregate(localEpisode, downloadClientItem, otherFiles);
|
||||
augmenter.Aggregate(localEpisode, downloadClientItem);
|
||||
}
|
||||
catch (Exception ex)
|
||||
{
|
||||
|
@ -16,20 +16,20 @@ public AggregateEpisodes(IParsingService parsingService)
|
||||
_parsingService = parsingService;
|
||||
}
|
||||
|
||||
public LocalEpisode Aggregate(LocalEpisode localEpisode, DownloadClientItem downloadClientItem, bool otherFiles)
|
||||
public LocalEpisode Aggregate(LocalEpisode localEpisode, DownloadClientItem downloadClientItem)
|
||||
{
|
||||
localEpisode.Episodes = GetEpisodes(localEpisode, otherFiles);
|
||||
localEpisode.Episodes = GetEpisodes(localEpisode);
|
||||
|
||||
return localEpisode;
|
||||
}
|
||||
|
||||
private ParsedEpisodeInfo GetBestEpisodeInfo(LocalEpisode localEpisode, bool otherFiles)
|
||||
private ParsedEpisodeInfo GetBestEpisodeInfo(LocalEpisode localEpisode)
|
||||
{
|
||||
var parsedEpisodeInfo = localEpisode.FileEpisodeInfo;
|
||||
var downloadClientEpisodeInfo = localEpisode.DownloadClientEpisodeInfo;
|
||||
var folderEpisodeInfo = localEpisode.FolderEpisodeInfo;
|
||||
|
||||
if (!otherFiles && !SceneChecker.IsSceneTitle(Path.GetFileNameWithoutExtension(localEpisode.Path)))
|
||||
if (!localEpisode.OtherVideoFiles && !SceneChecker.IsSceneTitle(Path.GetFileNameWithoutExtension(localEpisode.Path)))
|
||||
{
|
||||
if (downloadClientEpisodeInfo != null &&
|
||||
!downloadClientEpisodeInfo.FullSeason &&
|
||||
@ -59,9 +59,9 @@ private ParsedEpisodeInfo GetBestEpisodeInfo(LocalEpisode localEpisode, bool oth
|
||||
return parsedEpisodeInfo;
|
||||
}
|
||||
|
||||
private List<Episode> GetEpisodes(LocalEpisode localEpisode, bool otherFiles)
|
||||
private List<Episode> GetEpisodes(LocalEpisode localEpisode)
|
||||
{
|
||||
var bestEpisodeInfoForEpisodes = GetBestEpisodeInfo(localEpisode, otherFiles);
|
||||
var bestEpisodeInfoForEpisodes = GetBestEpisodeInfo(localEpisode);
|
||||
var isMediaFile = MediaFileExtensions.Extensions.Contains(Path.GetExtension(localEpisode.Path));
|
||||
|
||||
if (bestEpisodeInfoForEpisodes == null)
|
||||
|
@ -19,7 +19,7 @@ public AggregateLanguage(Logger logger)
|
||||
_logger = logger;
|
||||
}
|
||||
|
||||
public LocalEpisode Aggregate(LocalEpisode localEpisode, DownloadClientItem downloadClientItem, bool otherFiles)
|
||||
public LocalEpisode Aggregate(LocalEpisode localEpisode, DownloadClientItem downloadClientItem)
|
||||
{
|
||||
// Get languages in preferred order, download client item, folder and finally file.
|
||||
// Non-English languages will be preferred later, in the event there is a conflict
|
||||
|
@ -14,7 +14,7 @@ public AggregatePreferredWordScore(IPreferredWordService preferredWordService)
|
||||
_preferredWordService = preferredWordService;
|
||||
}
|
||||
|
||||
public LocalEpisode Aggregate(LocalEpisode localEpisode, DownloadClientItem downloadClientItem, bool otherFiles)
|
||||
public LocalEpisode Aggregate(LocalEpisode localEpisode, DownloadClientItem downloadClientItem)
|
||||
{
|
||||
var series = localEpisode.Series;
|
||||
var scores = new List<int>();
|
||||
|
@ -20,7 +20,7 @@ public AggregateQuality(IEnumerable<IAugmentQuality> augmentQualities,
|
||||
_logger = logger;
|
||||
}
|
||||
|
||||
public LocalEpisode Aggregate(LocalEpisode localEpisode, DownloadClientItem downloadClientItem, bool otherFiles)
|
||||
public LocalEpisode Aggregate(LocalEpisode localEpisode, DownloadClientItem downloadClientItem)
|
||||
{
|
||||
var source = QualitySource.Unknown;
|
||||
var sourceConfidence = Confidence.Default;
|
||||
|
@ -6,7 +6,7 @@ namespace NzbDrone.Core.MediaFiles.EpisodeImport.Aggregation.Aggregators
|
||||
{
|
||||
public class AggregateReleaseGroup : IAggregateLocalEpisode
|
||||
{
|
||||
public LocalEpisode Aggregate(LocalEpisode localEpisode, DownloadClientItem downloadClientItem, bool otherFiles)
|
||||
public LocalEpisode Aggregate(LocalEpisode localEpisode, DownloadClientItem downloadClientItem)
|
||||
{
|
||||
// Prefer ReleaseGroup from DownloadClient/Folder if they're not a season pack
|
||||
var releaseGroup = GetReleaseGroup(localEpisode.DownloadClientEpisodeInfo, true);
|
||||
|
@ -5,6 +5,6 @@ namespace NzbDrone.Core.MediaFiles.EpisodeImport.Aggregation.Aggregators
|
||||
{
|
||||
public interface IAggregateLocalEpisode
|
||||
{
|
||||
LocalEpisode Aggregate(LocalEpisode localEpisode, DownloadClientItem downloadClientItem, bool otherFiles);
|
||||
LocalEpisode Aggregate(LocalEpisode localEpisode, DownloadClientItem downloadClientItem);
|
||||
}
|
||||
}
|
||||
|
@ -82,7 +82,8 @@ public List<ImportDecision> GetImportDecisions(List<string> videoFiles, Series s
|
||||
FolderEpisodeInfo = folderInfo,
|
||||
Path = file,
|
||||
SceneSource = sceneSource,
|
||||
ExistingFile = series.Path.IsParentPath(file)
|
||||
ExistingFile = series.Path.IsParentPath(file),
|
||||
OtherVideoFiles = nonSampleVideoFileCount > 1
|
||||
};
|
||||
|
||||
decisions.AddIfNotNull(GetDecision(localEpisode, downloadClientItem, nonSampleVideoFileCount > 1));
|
||||
@ -110,7 +111,7 @@ private ImportDecision GetDecision(LocalEpisode localEpisode, DownloadClientItem
|
||||
|
||||
try
|
||||
{
|
||||
_aggregationService.Augment(localEpisode, downloadClientItem, otherFiles);
|
||||
_aggregationService.Augment(localEpisode, downloadClientItem);
|
||||
|
||||
if (localEpisode.Episodes.Empty())
|
||||
{
|
||||
|
@ -400,7 +400,7 @@ public void Execute(ManualImportCommand message)
|
||||
localEpisode.SceneSource = !existingFile;
|
||||
}
|
||||
|
||||
localEpisode = _aggregationService.Augment(localEpisode, trackedDownload?.DownloadItem, false);
|
||||
localEpisode = _aggregationService.Augment(localEpisode, trackedDownload?.DownloadItem);
|
||||
|
||||
// Apply the user-chosen values.
|
||||
localEpisode.Series = series;
|
||||
|
@ -9,9 +9,10 @@ public static class SceneNameCalculator
|
||||
{
|
||||
public static string GetSceneName(LocalEpisode localEpisode)
|
||||
{
|
||||
var otherVideoFiles = localEpisode.OtherVideoFiles;
|
||||
var downloadClientInfo = localEpisode.DownloadClientEpisodeInfo;
|
||||
|
||||
if (downloadClientInfo != null && !downloadClientInfo.FullSeason)
|
||||
if (!otherVideoFiles && downloadClientInfo != null && !downloadClientInfo.FullSeason)
|
||||
{
|
||||
return Parser.Parser.RemoveFileExtension(downloadClientInfo.ReleaseTitle);
|
||||
}
|
||||
|
@ -30,6 +30,7 @@ public LocalEpisode()
|
||||
public string ReleaseGroup { get; set; }
|
||||
public string SceneName { get; set; }
|
||||
public int PreferredWordScore { get; set; }
|
||||
public bool OtherVideoFiles { get; set; }
|
||||
|
||||
public int SeasonNumber
|
||||
{
|
||||
|
Loading…
Reference in New Issue
Block a user