mirror of
https://github.com/Ombi-app/Ombi.git
synced 2025-08-20 13:23:20 -07:00
test: 🧪 added full test coverage to the plex availability checker, also fixed a small few bugs in there at the same time
This commit is contained in:
parent
28e248046a
commit
9fb8af7e09
7 changed files with 236 additions and 71 deletions
|
@ -11,10 +11,9 @@ using Ombi.Schedule.Jobs;
|
|||
using Ombi.Store.Entities;
|
||||
using Ombi.Store.Entities.Requests;
|
||||
using Ombi.Store.Repository.Requests;
|
||||
using System;
|
||||
using Ombi.Tests;
|
||||
using System.Collections.Generic;
|
||||
using System.Linq;
|
||||
using System.Text;
|
||||
using System.Threading.Tasks;
|
||||
|
||||
namespace Ombi.Schedule.Tests
|
||||
|
@ -29,14 +28,8 @@ namespace Ombi.Schedule.Tests
|
|||
public void SetUp()
|
||||
{
|
||||
_mocker = new AutoMocker();
|
||||
Mock<IHubClients> mockClients = new Mock<IHubClients>();
|
||||
Mock<IClientProxy> mockClientProxy = new Mock<IClientProxy>();
|
||||
mockClients.Setup(clients => clients.Clients(It.IsAny<IReadOnlyList<string>>())).Returns(mockClientProxy.Object);
|
||||
|
||||
var hubContext = new Mock<IHubContext<NotificationHub>>();
|
||||
hubContext.Setup(x => x.Clients).Returns(() => mockClients.Object);
|
||||
_mocker.Use(hubContext);
|
||||
|
||||
var hub = SignalRHelper.MockHub<NotificationHub>();
|
||||
_mocker.Use(hub);
|
||||
|
||||
_subject = _mocker.CreateInstance<TestAvailabilityChecker>();
|
||||
}
|
||||
|
|
|
@ -20,6 +20,7 @@
|
|||
<ItemGroup>
|
||||
<ProjectReference Include="..\Ombi.Schedule\Ombi.Schedule.csproj" />
|
||||
<ProjectReference Include="..\Ombi.Test.Common\Ombi.Test.Common.csproj" />
|
||||
<ProjectReference Include="..\Ombi.Tests\Ombi.Tests.csproj" />
|
||||
</ItemGroup>
|
||||
|
||||
</Project>
|
||||
|
|
|
@ -19,49 +19,140 @@ using Ombi.Store.Repository;
|
|||
using Ombi.Store.Repository.Requests;
|
||||
using Ombi.Helpers;
|
||||
using Ombi.Core.Services;
|
||||
using Ombi.Tests;
|
||||
using Moq.AutoMock;
|
||||
using Ombi.Settings.Settings.Models;
|
||||
using Ombi.Notifications.Models;
|
||||
|
||||
namespace Ombi.Schedule.Tests
|
||||
{
|
||||
[TestFixture]
|
||||
[Ignore("Need to work out how to mockout the hub context")]
|
||||
public class PlexAvailabilityCheckerTests
|
||||
{
|
||||
private AutoMocker _mocker;
|
||||
private PlexAvailabilityChecker _subject;
|
||||
|
||||
[SetUp]
|
||||
public void Setup()
|
||||
{
|
||||
_repo = new Mock<IPlexContentRepository>();
|
||||
_tv = new Mock<ITvRequestRepository>();
|
||||
_movie = new Mock<IMovieRequestRepository>();
|
||||
_notify = new Mock<INotificationHelper>();
|
||||
var hub = new Mock<IHubContext<NotificationHub>>();
|
||||
hub.Setup(x =>
|
||||
x.Clients.Clients(It.IsAny<IReadOnlyList<string>>()).SendCoreAsync(It.IsAny<string>(), It.IsAny<object[]>(), It.IsAny<CancellationToken>()));
|
||||
NotificationHub.UsersOnline.TryAdd("A", new HubUsers());
|
||||
Checker = new PlexAvailabilityChecker(_repo.Object, _tv.Object, _movie.Object, _notify.Object, null, hub.Object, Mock.Of<IFeatureService>());
|
||||
_mocker = new AutoMocker();
|
||||
|
||||
var hub = SignalRHelper.MockHub<NotificationHub>();
|
||||
_mocker.Use(hub);
|
||||
|
||||
_subject = _mocker.CreateInstance<PlexAvailabilityChecker>();
|
||||
}
|
||||
|
||||
|
||||
private Mock<IPlexContentRepository> _repo;
|
||||
private Mock<ITvRequestRepository> _tv;
|
||||
private Mock<IMovieRequestRepository> _movie;
|
||||
private Mock<INotificationHelper> _notify;
|
||||
private PlexAvailabilityChecker Checker;
|
||||
|
||||
[Test]
|
||||
public async Task ProcessMovies_ShouldMarkAvailable_WhenInPlex()
|
||||
public async Task ProcessMovies_ShouldMarkAvailable_WhenInPlex_WithImdbId()
|
||||
{
|
||||
var request = new MovieRequests
|
||||
{
|
||||
ImdbId = "test"
|
||||
};
|
||||
_movie.Setup(x => x.GetAll()).Returns(new List<MovieRequests> { request }.AsQueryable());
|
||||
_repo.Setup(x => x.Get("test", ProviderType.ImdbId)).ReturnsAsync(new PlexServerContent());
|
||||
_mocker.Setup<IMovieRequestRepository>(x => x.GetAll()).Returns(new List<MovieRequests> { request }.AsQueryable());
|
||||
_mocker.Setup<IPlexContentRepository, Task<PlexServerContent>>(x => x.Get("test", ProviderType.ImdbId)).ReturnsAsync(new PlexServerContent());
|
||||
|
||||
await Checker.Execute(null);
|
||||
await _subject.Execute(null);
|
||||
|
||||
_movie.Verify(x => x.Save(), Times.Once);
|
||||
Assert.Multiple(() =>
|
||||
{
|
||||
Assert.That(request.Available, Is.True);
|
||||
Assert.That(request.MarkedAsAvailable, Is.Not.Null);
|
||||
Assert.That(request.Available4K, Is.False);
|
||||
Assert.That(request.MarkedAsAvailable4K, Is.Null);
|
||||
});
|
||||
|
||||
Assert.True(request.Available);
|
||||
_mocker.Verify<IMovieRequestRepository>(x => x.SaveChangesAsync(), Times.Once);
|
||||
_mocker.Verify<IPlexContentRepository>(x => x.Get("test", ProviderType.ImdbId), Times.Once);
|
||||
_mocker.Verify<IPlexContentRepository>(x => x.Get(It.IsAny<string>(), ProviderType.TheMovieDbId), Times.Never);
|
||||
_mocker.Verify<INotificationHelper>(x => x.Notify(It.Is<NotificationOptions>(x => x.NotificationType == NotificationType.RequestAvailable)), Times.Once);
|
||||
}
|
||||
|
||||
[Test]
|
||||
public async Task ProcessMovies_ShouldMarkAvailable_WhenInPlex_WithTheMovieDbId()
|
||||
{
|
||||
var request = new MovieRequests
|
||||
{
|
||||
ImdbId = null,
|
||||
TheMovieDbId = 33
|
||||
};
|
||||
_mocker.Setup<IMovieRequestRepository>(x => x.GetAll()).Returns(new List<MovieRequests> { request }.AsQueryable());
|
||||
_mocker.Setup<IPlexContentRepository, Task<PlexServerContent>>(x => x.Get(It.IsAny<string>(), ProviderType.ImdbId)).ReturnsAsync((PlexServerContent)null);
|
||||
_mocker.Setup<IPlexContentRepository, Task<PlexServerContent>>(x => x.Get("33", ProviderType.TheMovieDbId)).ReturnsAsync(new PlexServerContent());
|
||||
|
||||
await _subject.Execute(null);
|
||||
|
||||
Assert.Multiple(() =>
|
||||
{
|
||||
Assert.That(request.Available, Is.True);
|
||||
Assert.That(request.MarkedAsAvailable, Is.Not.Null);
|
||||
Assert.That(request.Available4K, Is.False);
|
||||
Assert.That(request.MarkedAsAvailable4K, Is.Null);
|
||||
});
|
||||
|
||||
_mocker.Verify<IMovieRequestRepository>(x => x.SaveChangesAsync(), Times.Once);
|
||||
_mocker.Verify<IPlexContentRepository>(x => x.Get(It.IsAny<string>(), ProviderType.ImdbId), Times.Never);
|
||||
_mocker.Verify<IPlexContentRepository>(x => x.Get(It.IsAny<string>(), ProviderType.TheMovieDbId), Times.Once);
|
||||
_mocker.Verify<INotificationHelper>(x => x.Notify(It.Is<NotificationOptions>(x => x.NotificationType == NotificationType.RequestAvailable)), Times.Once);
|
||||
}
|
||||
|
||||
[Test]
|
||||
public async Task ProcessMovies_ShouldMarkAvailable_WhenInPlex_WithTheMovieDbId_4K_Enabled ()
|
||||
{
|
||||
_mocker.Setup<IFeatureService, Task<bool>>(x => x.FeatureEnabled(FeatureNames.Movie4KRequests)).ReturnsAsync(true);
|
||||
var request = new MovieRequests
|
||||
{
|
||||
ImdbId = "test"
|
||||
};
|
||||
_mocker.Setup<IMovieRequestRepository>(x => x.GetAll()).Returns(new List<MovieRequests> { request }.AsQueryable());
|
||||
_mocker.Setup<IPlexContentRepository, Task<PlexServerContent>>(x => x.Get("test", ProviderType.ImdbId)).ReturnsAsync(new PlexServerContent { Quality = "1080p" });
|
||||
|
||||
await _subject.Execute(null);
|
||||
|
||||
Assert.Multiple(() =>
|
||||
{
|
||||
Assert.That(request.Available, Is.True);
|
||||
Assert.That(request.MarkedAsAvailable, Is.Not.Null);
|
||||
Assert.That(request.Available4K, Is.False);
|
||||
Assert.That(request.MarkedAsAvailable4K, Is.Null);
|
||||
});
|
||||
|
||||
_mocker.Verify<IMovieRequestRepository>(x => x.SaveChangesAsync(), Times.Once);
|
||||
_mocker.Verify<IPlexContentRepository>(x => x.Get("test", ProviderType.ImdbId), Times.Once);
|
||||
_mocker.Verify<IPlexContentRepository>(x => x.Get(It.IsAny<string>(), ProviderType.TheMovieDbId), Times.Never);
|
||||
_mocker.Verify<INotificationHelper>(x => x.Notify(It.Is<NotificationOptions>(x => x.NotificationType == NotificationType.RequestAvailable)), Times.Once);
|
||||
}
|
||||
|
||||
[Test]
|
||||
public async Task ProcessMovies_4K_ShouldMarkAvailable_WhenInPlex_WithImdbId_And_4K_FeatureEnabled()
|
||||
{
|
||||
_mocker.Setup<IFeatureService, Task<bool>>(x => x.FeatureEnabled(FeatureNames.Movie4KRequests)).ReturnsAsync(true);
|
||||
var request = new MovieRequests
|
||||
{
|
||||
ImdbId = "test",
|
||||
Is4kRequest = true,
|
||||
Has4KRequest = true,
|
||||
};
|
||||
_mocker.Setup<IMovieRequestRepository>(x => x.GetAll()).Returns(new List<MovieRequests> { request }.AsQueryable());
|
||||
_mocker.Setup<IPlexContentRepository, Task<PlexServerContent>>(x => x.Get("test", ProviderType.ImdbId)).ReturnsAsync(new PlexServerContent { Has4K = true });
|
||||
|
||||
await _subject.Execute(null);
|
||||
|
||||
_mocker.Verify<IMovieRequestRepository>(x => x.SaveChangesAsync(), Times.Once);
|
||||
|
||||
Assert.Multiple(() =>
|
||||
{
|
||||
Assert.That(request.Available, Is.False);
|
||||
Assert.That(request.MarkedAsAvailable, Is.Null);
|
||||
Assert.That(request.Available4K, Is.True);
|
||||
Assert.That(request.MarkedAsAvailable4K, Is.Not.Null);
|
||||
});
|
||||
|
||||
_mocker.Verify<IMovieRequestRepository>(x => x.SaveChangesAsync(), Times.Once);
|
||||
_mocker.Verify<IPlexContentRepository>(x => x.Get("test", ProviderType.ImdbId), Times.Once);
|
||||
_mocker.Verify<IPlexContentRepository>(x => x.Get(It.IsAny<string>(), ProviderType.TheMovieDbId), Times.Never);
|
||||
_mocker.Verify<INotificationHelper>(x => x.Notify(It.Is<NotificationOptions>(x => x.NotificationType == NotificationType.RequestAvailable)), Times.Once);
|
||||
}
|
||||
|
||||
[Test]
|
||||
|
@ -71,19 +162,96 @@ namespace Ombi.Schedule.Tests
|
|||
{
|
||||
ImdbId = "test"
|
||||
};
|
||||
_movie.Setup(x => x.GetAll()).Returns(new List<MovieRequests> { request }.AsQueryable());
|
||||
_mocker.Setup<IMovieRequestRepository>(x => x.GetAll()).Returns(new List<MovieRequests> { request }.AsQueryable());
|
||||
|
||||
await Checker.Execute(null);
|
||||
await _subject.Execute(null);
|
||||
|
||||
Assert.False(request.Available);
|
||||
}
|
||||
|
||||
[Test]
|
||||
public async Task ProcessTv_ShouldMark_Episode_Available_WhenInPlex()
|
||||
public async Task ProcessTv_ShouldMark_Episode_Available_WhenInPlex_MovieDbId()
|
||||
{
|
||||
var request = new ChildRequests
|
||||
var request = CreateChildRequest(null, 33, 99);
|
||||
_mocker.Setup<ITvRequestRepository>(x => x.GetChild()).Returns(new List<ChildRequests> { request }.AsQueryable().BuildMock().Object);
|
||||
_mocker.Setup<IPlexContentRepository, IQueryable<IMediaServerEpisode>>(x => x.GetAllEpisodes()).Returns(new List<PlexEpisode>
|
||||
{
|
||||
ParentRequest = new TvRequests { TvDbId = 1 },
|
||||
new PlexEpisode
|
||||
{
|
||||
Series = new PlexServerContent
|
||||
{
|
||||
TheMovieDbId = 33.ToString(),
|
||||
Title = "Test"
|
||||
},
|
||||
EpisodeNumber = 1,
|
||||
SeasonNumber = 2,
|
||||
}
|
||||
}.AsQueryable().BuildMock().Object);
|
||||
|
||||
await _subject.Execute(null);
|
||||
|
||||
_mocker.Verify<ITvRequestRepository>(x => x.Save(), Times.AtLeastOnce);
|
||||
|
||||
Assert.True(request.SeasonRequests[0].Episodes[0].Available);
|
||||
}
|
||||
|
||||
[Test]
|
||||
public async Task ProcessTv_ShouldMark_Episode_Available_WhenInPlex_ImdbId()
|
||||
{
|
||||
var request = CreateChildRequest("abc", -1, 99);
|
||||
_mocker.Setup<ITvRequestRepository>(x => x.GetChild()).Returns(new List<ChildRequests> { request }.AsQueryable().BuildMock().Object);
|
||||
_mocker.Setup<IPlexContentRepository, IQueryable<IMediaServerEpisode>>(x => x.GetAllEpisodes()).Returns(new List<PlexEpisode>
|
||||
{
|
||||
new PlexEpisode
|
||||
{
|
||||
Series = new PlexServerContent
|
||||
{
|
||||
ImdbId = "abc",
|
||||
},
|
||||
EpisodeNumber = 1,
|
||||
SeasonNumber = 2,
|
||||
}
|
||||
}.AsQueryable().BuildMock().Object);
|
||||
|
||||
await _subject.Execute(null);
|
||||
|
||||
_mocker.Verify<ITvRequestRepository>(x => x.Save(), Times.AtLeastOnce);
|
||||
|
||||
Assert.True(request.SeasonRequests[0].Episodes[0].Available);
|
||||
}
|
||||
|
||||
[Test]
|
||||
public async Task ProcessTv_ShouldMark_Episode_Available_By_TitleMatch()
|
||||
{
|
||||
var request = CreateChildRequest("abc", -1, 99);
|
||||
_mocker.Setup<ITvRequestRepository>(x => x.GetChild()).Returns(new List<ChildRequests> { request }.AsQueryable().BuildMock().Object);
|
||||
_mocker.Setup<IPlexContentRepository, IQueryable<IMediaServerEpisode>>(x => x.GetAllEpisodes()).Returns(new List<PlexEpisode>
|
||||
{
|
||||
new PlexEpisode
|
||||
{
|
||||
Series = new PlexServerContent
|
||||
{
|
||||
Title = "UNITTEST",
|
||||
ImdbId = "invlaid",
|
||||
},
|
||||
EpisodeNumber = 1,
|
||||
SeasonNumber = 2,
|
||||
}
|
||||
}.AsQueryable().BuildMock().Object);
|
||||
|
||||
await _subject.Execute(null);
|
||||
|
||||
_mocker.Verify<ITvRequestRepository>(x => x.Save(), Times.AtLeastOnce);
|
||||
|
||||
Assert.True(request.SeasonRequests[0].Episodes[0].Available);
|
||||
}
|
||||
|
||||
private ChildRequests CreateChildRequest(string imdbId, int theMovieDbId, int tvdbId)
|
||||
{
|
||||
return new ChildRequests
|
||||
{
|
||||
Title = "UnitTest",
|
||||
ParentRequest = new TvRequests { ImdbId = imdbId, ExternalProviderId = theMovieDbId, TvDbId = tvdbId },
|
||||
SeasonRequests = new EditableList<SeasonRequests>
|
||||
{
|
||||
new SeasonRequests
|
||||
|
@ -93,7 +261,7 @@ namespace Ombi.Schedule.Tests
|
|||
new EpisodeRequests
|
||||
{
|
||||
EpisodeNumber = 1,
|
||||
Season = new SeasonRequests
|
||||
Season = new SeasonRequests
|
||||
{
|
||||
SeasonNumber = 2
|
||||
}
|
||||
|
@ -106,27 +274,6 @@ namespace Ombi.Schedule.Tests
|
|||
Email = "abc"
|
||||
}
|
||||
};
|
||||
_tv.Setup(x => x.GetChild()).Returns(new List<ChildRequests> { request }.AsQueryable().BuildMock().Object);
|
||||
_repo.Setup(x => x.GetAllEpisodes()).Returns(new List<PlexEpisode>
|
||||
{
|
||||
new PlexEpisode
|
||||
{
|
||||
Series = new PlexServerContent
|
||||
{
|
||||
TvDbId = 1.ToString(),
|
||||
},
|
||||
EpisodeNumber = 1,
|
||||
SeasonNumber = 2
|
||||
}
|
||||
}.AsQueryable().BuildMock().Object);
|
||||
_repo.Setup(x => x.Include(It.IsAny<IQueryable<PlexEpisode>>(),It.IsAny<Expression<Func<PlexEpisode, PlexServerContent>>>()));
|
||||
|
||||
await Checker.Execute(null);
|
||||
|
||||
_tv.Verify(x => x.Save(), Times.Once);
|
||||
|
||||
Assert.True(request.SeasonRequests[0].Episodes[0].Available);
|
||||
|
||||
}
|
||||
}
|
||||
}
|
|
@ -38,7 +38,6 @@ namespace Ombi.Schedule.Jobs.Plex
|
|||
{
|
||||
try
|
||||
{
|
||||
|
||||
await _hub.Clients.Clients(NotificationHub.AdminConnectionIds)
|
||||
.SendAsync(NotificationHub.NotificationEvent, "Plex Availability Check Started");
|
||||
await ProcessMovies();
|
||||
|
@ -70,16 +69,22 @@ namespace Ombi.Schedule.Jobs.Plex
|
|||
{
|
||||
var useImdb = false;
|
||||
var useTvDb = false;
|
||||
var useMovieDb = false;
|
||||
if (child.ParentRequest.ImdbId.HasValue())
|
||||
{
|
||||
useImdb = true;
|
||||
}
|
||||
|
||||
if (child.ParentRequest.TvDbId.ToString().HasValue())
|
||||
if (child.ParentRequest.TvDbId > 0)
|
||||
{
|
||||
useTvDb = true;
|
||||
}
|
||||
|
||||
if (child.ParentRequest.ExternalProviderId > 0)
|
||||
{
|
||||
useMovieDb = true;
|
||||
}
|
||||
|
||||
var tvDbId = child.ParentRequest.TvDbId;
|
||||
var imdbId = child.ParentRequest.ImdbId;
|
||||
IQueryable<IMediaServerEpisode> seriesEpisodes = null;
|
||||
|
@ -91,18 +96,16 @@ namespace Ombi.Schedule.Jobs.Plex
|
|||
{
|
||||
seriesEpisodes = plexEpisodes.Where(x => x.Series.TvDbId == tvDbId.ToString());
|
||||
}
|
||||
|
||||
if (seriesEpisodes == null)
|
||||
if (useMovieDb && (seriesEpisodes == null || !seriesEpisodes.Any()))
|
||||
{
|
||||
continue;
|
||||
seriesEpisodes = plexEpisodes.Where(x => x.Series.TheMovieDbId == child.ParentRequest.ExternalProviderId.ToString());
|
||||
}
|
||||
|
||||
if (!seriesEpisodes.Any())
|
||||
if (seriesEpisodes == null || !seriesEpisodes.Any())
|
||||
{
|
||||
// Let's try and match the series by name
|
||||
seriesEpisodes = plexEpisodes.Where(x =>
|
||||
x.Series.Title == child.Title);
|
||||
|
||||
x.Series.Title.Equals(child.Title, StringComparison.InvariantCultureIgnoreCase));
|
||||
}
|
||||
|
||||
await ProcessTvShow(seriesEpisodes, child);
|
||||
|
|
|
@ -4,7 +4,7 @@ using System.ComponentModel.DataAnnotations.Schema;
|
|||
|
||||
namespace Ombi.Store.Entities
|
||||
{
|
||||
public interface IMediaServerContent: IEntity
|
||||
public interface IMediaServerContent : IEntity
|
||||
{
|
||||
public string Title { get; set; }
|
||||
public string ImdbId { get; set; }
|
||||
|
@ -29,7 +29,7 @@ namespace Ombi.Store.Entities
|
|||
public bool HasTheMovieDb => !string.IsNullOrEmpty(TheMovieDbId);
|
||||
}
|
||||
|
||||
public interface IMediaServerEpisode: IBaseMediaServerEpisode
|
||||
public interface IMediaServerEpisode : IBaseMediaServerEpisode
|
||||
{
|
||||
public string Title { get; set; }
|
||||
/// <summary>
|
||||
|
|
|
@ -36,7 +36,7 @@ namespace Ombi.Store.Entities
|
|||
public abstract RecentlyAddedType RecentlyAddedType { get; }
|
||||
}
|
||||
|
||||
public abstract class MediaServerEpisode: Entity, IMediaServerEpisode
|
||||
public abstract class MediaServerEpisode : Entity, IMediaServerEpisode
|
||||
{
|
||||
public int EpisodeNumber { get; set; }
|
||||
public int SeasonNumber { get; set; }
|
||||
|
|
21
src/Ombi.Tests/SignalRHelper.cs
Normal file
21
src/Ombi.Tests/SignalRHelper.cs
Normal file
|
@ -0,0 +1,21 @@
|
|||
using Microsoft.AspNetCore.SignalR;
|
||||
using Moq;
|
||||
using System.Collections.Generic;
|
||||
|
||||
namespace Ombi.Tests
|
||||
{
|
||||
public class SignalRHelper
|
||||
{
|
||||
public static Mock<IHubContext<T>> MockHub<T>() where T : Hub
|
||||
{
|
||||
Mock<IHubClients> mockClients = new Mock<IHubClients>();
|
||||
Mock<IClientProxy> mockClientProxy = new Mock<IClientProxy>();
|
||||
mockClients.Setup(clients => clients.Clients(It.IsAny<IReadOnlyList<string>>())).Returns(mockClientProxy.Object);
|
||||
|
||||
var hubContext = new Mock<IHubContext<T>>();
|
||||
hubContext.Setup(x => x.Clients).Returns(() => mockClients.Object);
|
||||
|
||||
return hubContext;
|
||||
}
|
||||
}
|
||||
}
|
Loading…
Add table
Add a link
Reference in a new issue