mirror of
https://github.com/lidarr/Lidarr
synced 2025-02-26 15:52:42 +00:00
Fixed: Skyhook Tests, Validate GUID before sending to metadata api
This commit is contained in:
parent
bc8bd9995a
commit
9cd60bc986
3 changed files with 74 additions and 6 deletions
|
@ -9,6 +9,8 @@
|
||||||
using NzbDrone.Core.Test.Framework;
|
using NzbDrone.Core.Test.Framework;
|
||||||
using NzbDrone.Core.Music;
|
using NzbDrone.Core.Music;
|
||||||
using NzbDrone.Test.Common.Categories;
|
using NzbDrone.Test.Common.Categories;
|
||||||
|
using Moq;
|
||||||
|
using NzbDrone.Core.Profiles.Metadata;
|
||||||
|
|
||||||
namespace NzbDrone.Core.Test.MetadataSource.SkyHook
|
namespace NzbDrone.Core.Test.MetadataSource.SkyHook
|
||||||
{
|
{
|
||||||
|
@ -20,13 +22,38 @@ public class SkyHookProxyFixture : CoreTest<SkyHookProxy>
|
||||||
public void Setup()
|
public void Setup()
|
||||||
{
|
{
|
||||||
UseRealHttp();
|
UseRealHttp();
|
||||||
|
|
||||||
|
var _metadataProfile = new MetadataProfile
|
||||||
|
{
|
||||||
|
PrimaryAlbumTypes = new List<ProfilePrimaryAlbumTypeItem>
|
||||||
|
{
|
||||||
|
new ProfilePrimaryAlbumTypeItem
|
||||||
|
{
|
||||||
|
PrimaryAlbumType = PrimaryAlbumType.Album,
|
||||||
|
Allowed = true
|
||||||
|
|
||||||
|
}
|
||||||
|
},
|
||||||
|
SecondaryAlbumTypes = new List<ProfileSecondaryAlbumTypeItem>
|
||||||
|
{
|
||||||
|
new ProfileSecondaryAlbumTypeItem()
|
||||||
|
{
|
||||||
|
SecondaryAlbumType = SecondaryAlbumType.Studio,
|
||||||
|
Allowed = true
|
||||||
|
}
|
||||||
|
},
|
||||||
|
};
|
||||||
|
|
||||||
|
Mocker.GetMock<IMetadataProfileService>()
|
||||||
|
.Setup(s => s.Get(It.IsAny<int>()))
|
||||||
|
.Returns(_metadataProfile);
|
||||||
}
|
}
|
||||||
|
|
||||||
[TestCase("f59c5520-5f46-4d2c-b2c4-822eabf53419", "Linkin Park")]
|
[TestCase("f59c5520-5f46-4d2c-b2c4-822eabf53419", "Linkin Park")]
|
||||||
[TestCase("66c662b6-6e2f-4930-8610-912e24c63ed1", "AC/DC")]
|
[TestCase("66c662b6-6e2f-4930-8610-912e24c63ed1", "AC/DC")]
|
||||||
public void should_be_able_to_get_artist_detail(string mbId, string name)
|
public void should_be_able_to_get_artist_detail(string mbId, string name)
|
||||||
{
|
{
|
||||||
var details = Subject.GetArtistInfo(mbId, 0);
|
var details = Subject.GetArtistInfo(mbId, 1);
|
||||||
|
|
||||||
ValidateArtist(details.Item1);
|
ValidateArtist(details.Item1);
|
||||||
ValidateAlbums(details.Item2);
|
ValidateAlbums(details.Item2);
|
||||||
|
@ -37,13 +64,14 @@ public void should_be_able_to_get_artist_detail(string mbId, string name)
|
||||||
[Test]
|
[Test]
|
||||||
public void getting_details_of_invalid_artist()
|
public void getting_details_of_invalid_artist()
|
||||||
{
|
{
|
||||||
Assert.Throws<ArtistNotFoundException>(() => Subject.GetArtistInfo("aaaaaa-aaa-aaaa-aaaa", 0));
|
Assert.Throws<BadRequestException>(() => Subject.GetArtistInfo("aaaaaa-aaa-aaaa-aaaa", 1));
|
||||||
}
|
}
|
||||||
|
|
||||||
[Test]
|
[Test]
|
||||||
|
[Ignore("We don't return a dothack from Metadata")]
|
||||||
public void should_not_have_period_at_start_of_name_slug()
|
public void should_not_have_period_at_start_of_name_slug()
|
||||||
{
|
{
|
||||||
var details = Subject.GetArtistInfo("b6db95cd-88d9-492f-bbf6-a34e0e89b2e5", 0);
|
var details = Subject.GetArtistInfo("b6db95cd-88d9-492f-bbf6-a34e0e89b2e5", 1);
|
||||||
|
|
||||||
details.Item1.NameSlug.Should().Be("dothack");
|
details.Item1.NameSlug.Should().Be("dothack");
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,9 +1,13 @@
|
||||||
using FluentAssertions;
|
using FluentAssertions;
|
||||||
using NUnit.Framework;
|
using NUnit.Framework;
|
||||||
using NzbDrone.Core.MetadataSource.SkyHook;
|
using NzbDrone.Core.MetadataSource.SkyHook;
|
||||||
using NzbDrone.Core.Test.Framework;
|
using NzbDrone.Core.Test.Framework;
|
||||||
using NzbDrone.Test.Common;
|
using NzbDrone.Test.Common;
|
||||||
using NzbDrone.Test.Common.Categories;
|
using NzbDrone.Test.Common.Categories;
|
||||||
|
using Moq;
|
||||||
|
using NzbDrone.Core.Profiles.Metadata;
|
||||||
|
using NzbDrone.Core.Music;
|
||||||
|
using System.Collections.Generic;
|
||||||
|
|
||||||
namespace NzbDrone.Core.Test.MetadataSource.SkyHook
|
namespace NzbDrone.Core.Test.MetadataSource.SkyHook
|
||||||
{
|
{
|
||||||
|
@ -15,6 +19,36 @@ public class SkyHookProxySearchFixture : CoreTest<SkyHookProxy>
|
||||||
public void Setup()
|
public void Setup()
|
||||||
{
|
{
|
||||||
UseRealHttp();
|
UseRealHttp();
|
||||||
|
|
||||||
|
var _metadataProfile = new MetadataProfile
|
||||||
|
{
|
||||||
|
Id = 1,
|
||||||
|
PrimaryAlbumTypes = new List<ProfilePrimaryAlbumTypeItem>
|
||||||
|
{
|
||||||
|
new ProfilePrimaryAlbumTypeItem
|
||||||
|
{
|
||||||
|
PrimaryAlbumType = PrimaryAlbumType.Album,
|
||||||
|
Allowed = true
|
||||||
|
|
||||||
|
}
|
||||||
|
},
|
||||||
|
SecondaryAlbumTypes = new List<ProfileSecondaryAlbumTypeItem>
|
||||||
|
{
|
||||||
|
new ProfileSecondaryAlbumTypeItem()
|
||||||
|
{
|
||||||
|
SecondaryAlbumType = SecondaryAlbumType.Studio,
|
||||||
|
Allowed = true
|
||||||
|
}
|
||||||
|
},
|
||||||
|
};
|
||||||
|
|
||||||
|
Mocker.GetMock<IMetadataProfileService>()
|
||||||
|
.Setup(s => s.All())
|
||||||
|
.Returns(new List<MetadataProfile>{_metadataProfile});
|
||||||
|
|
||||||
|
Mocker.GetMock<IMetadataProfileService>()
|
||||||
|
.Setup(s => s.Get(It.IsAny<int>()))
|
||||||
|
.Returns(_metadataProfile);
|
||||||
}
|
}
|
||||||
|
|
||||||
[TestCase("Coldplay", "Coldplay")]
|
[TestCase("Coldplay", "Coldplay")]
|
||||||
|
|
|
@ -70,6 +70,10 @@ public Tuple<Artist, List<Album>> GetArtistInfo(string foreignArtistId, int meta
|
||||||
{
|
{
|
||||||
throw new ArtistNotFoundException(foreignArtistId);
|
throw new ArtistNotFoundException(foreignArtistId);
|
||||||
}
|
}
|
||||||
|
else if (httpResponse.StatusCode == HttpStatusCode.BadRequest)
|
||||||
|
{
|
||||||
|
throw new BadRequestException(foreignArtistId);
|
||||||
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
throw new HttpException(httpRequest, httpResponse);
|
throw new HttpException(httpRequest, httpResponse);
|
||||||
|
@ -93,7 +97,9 @@ public List<Artist> SearchForNewArtist(string title)
|
||||||
{
|
{
|
||||||
var slug = lowerTitle.Split(':')[1].Trim();
|
var slug = lowerTitle.Split(':')[1].Trim();
|
||||||
|
|
||||||
if (slug.IsNullOrWhiteSpace() || slug.Any(char.IsWhiteSpace))
|
bool isValid = Guid.TryParse(slug, out var searchGuid);
|
||||||
|
|
||||||
|
if (slug.IsNullOrWhiteSpace() || slug.Any(char.IsWhiteSpace) || isValid == false)
|
||||||
{
|
{
|
||||||
return new List<Artist>();
|
return new List<Artist>();
|
||||||
}
|
}
|
||||||
|
@ -101,7 +107,7 @@ public List<Artist> SearchForNewArtist(string title)
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
var metadataProfile = _metadataProfileService.All().First().Id; //Change this to Use last Used profile?
|
var metadataProfile = _metadataProfileService.All().First().Id; //Change this to Use last Used profile?
|
||||||
return new List<Artist> { GetArtistInfo(slug, metadataProfile).Item1 };
|
return new List<Artist> { GetArtistInfo(searchGuid.ToString(), metadataProfile).Item1 };
|
||||||
}
|
}
|
||||||
catch (ArtistNotFoundException)
|
catch (ArtistNotFoundException)
|
||||||
{
|
{
|
||||||
|
|
Loading…
Reference in a new issue