Fixed: Skyhook Tests, Validate GUID before sending to metadata api

pull/6/head
Qstick 7 years ago
parent bc8bd9995a
commit 9cd60bc986

@ -9,6 +9,8 @@ using NzbDrone.Core.MetadataSource.SkyHook;
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 @@ namespace NzbDrone.Core.Test.MetadataSource.SkyHook
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 @@ namespace NzbDrone.Core.Test.MetadataSource.SkyHook
[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 @@ namespace NzbDrone.Core.Test.MetadataSource.SkyHook
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 @@ namespace NzbDrone.Core.MetadataSource.SkyHook
{ {
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 @@ namespace NzbDrone.Core.MetadataSource.SkyHook
{ {
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 @@ namespace NzbDrone.Core.MetadataSource.SkyHook
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…
Cancel
Save