From 0668f12e62deedc140533c4f153f44de9ffd301a Mon Sep 17 00:00:00 2001 From: Leonardo Galli Date: Tue, 7 Mar 2017 10:33:59 +0100 Subject: [PATCH] Fix error with weirdly formatted audioChannelPositions on MediaInfo. --- .../MediaInfo/VideoFileInfoReaderFixture.cs | 18 ++++++++ .../MediaFiles/MediaInfo/MediaInfoModel.cs | 42 +++++++++++-------- 2 files changed, 42 insertions(+), 18 deletions(-) diff --git a/src/NzbDrone.Core.Test/MediaFiles/MediaInfo/VideoFileInfoReaderFixture.cs b/src/NzbDrone.Core.Test/MediaFiles/MediaInfo/VideoFileInfoReaderFixture.cs index 5ccd1e4eb..617a4e41c 100644 --- a/src/NzbDrone.Core.Test/MediaFiles/MediaInfo/VideoFileInfoReaderFixture.cs +++ b/src/NzbDrone.Core.Test/MediaFiles/MediaInfo/VideoFileInfoReaderFixture.cs @@ -100,5 +100,23 @@ public void should_dispose_file_after_scanning_mediainfo() stream.Close(); } + + [Test] + [TestCase("/ Front: L R", 2.0)] + public void should_correctly_read_audio_channels(string ChannelPositions, decimal formattedChannels) + { + var info = new MediaInfoModel() + { + VideoCodec = "AVC", + AudioFormat = "DTS", + AudioLanguages = "English", + Subtitles = "English", + AudioChannels = 2, + AudioChannelPositions = ChannelPositions, + SchemaRevision = 3, + }; + + info.FormattedAudioChannels.Should().Be(formattedChannels); + } } } \ No newline at end of file diff --git a/src/NzbDrone.Core/MediaFiles/MediaInfo/MediaInfoModel.cs b/src/NzbDrone.Core/MediaFiles/MediaInfo/MediaInfoModel.cs index 371d43d35..8d8b0342e 100644 --- a/src/NzbDrone.Core/MediaFiles/MediaInfo/MediaInfoModel.cs +++ b/src/NzbDrone.Core/MediaFiles/MediaInfo/MediaInfoModel.cs @@ -34,27 +34,33 @@ public decimal FormattedAudioChannels { get { - if (AudioChannelPositions.IsNullOrWhiteSpace()) - { - if (AudioChannelPositionsText.IsNullOrWhiteSpace()) - { - if (SchemaRevision >= 3) - { - return AudioChannels; - } + try + { + return + AudioChannelPositions.Replace("Object Based /", "").Replace(" / ", "$") + .Split('$') + .First() + .Split('/') + .Sum(s => decimal.Parse(s, CultureInfo.InvariantCulture)); + } + catch + { - return 0; - } + if (AudioChannelPositionsText.IsNullOrWhiteSpace()) + { + if (SchemaRevision >= 3) + { + return AudioChannels; + } - return AudioChannelPositionsText.ContainsIgnoreCase("LFE") ? AudioChannels - 1 + 0.1m : AudioChannels; - } + return 0; + } + + return AudioChannelPositionsText.ContainsIgnoreCase("LFE") ? AudioChannels - 1 + 0.1m : AudioChannels; + + + } - return - AudioChannelPositions.Replace("Object Based /", "").Replace(" / ", "$") - .Split('$') - .First() - .Split('/') - .Sum(s => decimal.Parse(s, CultureInfo.InvariantCulture)); } } }