EpisodeRepository: Adding tests

This commit is contained in:
Zoe Roux 2021-08-01 14:44:19 +02:00
parent 1472ff1cfa
commit 5152368950
5 changed files with 185 additions and 24 deletions

View File

@ -1,6 +1,9 @@
using System.Collections.Generic;
using System.Linq;
using System.Threading.Tasks; using System.Threading.Tasks;
using Kyoo.Controllers; using Kyoo.Controllers;
using Kyoo.Models; using Kyoo.Models;
using Microsoft.EntityFrameworkCore;
using Xunit; using Xunit;
using Xunit.Abstractions; using Xunit.Abstractions;
@ -92,10 +95,6 @@ namespace Kyoo.Tests.Database
}); });
Assert.Equal($"{TestSample.Get<Show>().Slug}-s2e4", episode.Slug); Assert.Equal($"{TestSample.Get<Show>().Slug}-s2e4", episode.Slug);
} }
// TODO absolute numbering tests
[Fact] [Fact]
public void AbsoluteSlugTest() public void AbsoluteSlugTest()
@ -188,5 +187,137 @@ namespace Kyoo.Tests.Database
Episode episode = await _repository.Get(3); Episode episode = await _repository.Get(3);
Assert.Equal("john-wick", episode.Slug); Assert.Equal("john-wick", episode.Slug);
} }
[Fact]
public async Task CreateWithExternalIdTest()
{
Episode value = TestSample.GetNew<Episode>();
value.ExternalIDs = new[]
{
new MetadataID
{
Provider = TestSample.Get<Provider>(),
Link = "link",
DataID = "id"
},
new MetadataID
{
Provider = TestSample.GetNew<Provider>(),
Link = "new-provider-link",
DataID = "new-id"
}
};
await _repository.Create(value);
Episode retrieved = await _repository.Get(2);
await Repositories.LibraryManager.Load(retrieved, x => x.ExternalIDs);
Assert.Equal(2, retrieved.ExternalIDs.Count);
KAssert.DeepEqual(value.ExternalIDs.First(), retrieved.ExternalIDs.First());
KAssert.DeepEqual(value.ExternalIDs.Last(), retrieved.ExternalIDs.Last());
}
[Fact]
public async Task EditTest()
{
Episode value = await _repository.Get(TestSample.Get<Episode>().Slug);
value.Title = "New Title";
value.Images = new Dictionary<int, string>
{
[Images.Poster] = "new-poster"
};
await _repository.Edit(value, false);
await using DatabaseContext database = Repositories.Context.New();
Episode retrieved = await database.Episodes.FirstAsync();
KAssert.DeepEqual(value, retrieved);
}
[Fact]
public async Task EditMetadataTest()
{
Episode value = await _repository.Get(TestSample.Get<Episode>().Slug);
value.ExternalIDs = new[]
{
new MetadataID
{
Provider = TestSample.Get<Provider>(),
Link = "link",
DataID = "id"
},
};
await _repository.Edit(value, false);
await using DatabaseContext database = Repositories.Context.New();
Episode retrieved = await database.Episodes
.Include(x => x.ExternalIDs)
.ThenInclude(x => x.Provider)
.FirstAsync();
KAssert.DeepEqual(value, retrieved);
}
[Fact]
public async Task AddMetadataTest()
{
Episode value = await _repository.Get(TestSample.Get<Episode>().Slug);
value.ExternalIDs = new List<MetadataID>
{
new()
{
Provider = TestSample.Get<Provider>(),
Link = "link",
DataID = "id"
},
};
await _repository.Edit(value, false);
{
await using DatabaseContext database = Repositories.Context.New();
Episode retrieved = await database.Episodes
.Include(x => x.ExternalIDs)
.ThenInclude(x => x.Provider)
.FirstAsync();
KAssert.DeepEqual(value, retrieved);
}
value.ExternalIDs.Add(new MetadataID
{
Provider = TestSample.GetNew<Provider>(),
Link = "link",
DataID = "id"
});
await _repository.Edit(value, false);
{
await using DatabaseContext database = Repositories.Context.New();
Episode retrieved = await database.Episodes
.Include(x => x.ExternalIDs)
.ThenInclude(x => x.Provider)
.FirstAsync();
KAssert.DeepEqual(value, retrieved);
}
}
[Theory]
[InlineData("test")]
[InlineData("super")]
[InlineData("title")]
[InlineData("TiTlE")]
[InlineData("SuPeR")]
public async Task SearchTest(string query)
{
Episode value = new()
{
Title = "This is a test super title",
ShowID = 1,
AbsoluteNumber = 2
};
await _repository.Create(value);
ICollection<Episode> ret = await _repository.Search(query);
KAssert.DeepEqual(value, ret.First());
}
} }
} }

