mirror of
https://github.com/Ombi-app/Ombi.git
synced 2025-08-21 05:43:19 -07:00
test: ✅ Added some unit tests around the new code in the Plex Sync
This commit is contained in:
parent
7c5646d416
commit
98f655e92e
3 changed files with 250 additions and 95 deletions
|
@ -7,12 +7,13 @@
|
||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
<PackageReference Include="Microsoft.AspNetCore" Version="2.2.0" />
|
<PackageReference Include="Microsoft.AspNetCore" Version="2.2.0" />
|
||||||
<PackageReference Include="MockQueryable.Moq" Version="5.0.0-preview.7" />
|
<PackageReference Include="MockQueryable.Moq" Version="5.0.0-preview.7" />
|
||||||
<PackageReference Include="Moq" Version="4.10.0" />
|
<PackageReference Include="Moq" Version="4.15.1" />
|
||||||
|
<PackageReference Include="Moq.AutoMock" Version="0.4.0" />
|
||||||
<PackageReference Include="Nunit" Version="3.11.0" />
|
<PackageReference Include="Nunit" Version="3.11.0" />
|
||||||
<PackageReference Include="Microsoft.Bcl.AsyncInterfaces" Version="5.0.0" />
|
<PackageReference Include="Microsoft.Bcl.AsyncInterfaces" Version="5.0.0" />
|
||||||
<PackageReference Include="NUnit.ConsoleRunner" Version="3.9.0" />
|
<PackageReference Include="NUnit.ConsoleRunner" Version="3.9.0" />
|
||||||
<PackageReference Include="NUnit3TestAdapter" Version="3.13.0" />
|
<PackageReference Include="NUnit3TestAdapter" Version="3.13.0" />
|
||||||
<packagereference Include="Microsoft.NET.Test.Sdk" Version="16.8.0"></packagereference>
|
<packagereference Include="Microsoft.NET.Test.Sdk" Version="16.11.0"></packagereference>
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
|
|
||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
|
|
144
src/Ombi.Schedule.Tests/PlexContentSyncTests.cs
Normal file
144
src/Ombi.Schedule.Tests/PlexContentSyncTests.cs
Normal file
|
@ -0,0 +1,144 @@
|
||||||
|
using System;
|
||||||
|
using System.Collections.Generic;
|
||||||
|
using System.Linq;
|
||||||
|
using System.Linq.Expressions;
|
||||||
|
using System.Text;
|
||||||
|
using System.Threading.Tasks;
|
||||||
|
using Microsoft.Extensions.Logging;
|
||||||
|
using Moq;
|
||||||
|
using Moq.AutoMock;
|
||||||
|
using NUnit.Framework;
|
||||||
|
using Ombi.Api.Plex;
|
||||||
|
using Ombi.Api.Plex.Models;
|
||||||
|
using Ombi.Core.Settings.Models.External;
|
||||||
|
using Ombi.Schedule.Jobs.Plex;
|
||||||
|
using Ombi.Store.Entities;
|
||||||
|
using Ombi.Store.Repository;
|
||||||
|
|
||||||
|
namespace Ombi.Schedule.Tests
|
||||||
|
{
|
||||||
|
[TestFixture]
|
||||||
|
public class PlexContentSyncTests
|
||||||
|
{
|
||||||
|
|
||||||
|
private AutoMocker _mocker;
|
||||||
|
private PlexContentSync _subject;
|
||||||
|
|
||||||
|
[SetUp]
|
||||||
|
public void Setup()
|
||||||
|
{
|
||||||
|
_mocker = new AutoMocker();
|
||||||
|
_subject = _mocker.CreateInstance<PlexContentSync>();
|
||||||
|
}
|
||||||
|
|
||||||
|
[Test]
|
||||||
|
public async Task DoesNotSyncExistingMovie()
|
||||||
|
{
|
||||||
|
var content = new Mediacontainer
|
||||||
|
{
|
||||||
|
Metadata = new[]
|
||||||
|
{
|
||||||
|
new Metadata
|
||||||
|
{
|
||||||
|
title = "test1",
|
||||||
|
year = 2021,
|
||||||
|
type = "movie"
|
||||||
|
},
|
||||||
|
}
|
||||||
|
};
|
||||||
|
var contentToAdd = new HashSet<PlexServerContent>();
|
||||||
|
var contentProcessed = new Dictionary<int, int>();
|
||||||
|
_mocker.Setup<IPlexContentRepository>(x =>
|
||||||
|
x.GetFirstContentByCustom(It.IsAny<Expression<Func<PlexServerContent, bool>>>()))
|
||||||
|
.Returns(Task.FromResult(new PlexServerContent()));
|
||||||
|
|
||||||
|
await _subject.MovieLoop(new PlexServers(), content, contentToAdd, contentProcessed);
|
||||||
|
|
||||||
|
Assert.That(contentToAdd, Is.Empty);
|
||||||
|
}
|
||||||
|
|
||||||
|
[Test]
|
||||||
|
public async Task SyncsMovieWithGuidFromInitalMetadata()
|
||||||
|
{
|
||||||
|
var content = new Mediacontainer
|
||||||
|
{
|
||||||
|
Metadata = new[]
|
||||||
|
{
|
||||||
|
new Metadata
|
||||||
|
{
|
||||||
|
title = "test1",
|
||||||
|
year = 2021,
|
||||||
|
type = "movie",
|
||||||
|
Guid = new List<PlexGuids>
|
||||||
|
{
|
||||||
|
new PlexGuids
|
||||||
|
{
|
||||||
|
Id = "imdb://tt0322259"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
ratingKey = 1
|
||||||
|
},
|
||||||
|
}
|
||||||
|
};
|
||||||
|
var contentToAdd = new HashSet<PlexServerContent>();
|
||||||
|
var contentProcessed = new Dictionary<int, int>();
|
||||||
|
|
||||||
|
await _subject.MovieLoop(new PlexServers(), content, contentToAdd, contentProcessed);
|
||||||
|
|
||||||
|
var first = contentToAdd.First();
|
||||||
|
Assert.That(first.ImdbId, Is.EqualTo("tt0322259"));
|
||||||
|
_mocker.Verify<IPlexApi>(x => x.GetMetadata(It.IsAny<string>(), It.IsAny<string>(),It.IsAny<int>()), Times.Never);
|
||||||
|
}
|
||||||
|
|
||||||
|
[Test]
|
||||||
|
public async Task SyncsMovieWithGuidFromCallToApi()
|
||||||
|
{
|
||||||
|
var content = new Mediacontainer
|
||||||
|
{
|
||||||
|
Metadata = new[]
|
||||||
|
{
|
||||||
|
new Metadata
|
||||||
|
{
|
||||||
|
ratingKey = 11,
|
||||||
|
title = "test1",
|
||||||
|
year = 2021,
|
||||||
|
type = "movie",
|
||||||
|
},
|
||||||
|
}
|
||||||
|
};
|
||||||
|
var contentToAdd = new HashSet<PlexServerContent>();
|
||||||
|
var contentProcessed = new Dictionary<int, int>();
|
||||||
|
_mocker.Setup<IPlexApi>(x => x.GetMetadata(It.IsAny<string>(), It.IsAny<string>(), It.IsAny<int>()))
|
||||||
|
.Returns(Task.FromResult(new PlexMetadata
|
||||||
|
{
|
||||||
|
MediaContainer = new Mediacontainer
|
||||||
|
{
|
||||||
|
Metadata = new[]
|
||||||
|
{
|
||||||
|
new Metadata
|
||||||
|
{
|
||||||
|
ratingKey = 11,
|
||||||
|
title = "test1",
|
||||||
|
year = 2021,
|
||||||
|
type = "movie",
|
||||||
|
Guid = new List<PlexGuids>
|
||||||
|
{
|
||||||
|
new PlexGuids
|
||||||
|
{
|
||||||
|
Id = "imdb://tt0322259"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}));
|
||||||
|
|
||||||
|
await _subject.MovieLoop(new PlexServers { Ip = "http://test.com/", Port = 80}, content, contentToAdd, contentProcessed);
|
||||||
|
|
||||||
|
var first = contentToAdd.First();
|
||||||
|
Assert.That(first.ImdbId, Is.EqualTo("tt0322259"));
|
||||||
|
|
||||||
|
_mocker.Verify<IPlexApi>(x => x.GetMetadata(It.IsAny<string>(), It.IsAny<string>(), It.IsAny<int>()), Times.Once);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -262,99 +262,7 @@ namespace Ombi.Schedule.Jobs.Plex
|
||||||
}
|
}
|
||||||
if (content.viewGroup.Equals(PlexMediaType.Movie.ToString(), StringComparison.InvariantCultureIgnoreCase))
|
if (content.viewGroup.Equals(PlexMediaType.Movie.ToString(), StringComparison.InvariantCultureIgnoreCase))
|
||||||
{
|
{
|
||||||
Logger.LogDebug("Processing Movies");
|
await MovieLoop(servers, content, contentToAdd, contentProcessed);
|
||||||
foreach (var movie in content?.Metadata ?? new Metadata[] { })
|
|
||||||
{
|
|
||||||
// Let's check if we have this movie
|
|
||||||
|
|
||||||
try
|
|
||||||
{
|
|
||||||
var existing = await Repo.GetFirstContentByCustom(x => x.Title == movie.title
|
|
||||||
&& x.ReleaseYear == movie.year.ToString()
|
|
||||||
&& x.Type == PlexMediaTypeEntity.Movie);
|
|
||||||
// The rating key keeps changing
|
|
||||||
//var existing = await Repo.GetByKey(movie.ratingKey);
|
|
||||||
if (existing != null)
|
|
||||||
{
|
|
||||||
Logger.LogDebug("We already have movie {0}", movie.title);
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
|
|
||||||
var hasSameKey = await Repo.GetByKey(movie.ratingKey);
|
|
||||||
if (hasSameKey != null)
|
|
||||||
{
|
|
||||||
await Repo.Delete(hasSameKey);
|
|
||||||
}
|
|
||||||
|
|
||||||
Logger.LogDebug("Adding movie {0}", movie.title);
|
|
||||||
var guids = new List<string>();
|
|
||||||
if (!movie.Guid.Any())
|
|
||||||
{
|
|
||||||
var metaData = await PlexApi.GetMetadata(servers.PlexAuthToken, servers.FullUri,
|
|
||||||
movie.ratingKey);
|
|
||||||
|
|
||||||
var meta = metaData.MediaContainer.Metadata.FirstOrDefault();
|
|
||||||
guids.Add(meta.guid);
|
|
||||||
if (meta.Guid != null)
|
|
||||||
{
|
|
||||||
foreach (var g in meta.Guid)
|
|
||||||
{
|
|
||||||
guids.Add(g.Id);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
// Currently a Plex Pass feature only
|
|
||||||
foreach (var g in movie.Guid)
|
|
||||||
{
|
|
||||||
guids.Add(g.Id);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
var providerIds = PlexHelper.GetProviderIdsFromMetadata(guids.ToArray());
|
|
||||||
|
|
||||||
var item = new PlexServerContent
|
|
||||||
{
|
|
||||||
AddedAt = DateTime.Now,
|
|
||||||
Key = movie.ratingKey,
|
|
||||||
ReleaseYear = movie.year.ToString(),
|
|
||||||
Type = PlexMediaTypeEntity.Movie,
|
|
||||||
Title = movie.title,
|
|
||||||
Url = PlexHelper.GetPlexMediaUrl(servers.MachineIdentifier, movie.ratingKey),
|
|
||||||
Seasons = new List<PlexSeasonsContent>(),
|
|
||||||
Quality = movie.Media?.FirstOrDefault()?.videoResolution ?? string.Empty
|
|
||||||
};
|
|
||||||
if (providerIds.ImdbId.HasValue())
|
|
||||||
{
|
|
||||||
item.ImdbId = providerIds.ImdbId;
|
|
||||||
}
|
|
||||||
if (providerIds.TheMovieDb.HasValue())
|
|
||||||
{
|
|
||||||
item.TheMovieDbId = providerIds.TheMovieDb;
|
|
||||||
}
|
|
||||||
if (providerIds.TheTvDb.HasValue())
|
|
||||||
{
|
|
||||||
item.TvDbId = providerIds.TheTvDb;
|
|
||||||
}
|
|
||||||
contentToAdd.Add(item);
|
|
||||||
}
|
|
||||||
catch (Exception e)
|
|
||||||
{
|
|
||||||
Logger.LogError(LoggingEvents.PlexContentCacher, e, "Exception when adding new Movie {0}",
|
|
||||||
movie.title);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (contentToAdd.Count > 500)
|
|
||||||
{
|
|
||||||
await Repo.AddRange(contentToAdd);
|
|
||||||
foreach (var c in contentToAdd)
|
|
||||||
{
|
|
||||||
contentProcessed.Add(c.Id, c.Key);
|
|
||||||
}
|
|
||||||
contentToAdd.Clear();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
if (contentToAdd.Count > 500)
|
if (contentToAdd.Count > 500)
|
||||||
{
|
{
|
||||||
|
@ -381,6 +289,108 @@ namespace Ombi.Schedule.Jobs.Plex
|
||||||
return retVal;
|
return retVal;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public async Task MovieLoop(PlexServers servers, Mediacontainer content, HashSet<PlexServerContent> contentToAdd,
|
||||||
|
Dictionary<int, int> contentProcessed)
|
||||||
|
{
|
||||||
|
Logger.LogDebug("Processing Movies");
|
||||||
|
foreach (var movie in content?.Metadata ?? new Metadata[] { })
|
||||||
|
{
|
||||||
|
// Let's check if we have this movie
|
||||||
|
|
||||||
|
try
|
||||||
|
{
|
||||||
|
var existing = await Repo.GetFirstContentByCustom(x => x.Title == movie.title
|
||||||
|
&& x.ReleaseYear == movie.year.ToString()
|
||||||
|
&& x.Type == PlexMediaTypeEntity.Movie);
|
||||||
|
// The rating key keeps changing
|
||||||
|
//var existing = await Repo.GetByKey(movie.ratingKey);
|
||||||
|
if (existing != null)
|
||||||
|
{
|
||||||
|
Logger.LogDebug("We already have movie {0}", movie.title);
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
var hasSameKey = await Repo.GetByKey(movie.ratingKey);
|
||||||
|
if (hasSameKey != null)
|
||||||
|
{
|
||||||
|
await Repo.Delete(hasSameKey);
|
||||||
|
}
|
||||||
|
|
||||||
|
Logger.LogDebug("Adding movie {0}", movie.title);
|
||||||
|
var guids = new List<string>();
|
||||||
|
if (!movie.Guid.Any())
|
||||||
|
{
|
||||||
|
var metaData = await PlexApi.GetMetadata(servers.PlexAuthToken, servers.FullUri,
|
||||||
|
movie.ratingKey);
|
||||||
|
|
||||||
|
var meta = metaData.MediaContainer.Metadata.FirstOrDefault();
|
||||||
|
guids.Add(meta.guid);
|
||||||
|
if (meta.Guid != null)
|
||||||
|
{
|
||||||
|
foreach (var g in meta.Guid)
|
||||||
|
{
|
||||||
|
guids.Add(g.Id);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
// Currently a Plex Pass feature only
|
||||||
|
foreach (var g in movie.Guid)
|
||||||
|
{
|
||||||
|
guids.Add(g.Id);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
var providerIds = PlexHelper.GetProviderIdsFromMetadata(guids.ToArray());
|
||||||
|
|
||||||
|
var item = new PlexServerContent
|
||||||
|
{
|
||||||
|
AddedAt = DateTime.Now,
|
||||||
|
Key = movie.ratingKey,
|
||||||
|
ReleaseYear = movie.year.ToString(),
|
||||||
|
Type = PlexMediaTypeEntity.Movie,
|
||||||
|
Title = movie.title,
|
||||||
|
Url = PlexHelper.GetPlexMediaUrl(servers.MachineIdentifier, movie.ratingKey),
|
||||||
|
Seasons = new List<PlexSeasonsContent>(),
|
||||||
|
Quality = movie.Media?.FirstOrDefault()?.videoResolution ?? string.Empty
|
||||||
|
};
|
||||||
|
if (providerIds.ImdbId.HasValue())
|
||||||
|
{
|
||||||
|
item.ImdbId = providerIds.ImdbId;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (providerIds.TheMovieDb.HasValue())
|
||||||
|
{
|
||||||
|
item.TheMovieDbId = providerIds.TheMovieDb;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (providerIds.TheTvDb.HasValue())
|
||||||
|
{
|
||||||
|
item.TvDbId = providerIds.TheTvDb;
|
||||||
|
}
|
||||||
|
|
||||||
|
contentToAdd.Add(item);
|
||||||
|
}
|
||||||
|
catch (Exception e)
|
||||||
|
{
|
||||||
|
Logger.LogError(LoggingEvents.PlexContentCacher, e, "Exception when adding new Movie {0}",
|
||||||
|
movie.title);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (contentToAdd.Count > 500)
|
||||||
|
{
|
||||||
|
await Repo.AddRange(contentToAdd);
|
||||||
|
foreach (var c in contentToAdd)
|
||||||
|
{
|
||||||
|
contentProcessed.Add(c.Id, c.Key);
|
||||||
|
}
|
||||||
|
|
||||||
|
contentToAdd.Clear();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
private async Task ProcessTvShow(PlexServers servers, Metadata show, HashSet<PlexServerContent> contentToAdd, Dictionary<int, int> contentProcessed)
|
private async Task ProcessTvShow(PlexServers servers, Metadata show, HashSet<PlexServerContent> contentToAdd, Dictionary<int, int> contentProcessed)
|
||||||
{
|
{
|
||||||
var seasonList = await PlexApi.GetSeasons(servers.PlexAuthToken, servers.FullUri,
|
var seasonList = await PlexApi.GetSeasons(servers.PlexAuthToken, servers.FullUri,
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue