diff options
Diffstat (limited to 'tests')
| -rw-r--r-- | tests/Jellyfin.Providers.Tests/Manager/MetadataServiceTests.cs (renamed from tests/Jellyfin.Providers.Tests/Manager/ProviderUtilsTests.cs) | 73 |
1 files changed, 38 insertions, 35 deletions
diff --git a/tests/Jellyfin.Providers.Tests/Manager/ProviderUtilsTests.cs b/tests/Jellyfin.Providers.Tests/Manager/MetadataServiceTests.cs index 9e4bbef13..b74b331b7 100644 --- a/tests/Jellyfin.Providers.Tests/Manager/ProviderUtilsTests.cs +++ b/tests/Jellyfin.Providers.Tests/Manager/MetadataServiceTests.cs @@ -11,7 +11,7 @@ using Xunit; namespace Jellyfin.Providers.Tests.Manager { - public class ProviderUtilsTests + public class MetadataServiceTests { [Theory] [InlineData(false, false)] @@ -55,7 +55,7 @@ namespace Jellyfin.Providers.Tests.Manager } }; - ProviderUtils.MergeBaseItemData(source, target, Array.Empty<MetadataField>(), true, mergeMetadataSettings); + MetadataService<Movie, MovieInfo>.MergeBaseItemData(source, target, Array.Empty<MetadataField>(), true, mergeMetadataSettings); if (mergeMetadataSettings) { @@ -90,19 +90,19 @@ namespace Jellyfin.Providers.Tests.Manager var newValue = "New"; // Use type Series to hit DisplayOrder - Assert.False(TestMergeBaseItemData<Series>(propName, oldValue, newValue, null, false, out _)); + Assert.False(TestMergeBaseItemData<Series, SeriesInfo>(propName, oldValue, newValue, null, false, out _)); if (lockField != null) { - Assert.False(TestMergeBaseItemData<Series>(propName, oldValue, newValue, lockField, true, out _)); - Assert.False(TestMergeBaseItemData<Series>(propName, null, newValue, lockField, false, out _)); - Assert.False(TestMergeBaseItemData<Series>(propName, string.Empty, newValue, lockField, false, out _)); + Assert.False(TestMergeBaseItemData<Series, SeriesInfo>(propName, oldValue, newValue, lockField, true, out _)); + Assert.False(TestMergeBaseItemData<Series, SeriesInfo>(propName, null, newValue, lockField, false, out _)); + Assert.False(TestMergeBaseItemData<Series, SeriesInfo>(propName, string.Empty, newValue, lockField, false, out _)); } - Assert.True(TestMergeBaseItemData<Series>(propName, oldValue, newValue, null, true, out _)); - Assert.True(TestMergeBaseItemData<Series>(propName, null, newValue, null, false, out _)); - Assert.True(TestMergeBaseItemData<Series>(propName, string.Empty, newValue, null, false, out _)); + Assert.True(TestMergeBaseItemData<Series, SeriesInfo>(propName, oldValue, newValue, null, true, out _)); + Assert.True(TestMergeBaseItemData<Series, SeriesInfo>(propName, null, newValue, null, false, out _)); + Assert.True(TestMergeBaseItemData<Series, SeriesInfo>(propName, string.Empty, newValue, null, false, out _)); - var replacedWithEmpty = TestMergeBaseItemData<Series>(propName, oldValue, string.Empty, null, true, out _); + var replacedWithEmpty = TestMergeBaseItemData<Series, SeriesInfo>(propName, oldValue, string.Empty, null, true, out _); Assert.Equal(replacesWithEmpty, replacedWithEmpty); } @@ -119,17 +119,17 @@ namespace Jellyfin.Providers.Tests.Manager var newValue = new[] { "New" }; // Use type Audio to hit AlbumArtists - Assert.False(TestMergeBaseItemData<Audio>(propName, oldValue, newValue, null, false, out _)); + Assert.False(TestMergeBaseItemData<Audio, SongInfo>(propName, oldValue, newValue, null, false, out _)); if (lockField != null) { - Assert.False(TestMergeBaseItemData<Audio>(propName, oldValue, newValue, lockField, true, out _)); - Assert.False(TestMergeBaseItemData<Audio>(propName, Array.Empty<string>(), newValue, lockField, false, out _)); + Assert.False(TestMergeBaseItemData<Audio, SongInfo>(propName, oldValue, newValue, lockField, true, out _)); + Assert.False(TestMergeBaseItemData<Audio, SongInfo>(propName, Array.Empty<string>(), newValue, lockField, false, out _)); } - Assert.True(TestMergeBaseItemData<Audio>(propName, oldValue, newValue, null, true, out _)); - Assert.True(TestMergeBaseItemData<Audio>(propName, Array.Empty<string>(), newValue, null, false, out _)); + Assert.True(TestMergeBaseItemData<Audio, SongInfo>(propName, oldValue, newValue, null, true, out _)); + Assert.True(TestMergeBaseItemData<Audio, SongInfo>(propName, Array.Empty<string>(), newValue, null, false, out _)); - Assert.True(TestMergeBaseItemData<Audio>(propName, oldValue, Array.Empty<string>(), null, true, out _)); + Assert.True(TestMergeBaseItemData<Audio, SongInfo>(propName, oldValue, Array.Empty<string>(), null, true, out _)); } private static TheoryData<string, object, object> MergeBaseItemData_SimpleField_ReplacesAppropriately_TestData() @@ -150,12 +150,12 @@ namespace Jellyfin.Providers.Tests.Manager public void MergeBaseItemData_SimpleField_ReplacesAppropriately(string propName, object oldValue, object newValue) { // Use type Movie to allow testing of Video3DFormat - Assert.False(TestMergeBaseItemData<Movie>(propName, oldValue, newValue, null, false, out _)); + Assert.False(TestMergeBaseItemData<Movie, MovieInfo>(propName, oldValue, newValue, null, false, out _)); - Assert.True(TestMergeBaseItemData<Movie>(propName, oldValue, newValue, null, true, out _)); - Assert.True(TestMergeBaseItemData<Movie>(propName, null, newValue, null, false, out _)); + Assert.True(TestMergeBaseItemData<Movie, MovieInfo>(propName, oldValue, newValue, null, true, out _)); + Assert.True(TestMergeBaseItemData<Movie, MovieInfo>(propName, null, newValue, null, false, out _)); - Assert.True(TestMergeBaseItemData<Movie>(propName, oldValue, null, null, true, out _)); + Assert.True(TestMergeBaseItemData<Movie, MovieInfo>(propName, oldValue, null, null, true, out _)); } [Fact] @@ -179,12 +179,12 @@ namespace Jellyfin.Providers.Tests.Manager } }; - Assert.False(TestMergeBaseItemData<Movie>(propName, oldValue, newValue, null, false, out _)); + Assert.False(TestMergeBaseItemData<Movie, MovieInfo>(propName, oldValue, newValue, null, false, out _)); - Assert.True(TestMergeBaseItemData<Movie>(propName, oldValue, newValue, null, true, out _)); - Assert.True(TestMergeBaseItemData<Movie>(propName, Array.Empty<MediaUrl>(), newValue, null, false, out _)); + Assert.True(TestMergeBaseItemData<Movie, MovieInfo>(propName, oldValue, newValue, null, true, out _)); + Assert.True(TestMergeBaseItemData<Movie, MovieInfo>(propName, Array.Empty<MediaUrl>(), newValue, null, false, out _)); - Assert.True(TestMergeBaseItemData<Movie>(propName, oldValue, Array.Empty<MediaUrl>(), null, true, out _)); + Assert.True(TestMergeBaseItemData<Movie, MovieInfo>(propName, oldValue, Array.Empty<MediaUrl>(), null, true, out _)); } [Fact] @@ -201,8 +201,8 @@ namespace Jellyfin.Providers.Tests.Manager { { "provider 1", "id 2" } }; - Assert.False(TestMergeBaseItemData<Movie>(propName, new Dictionary<string, string>(oldValue), overwriteNewValue, null, false, out _)); - TestMergeBaseItemData<Movie>(propName, new Dictionary<string, string>(oldValue), overwriteNewValue, null, true, out var overwritten); + Assert.False(TestMergeBaseItemData<Movie, MovieInfo>(propName, new Dictionary<string, string>(oldValue), overwriteNewValue, null, false, out _)); + TestMergeBaseItemData<Movie, MovieInfo>(propName, new Dictionary<string, string>(oldValue), overwriteNewValue, null, true, out var overwritten); Assert.Equal(overwriteNewValue, overwritten); // merge without overwriting @@ -211,13 +211,13 @@ namespace Jellyfin.Providers.Tests.Manager { "provider 1", "id 2" }, { "provider 2", "id 3" } }; - TestMergeBaseItemData<Movie>(propName, new Dictionary<string, string>(oldValue), mergeNewValue, null, false, out var merged); + TestMergeBaseItemData<Movie, MovieInfo>(propName, new Dictionary<string, string>(oldValue), mergeNewValue, null, false, out var merged); var actual = (Dictionary<string, string>)merged!; Assert.Equal("id 1", actual["provider 1"]); Assert.Equal("id 3", actual["provider 2"]); // empty source results in no change - TestMergeBaseItemData<Movie>(propName, new Dictionary<string, string>(oldValue), new Dictionary<string, string>(), null, true, out var notOverwritten); + TestMergeBaseItemData<Movie, MovieInfo>(propName, new Dictionary<string, string>(oldValue), new Dictionary<string, string>(), null, true, out var notOverwritten); Assert.Equal(oldValue, notOverwritten); } @@ -329,14 +329,14 @@ namespace Jellyfin.Providers.Tests.Manager }; var lockedFields = lockField == null ? Array.Empty<MetadataField>() : new[] { (MetadataField)lockField }; - ProviderUtils.MergeBaseItemData(source, target, lockedFields, replaceData, false); + MetadataService<Movie, MovieInfo>.MergeBaseItemData(source, target, lockedFields, replaceData, false); actualValue = target.People; return newValue?.Equals(actualValue) ?? actualValue == null; } /// <summary> - /// Makes a call to <see cref="ProviderUtils.MergeBaseItemData{T}"/> with the provided parameters and returns whether the target changed or not. + /// Makes a call to <see cref="MetadataService{TItemType,TIdType}.MergeBaseItemData"/> with the provided parameters and returns whether the target changed or not. /// /// Reflection is used to allow testing of all fields using the same logic, rather than relying on copy/pasting test code for each field. /// </summary> @@ -344,12 +344,14 @@ namespace Jellyfin.Providers.Tests.Manager /// <param name="oldValue">The initial value in the target object.</param> /// <param name="newValue">The initial value in the source object.</param> /// <param name="lockField">The metadata field that locks this property if the field should be locked, or <c>null</c> to leave unlocked.</param> - /// <param name="replaceData">Passed through to <see cref="ProviderUtils.MergeBaseItemData{T}"/>.</param> + /// <param name="replaceData">Passed through to <see cref="MetadataService{TItemType,TIdType}.MergeBaseItemData"/>.</param> /// <param name="actualValue">The resulting value set to the target.</param> /// <typeparam name="TItemType">The <see cref="BaseItem"/> type to test on.</typeparam> - /// <returns><c>true</c> if the property on the target updates to match the source value when<see cref="ProviderUtils.MergeBaseItemData{T}"/> is called.</returns> - private static bool TestMergeBaseItemData<TItemType>(string propName, object? oldValue, object? newValue, MetadataField? lockField, bool replaceData, out object? actualValue) - where TItemType : BaseItem, new() + /// <typeparam name="TIdType">The <see cref="BaseItem"/> info type.</typeparam> + /// <returns><c>true</c> if the property on the target updates to match the source value when<see cref="MetadataService{TItemType,TIdType}.MergeBaseItemData"/> is called.</returns> + private static bool TestMergeBaseItemData<TItemType, TIdType>(string propName, object? oldValue, object? newValue, MetadataField? lockField, bool replaceData, out object? actualValue) + where TItemType : BaseItem, IHasLookupInfo<TIdType>, new() + where TIdType : ItemLookupInfo, new() { var property = typeof(TItemType).GetProperty(propName)!; @@ -366,7 +368,8 @@ namespace Jellyfin.Providers.Tests.Manager property.SetValue(target.Item, oldValue); var lockedFields = lockField == null ? Array.Empty<MetadataField>() : new[] { (MetadataField)lockField }; - ProviderUtils.MergeBaseItemData(source, target, lockedFields, replaceData, false); + // generic type doesn't actually matter to call the static method, just has to be filled in + MetadataService<TItemType, TIdType>.MergeBaseItemData(source, target, lockedFields, replaceData, false); actualValue = property.GetValue(target.Item); return newValue?.Equals(actualValue) ?? actualValue == null; |
