commit
d67d89f54a
@ -0,0 +1,67 @@
|
|||||||
|
using System.Linq;
|
||||||
|
using FizzWare.NBuilder;
|
||||||
|
using FluentAssertions;
|
||||||
|
using Marr.Data;
|
||||||
|
using NUnit.Framework;
|
||||||
|
using NzbDrone.Core.MediaFiles;
|
||||||
|
using NzbDrone.Core.MediaFiles.EpisodeImport.Specifications;
|
||||||
|
using NzbDrone.Core.Parser.Model;
|
||||||
|
using NzbDrone.Core.Test.Framework;
|
||||||
|
using NzbDrone.Core.Tv;
|
||||||
|
|
||||||
|
namespace NzbDrone.Core.Test.MediaFiles.EpisodeImport.Specifications
|
||||||
|
{
|
||||||
|
[TestFixture]
|
||||||
|
public class SameFileSpecificationFixture : CoreTest<SameFileSpecification>
|
||||||
|
{
|
||||||
|
private LocalMovie _localMovie;
|
||||||
|
|
||||||
|
[SetUp]
|
||||||
|
public void Setup()
|
||||||
|
{
|
||||||
|
_localMovie = Builder<LocalMovie>.CreateNew()
|
||||||
|
.With(l => l.Size = 150.Megabytes())
|
||||||
|
.Build();
|
||||||
|
}
|
||||||
|
|
||||||
|
[Test]
|
||||||
|
public void should_be_accepted_if_no_existing_file()
|
||||||
|
{
|
||||||
|
_localMovie.Movie = Builder<Movie>.CreateNew()
|
||||||
|
.With(e => e.MovieFileId = 0)
|
||||||
|
.Build();
|
||||||
|
|
||||||
|
Subject.IsSatisfiedBy(_localMovie, null).Accepted.Should().BeTrue();
|
||||||
|
}
|
||||||
|
|
||||||
|
[Test]
|
||||||
|
public void should_be_accepted_if_file_size_is_different()
|
||||||
|
{
|
||||||
|
_localMovie.Movie = Builder<Movie>.CreateNew()
|
||||||
|
.With(e => e.MovieFileId = 1)
|
||||||
|
.With(e => e.MovieFile = new LazyLoaded<MovieFile>(
|
||||||
|
new MovieFile
|
||||||
|
{
|
||||||
|
Size = _localMovie.Size + 100.Megabytes()
|
||||||
|
}))
|
||||||
|
.Build();
|
||||||
|
|
||||||
|
Subject.IsSatisfiedBy(_localMovie, null).Accepted.Should().BeTrue();
|
||||||
|
}
|
||||||
|
|
||||||
|
[Test]
|
||||||
|
public void should_be_reject_if_file_size_is_the_same()
|
||||||
|
{
|
||||||
|
_localMovie.Movie = Builder<Movie>.CreateNew()
|
||||||
|
.With(e => e.MovieFileId = 1)
|
||||||
|
.With(e => e.MovieFile = new LazyLoaded<MovieFile>(
|
||||||
|
new MovieFile
|
||||||
|
{
|
||||||
|
Size = _localMovie.Size
|
||||||
|
}))
|
||||||
|
.Build();
|
||||||
|
|
||||||
|
Subject.IsSatisfiedBy(_localMovie, null).Accepted.Should().BeFalse();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,42 @@
|
|||||||
|
using System.Linq;
|
||||||
|
using NLog;
|
||||||
|
using NzbDrone.Core.DecisionEngine;
|
||||||
|
using NzbDrone.Core.Download;
|
||||||
|
using NzbDrone.Core.Parser.Model;
|
||||||
|
|
||||||
|
namespace NzbDrone.Core.MediaFiles.EpisodeImport.Specifications
|
||||||
|
{
|
||||||
|
public class SameFileSpecification : IImportDecisionEngineSpecification
|
||||||
|
{
|
||||||
|
private readonly Logger _logger;
|
||||||
|
|
||||||
|
public SameFileSpecification(Logger logger)
|
||||||
|
{
|
||||||
|
_logger = logger;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Decision IsSatisfiedBy(LocalEpisode localEpisode)
|
||||||
|
{
|
||||||
|
return Decision.Accept();
|
||||||
|
}
|
||||||
|
|
||||||
|
public Decision IsSatisfiedBy(LocalMovie localMovie, DownloadClientItem downloadClientItem)
|
||||||
|
{
|
||||||
|
var movieFile = localMovie.Movie.MovieFile;
|
||||||
|
|
||||||
|
if (localMovie.Movie.MovieFileId == 0)
|
||||||
|
{
|
||||||
|
_logger.Debug("No existing movie file, skipping");
|
||||||
|
return Decision.Accept();
|
||||||
|
}
|
||||||
|
|
||||||
|
if (movieFile.Size == localMovie.Size)
|
||||||
|
{
|
||||||
|
_logger.Debug("'{0}' Has the same filesize as existing file", localMovie.Path);
|
||||||
|
return Decision.Reject("Has the same filesize as existing file");
|
||||||
|
}
|
||||||
|
|
||||||
|
return Decision.Accept();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in new issue