View File

@ -203,6 +203,7 @@ namespace Kyoo.Tests.Database
Season value = new() Season value = new()
{ {
Title = "This is a test super title", Title = "This is a test super title",
ShowID = 1
}; };
await _repository.Create(value); await _repository.Create(value);
ICollection<Season> ret = await _repository.Search(query); ICollection<Season> ret = await _repository.Search(query);

View File

@ -71,6 +71,27 @@ namespace Kyoo.Tests
} }
} }
}, },
{
typeof(Episode),
() => new Episode
{
ID = 2,
ShowID = 1,
ShowSlug = Get<Show>().Slug,
SeasonID = 1,
SeasonNumber = Get<Season>().SeasonNumber,
EpisodeNumber = 3,
AbsoluteNumber = 4,
Path = "/episode-path",
Title = "New Episode Title",
ReleaseDate = new DateTime(2000, 10, 10),
Overview = "new episode overview",
Images = new Dictionary<int, string>
{
[Images.Logo] = "new episode logo"
}
}
},
{ {
typeof(Provider), typeof(Provider),
() => new Provider () => new Provider

View File

@ -99,7 +99,7 @@ namespace Kyoo.Controllers
public override async Task<ICollection<Episode>> Search(string query) public override async Task<ICollection<Episode>> Search(string query)
{ {
return await _database.Episodes return await _database.Episodes
.Where(x => x.EpisodeNumber != null) .Where(x => x.EpisodeNumber != null || x.AbsoluteNumber != null)
.Where(_database.Like<Episode>(x => x.Title, $"%{query}%")) .Where(_database.Like<Episode>(x => x.Title, $"%{query}%"))
.OrderBy(DefaultSort) .OrderBy(DefaultSort)
.Take(20) .Take(20)
@ -111,7 +111,6 @@ namespace Kyoo.Controllers
{ {
await base.Create(obj); await base.Create(obj);
_database.Entry(obj).State = EntityState.Added; _database.Entry(obj).State = EntityState.Added;
obj.ExternalIDs.ForEach(x => _database.MetadataIds<Episode>().Attach(x));
await _database.SaveChangesAsync($"Trying to insert a duplicated episode (slug {obj.Slug} already exists)."); await _database.SaveChangesAsync($"Trying to insert a duplicated episode (slug {obj.Slug} already exists).");
return await ValidateTracks(obj); return await ValidateTracks(obj);
} }
@ -119,9 +118,6 @@ namespace Kyoo.Controllers
/// <inheritdoc /> /// <inheritdoc />
protected override async Task EditRelations(Episode resource, Episode changed, bool resetOld) protected override async Task EditRelations(Episode resource, Episode changed, bool resetOld)
{ {
if (resource.ShowID <= 0)
throw new InvalidOperationException($"Can't store an episode not related to any show (showID: {resource.ShowID}).");
if (changed.Tracks != null || resetOld) if (changed.Tracks != null || resetOld)
{ {
await _tracks.DeleteAll(x => x.EpisodeID == resource.ID); await _tracks.DeleteAll(x => x.EpisodeID == resource.ID);
@ -158,12 +154,20 @@ namespace Kyoo.Controllers
protected override async Task Validate(Episode resource) protected override async Task Validate(Episode resource)
{ {
await base.Validate(resource); await base.Validate(resource);
await resource.ExternalIDs.ForEachAsync(async x => if (resource.ShowID <= 0)
{ throw new ArgumentException($"Can't store an episode not related " +
x.Provider = await _providers.CreateIfNotExists(x.Provider); $"to any show (showID: {resource.ShowID}).");
x.ProviderID = x.Provider.ID;
_database.Entry(x.Provider).State = EntityState.Detached; if (resource.ExternalIDs != null)
}); {
foreach (MetadataID id in resource.ExternalIDs)
{
id.Provider = await _providers.CreateIfNotExists(id.Provider);
id.ProviderID = id.Provider.ID;
_database.Entry(id.Provider).State = EntityState.Unchanged;
}
_database.MetadataIds<Episode>().AttachRange(resource.ExternalIDs);
}
} }
/// <inheritdoc /> /// <inheritdoc />

View File

@ -87,7 +87,6 @@ namespace Kyoo.Controllers
{ {
await base.Create(obj); await base.Create(obj);
_database.Entry(obj).State = EntityState.Added; _database.Entry(obj).State = EntityState.Added;
obj.ExternalIDs.ForEach(x => _database.MetadataIds<Season>().Attach(x));
await _database.SaveChangesAsync($"Trying to insert a duplicated season (slug {obj.Slug} already exists)."); await _database.SaveChangesAsync($"Trying to insert a duplicated season (slug {obj.Slug} already exists).");
return obj; return obj;
} }
@ -95,32 +94,37 @@ namespace Kyoo.Controllers
/// <inheritdoc/> /// <inheritdoc/>
protected override async Task Validate(Season resource) protected override async Task Validate(Season resource)
{ {
await base.Validate(resource);
if (resource.ShowID <= 0) if (resource.ShowID <= 0)
{ {
if (resource.Show == null) if (resource.Show == null)
throw new InvalidOperationException( throw new ArgumentException(
$"Can't store a season not related to any show (showID: {resource.ShowID})."); $"Can't store a season not related to any show (showID: {resource.ShowID}).");
resource.ShowID = resource.Show.ID; resource.ShowID = resource.Show.ID;
} }
await base.Validate(resource); if (resource.ExternalIDs != null)
await resource.ExternalIDs.ForEachAsync(async id =>
{ {
id.Provider = await _providers.CreateIfNotExists(id.Provider); foreach (MetadataID id in resource.ExternalIDs)
id.ProviderID = id.Provider.ID; {
_database.Entry(id.Provider).State = EntityState.Detached; id.Provider = await _providers.CreateIfNotExists(id.Provider);
}); id.ProviderID = id.Provider.ID;
_database.Entry(id.Provider).State = EntityState.Unchanged;
}
_database.MetadataIds<Season>().AttachRange(resource.ExternalIDs);
}
} }
/// <inheritdoc/> /// <inheritdoc/>
protected override async Task EditRelations(Season resource, Season changed, bool resetOld) protected override async Task EditRelations(Season resource, Season changed, bool resetOld)
{ {
await Validate(changed);
if (changed.ExternalIDs != null || resetOld) if (changed.ExternalIDs != null || resetOld)
{ {
await Database.Entry(resource).Collection(x => x.ExternalIDs).LoadAsync(); await Database.Entry(resource).Collection(x => x.ExternalIDs).LoadAsync();
resource.ExternalIDs = changed.ExternalIDs; resource.ExternalIDs = changed.ExternalIDs;
} }
await base.EditRelations(resource, changed, resetOld);
} }
/// <inheritdoc/> /// <inheritdoc/>