mirror of https://github.com/Radarr/Radarr
Added tests for rename episodes
This commit is contained in:
parent
637b101975
commit
b6b3d26868
|
@ -0,0 +1,145 @@
|
||||||
|
using System;
|
||||||
|
using System.Collections.Generic;
|
||||||
|
using System.Linq;
|
||||||
|
using System.Text;
|
||||||
|
using FizzWare.NBuilder;
|
||||||
|
using Moq;
|
||||||
|
using NUnit.Framework;
|
||||||
|
using NzbDrone.Common.Messaging;
|
||||||
|
using NzbDrone.Core.MediaFiles;
|
||||||
|
using NzbDrone.Core.MediaFiles.Commands;
|
||||||
|
using NzbDrone.Core.MediaFiles.Events;
|
||||||
|
using NzbDrone.Core.Tv;
|
||||||
|
using NzbDrone.Core.Test.Framework;
|
||||||
|
|
||||||
|
namespace NzbDrone.Core.Test.MediaFileTests
|
||||||
|
{
|
||||||
|
public class RenameEpisodeFileServiceFixture : CoreTest<RenameEpisodeFileService>
|
||||||
|
{
|
||||||
|
private Series _series;
|
||||||
|
private List<EpisodeFile> _episodeFiles;
|
||||||
|
|
||||||
|
[SetUp]
|
||||||
|
public void Setup()
|
||||||
|
{
|
||||||
|
_series = Builder<Series>.CreateNew()
|
||||||
|
.Build();
|
||||||
|
|
||||||
|
_episodeFiles = Builder<EpisodeFile>.CreateListOfSize(2)
|
||||||
|
.All()
|
||||||
|
.With(e => e.SeriesId = _series.Id)
|
||||||
|
.With(e => e.SeasonNumber = 1)
|
||||||
|
.Build()
|
||||||
|
.ToList();
|
||||||
|
|
||||||
|
Mocker.GetMock<ISeriesService>()
|
||||||
|
.Setup(s => s.GetSeries(_series.Id))
|
||||||
|
.Returns(_series);
|
||||||
|
}
|
||||||
|
|
||||||
|
private void GivenNoEpisodeFiles()
|
||||||
|
{
|
||||||
|
Mocker.GetMock<IMediaFileService>()
|
||||||
|
.Setup(s => s.GetFilesBySeries(_series.Id))
|
||||||
|
.Returns(new List<EpisodeFile>());
|
||||||
|
|
||||||
|
Mocker.GetMock<IMediaFileService>()
|
||||||
|
.Setup(s => s.GetFilesBySeason(_series.Id, _episodeFiles.First().SeasonNumber))
|
||||||
|
.Returns(new List<EpisodeFile>());
|
||||||
|
}
|
||||||
|
|
||||||
|
private void GivenEpisodeFiles()
|
||||||
|
{
|
||||||
|
Mocker.GetMock<IMediaFileService>()
|
||||||
|
.Setup(s => s.GetFilesBySeries(_series.Id))
|
||||||
|
.Returns(_episodeFiles);
|
||||||
|
|
||||||
|
Mocker.GetMock<IMediaFileService>()
|
||||||
|
.Setup(s => s.GetFilesBySeason(_series.Id, _episodeFiles.First().SeasonNumber))
|
||||||
|
.Returns(_episodeFiles);
|
||||||
|
}
|
||||||
|
|
||||||
|
private void GivenMovedFiles()
|
||||||
|
{
|
||||||
|
Mocker.GetMock<IMoveEpisodeFiles>()
|
||||||
|
.Setup(s => s.MoveEpisodeFile(It.IsAny<EpisodeFile>(), _series))
|
||||||
|
.Returns(_episodeFiles.First());
|
||||||
|
}
|
||||||
|
|
||||||
|
[Test]
|
||||||
|
public void should_not_publish_event_if_no_files_to_rename()
|
||||||
|
{
|
||||||
|
GivenNoEpisodeFiles();
|
||||||
|
|
||||||
|
Subject.Execute(new RenameSeriesCommand(_series.Id));
|
||||||
|
|
||||||
|
Mocker.GetMock<IMessageAggregator>()
|
||||||
|
.Verify(v => v.PublishEvent(It.IsAny<SeriesRenamedEvent>()), Times.Never());
|
||||||
|
}
|
||||||
|
|
||||||
|
[Test]
|
||||||
|
public void should_not_publish_event_if_no_files_are_renamed()
|
||||||
|
{
|
||||||
|
GivenEpisodeFiles();
|
||||||
|
|
||||||
|
Subject.Execute(new RenameSeriesCommand(_series.Id));
|
||||||
|
|
||||||
|
Mocker.GetMock<IMessageAggregator>()
|
||||||
|
.Verify(v => v.PublishEvent(It.IsAny<SeriesRenamedEvent>()), Times.Never());
|
||||||
|
}
|
||||||
|
|
||||||
|
[Test]
|
||||||
|
public void should_publish_event_if_files_are_renamed()
|
||||||
|
{
|
||||||
|
GivenEpisodeFiles();
|
||||||
|
GivenMovedFiles();
|
||||||
|
|
||||||
|
Subject.Execute(new RenameSeriesCommand(_series.Id));
|
||||||
|
|
||||||
|
Mocker.GetMock<IMessageAggregator>()
|
||||||
|
.Verify(v => v.PublishEvent(It.IsAny<SeriesRenamedEvent>()), Times.Once());
|
||||||
|
}
|
||||||
|
|
||||||
|
[Test]
|
||||||
|
public void should_update_moved_files()
|
||||||
|
{
|
||||||
|
GivenEpisodeFiles();
|
||||||
|
GivenMovedFiles();
|
||||||
|
|
||||||
|
Subject.Execute(new RenameSeriesCommand(_series.Id));
|
||||||
|
|
||||||
|
Mocker.GetMock<IMediaFileService>()
|
||||||
|
.Verify(v => v.Update(It.IsAny<EpisodeFile>()), Times.Exactly(2));
|
||||||
|
}
|
||||||
|
|
||||||
|
[Test]
|
||||||
|
public void rename_season_should_get_episodefiles_for_season()
|
||||||
|
{
|
||||||
|
GivenEpisodeFiles();
|
||||||
|
GivenMovedFiles();
|
||||||
|
|
||||||
|
Subject.Execute(new RenameSeasonCommand(_series.Id, _episodeFiles.First().SeasonNumber));
|
||||||
|
|
||||||
|
Mocker.GetMock<IMediaFileService>()
|
||||||
|
.Verify(v => v.GetFilesBySeries(_series.Id), Times.Never());
|
||||||
|
|
||||||
|
Mocker.GetMock<IMediaFileService>()
|
||||||
|
.Verify(v => v.GetFilesBySeason(_series.Id, _episodeFiles.First().SeasonNumber), Times.Once());
|
||||||
|
}
|
||||||
|
|
||||||
|
[Test]
|
||||||
|
public void rename_series_should_get_episodefiles_for_series()
|
||||||
|
{
|
||||||
|
GivenEpisodeFiles();
|
||||||
|
GivenMovedFiles();
|
||||||
|
|
||||||
|
Subject.Execute(new RenameSeriesCommand(_series.Id));
|
||||||
|
|
||||||
|
Mocker.GetMock<IMediaFileService>()
|
||||||
|
.Verify(v => v.GetFilesBySeries(_series.Id), Times.Once());
|
||||||
|
|
||||||
|
Mocker.GetMock<IMediaFileService>()
|
||||||
|
.Verify(v => v.GetFilesBySeason(_series.Id, _episodeFiles.First().SeasonNumber), Times.Never());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -147,6 +147,7 @@
|
||||||
<Compile Include="JobTests\TestJobs.cs" />
|
<Compile Include="JobTests\TestJobs.cs" />
|
||||||
<Compile Include="MediaCoverTests\CoverExistsSpecificationFixture.cs" />
|
<Compile Include="MediaCoverTests\CoverExistsSpecificationFixture.cs" />
|
||||||
<Compile Include="MediaCoverTests\MediaCoverServiceFixture.cs" />
|
<Compile Include="MediaCoverTests\MediaCoverServiceFixture.cs" />
|
||||||
|
<Compile Include="MediaFileTests\RenameEpisodeFileServiceFixture.cs" />
|
||||||
<Compile Include="MediaFileTests\UpgradeMediaFileServiceFixture.cs" />
|
<Compile Include="MediaFileTests\UpgradeMediaFileServiceFixture.cs" />
|
||||||
<Compile Include="MediaFileTests\EpisodeImportTests\NotExistingFileSpecificationFixture.cs" />
|
<Compile Include="MediaFileTests\EpisodeImportTests\NotExistingFileSpecificationFixture.cs" />
|
||||||
<Compile Include="MediaFileTests\ImportApprovedEpisodesFixture.cs" />
|
<Compile Include="MediaFileTests\ImportApprovedEpisodesFixture.cs" />
|
||||||
|
|
|
@ -10,12 +10,7 @@ using NzbDrone.Core.Tv;
|
||||||
|
|
||||||
namespace NzbDrone.Core.MediaFiles
|
namespace NzbDrone.Core.MediaFiles
|
||||||
{
|
{
|
||||||
public interface IRenameEpisodeFiles
|
public class RenameEpisodeFileService : IExecute<RenameSeasonCommand>, IExecute<RenameSeriesCommand>
|
||||||
{
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
public class RenameEpisodeFileService : IRenameEpisodeFiles, IExecute<RenameSeasonCommand>, IExecute<RenameSeriesCommand>
|
|
||||||
{
|
{
|
||||||
private readonly ISeriesService _seriesService;
|
private readonly ISeriesService _seriesService;
|
||||||
private readonly IMediaFileService _mediaFileService;
|
private readonly IMediaFileService _mediaFileService;
|
||||||
|
|
Loading…
Reference in New Issue