Fixed: Gazelle Issues, Plus add feed parse test

Fixes #217
pull/221/head
Qstick 7 years ago
parent 88298fbac8
commit 97a0daa1aa

@ -0,0 +1,166 @@
{
"status": "success",
"response": {
"currentPage": 1,
"pages": 1,
"results": [
{
"groupId": 106951,
"groupName": "Shania Twain",
"artist": "Shania Twain",
"cover": "https:\\/\\/ptpimg.me\\/460az6.jpg",
"tags": [
"rock",
"country"
],
"bookmarked": false,
"vanityHouse": false,
"groupYear": 1993,
"releaseType": "Album",
"groupTime": "1512951473",
"maxSize": 653734702,
"totalSnatched": 33,
"totalSeeders": 27,
"totalLeechers": 0,
"torrents": [
{
"torrentId": 194008,
"editionId": 1,
"artists": [
{
"id": 9504,
"name": "Shania Twain",
"aliasid": 9506
}
],
"remastered": false,
"remasterYear": 0,
"remasterCatalogueNumber": "",
"remasterTitle": "",
"media": "CD",
"encoding": "Lossless",
"format": "FLAC",
"hasLog": true,
"logScore": 100,
"hasCue": true,
"scene": false,
"vanityHouse": false,
"fileCount": 14,
"time": "2016-12-02 16:02:39",
"size": 198741350,
"snatches": 19,
"seeders": 17,
"leechers": 0,
"isFreeleech": false,
"isNeutralLeech": false,
"isPersonalFreeleech": false,
"canUseToken": false,
"hasSnatched": false
},
{
"torrentId": 230096,
"editionId": 1,
"artists": [
{
"id": 9504,
"name": "Shania Twain",
"aliasid": 9506
}
],
"remastered": false,
"remasterYear": 0,
"remasterCatalogueNumber": "",
"remasterTitle": "",
"media": "CD",
"encoding": "320",
"format": "MP3",
"hasLog": false,
"logScore": 0,
"hasCue": false,
"scene": false,
"vanityHouse": false,
"fileCount": 13,
"time": "2016-12-03 21:46:04",
"size": 74275018,
"snatches": 3,
"seeders": 3,
"leechers": 0,
"isFreeleech": false,
"isNeutralLeech": false,
"isPersonalFreeleech": false,
"canUseToken": false,
"hasSnatched": false
},
{
"torrentId": 230086,
"editionId": 1,
"artists": [
{
"id": 9504,
"name": "Shania Twain",
"aliasid": 9506
}
],
"remastered": false,
"remasterYear": 0,
"remasterCatalogueNumber": "",
"remasterTitle": "",
"media": "CD",
"encoding": "V0 (VBR)",
"format": "MP3",
"hasLog": false,
"logScore": 0,
"hasCue": false,
"scene": false,
"vanityHouse": false,
"fileCount": 13,
"time": "2016-12-03 21:45:41",
"size": 61191629,
"snatches": 7,
"seeders": 5,
"leechers": 0,
"isFreeleech": false,
"isNeutralLeech": false,
"isPersonalFreeleech": false,
"canUseToken": false,
"hasSnatched": false
},
{
"torrentId": 1541452,
"editionId": 2,
"artists": [
{
"id": 9504,
"name": "Shania Twain",
"aliasid": 9506
}
],
"remastered": true,
"remasterYear": 2017,
"remasterCatalogueNumber": "",
"remasterTitle": "",
"media": "WEB",
"encoding": "24bit Lossless",
"format": "FLAC",
"hasLog": false,
"logScore": 0,
"hasCue": false,
"scene": false,
"vanityHouse": false,
"fileCount": 13,
"time": "2017-12-11 00:17:53",
"size": 653734702,
"snatches": 4,
"seeders": 2,
"leechers": 0,
"isFreeleech": false,
"isNeutralLeech": false,
"isPersonalFreeleech": false,
"canUseToken": false,
"hasSnatched": false
}
]
}
]
}
}

@ -0,0 +1,22 @@
{
"status": "success",
"response": {
"username": "dr4g0n",
"id": 469,
"authkey": "redacted",
"passkey": "redacted",
"notifications": {
"messages": 0,
"notifications": 9000,
"newAnnouncement": false,
"newBlog": false
},
"userstats": {
"uploaded": 585564424629,
"downloaded": 177461229738,
"ratio": 3.29,
"requiredratio": 0.6,
"class": "VIP"
}
}
}

@ -0,0 +1,66 @@
using System;
using System.Linq;
using FluentAssertions;
using Moq;
using NUnit.Framework;
using NzbDrone.Common.Http;
using NzbDrone.Core.Indexers;
using NzbDrone.Core.Indexers.Gazelle;
using NzbDrone.Core.Test.Framework;
namespace NzbDrone.Core.Test.IndexerTests.GazelleTests
{
[TestFixture]
public class GazelleFixture : CoreTest<Gazelle>
{
[SetUp]
public void Setup()
{
Subject.Definition = new IndexerDefinition()
{
Name = "Gazelle",
Settings = new GazelleSettings
{
Username = "user",
Password = "pass",
BaseUrl = "http://someurl.ch"
}
};
}
[Test]
public void should_parse_recent_feed_from_gazelle()
{
var recentFeed = ReadAllText(@"Files/Indexers/Gazelle/Gazelle.json");
var indexFeed = ReadAllText(@"Files/Indexers/Gazelle/GazelleIndex.json");
Mocker.GetMock<IHttpClient>()
.Setup(o => o.Execute(It.Is<HttpRequest>(v => v.Method == HttpMethod.GET && v.Url.FullUri.Contains("ajax.php?action=browse"))))
.Returns<HttpRequest>(r => new HttpResponse(r, new HttpHeader{ContentType = "application/json" }, recentFeed));
Mocker.GetMock<IHttpClient>()
.Setup(o => o.Execute(It.Is<HttpRequest>(v => v.Method == HttpMethod.POST && v.Url.FullUri.Contains("ajax.php?action=index"))))
.Returns<HttpRequest>(r => new HttpResponse(r, new HttpHeader(), indexFeed));
Mocker.GetMock<IHttpClient>()
.Setup(o => o.Execute(It.Is<HttpRequest>(v => v.Method == HttpMethod.POST && v.Url.FullUri.Contains("login.php"))))
.Returns<HttpRequest>(r => new HttpResponse(r, new HttpHeader(), indexFeed));
var releases = Subject.FetchRecent();
releases.Should().HaveCount(4);
var releaseInfo = releases.First();
releaseInfo.Title.Should().Be("Shania Twain - Shania Twain (1993) [FLAC 24bit Lossless]");
releaseInfo.DownloadProtocol.Should().Be(DownloadProtocol.Torrent);
releaseInfo.DownloadUrl.Should()
.Be("http://someurl.ch/torrents.php?action=download&id=1541452&authkey=redacted&torrent_pass=redacted");
releaseInfo.InfoUrl.Should().Be("http://someurl.ch/torrents.php?id=106951&torrentid=1541452");
releaseInfo.CommentUrl.Should().Be(null);
releaseInfo.Indexer.Should().Be(Subject.Definition.Name);
releaseInfo.PublishDate.Should().Be(DateTime.Parse("2017-12-11 00:17:53"));
releaseInfo.Size.Should().Be(653734702);
}
}
}

@ -184,6 +184,9 @@
<Compile Include="Download\Pending\PendingReleaseServiceTests\RemoveRejectedFixture.cs" /> <Compile Include="Download\Pending\PendingReleaseServiceTests\RemoveRejectedFixture.cs" />
<Compile Include="Download\Pending\PendingReleaseServiceTests\RemoveGrabbedFixture.cs" /> <Compile Include="Download\Pending\PendingReleaseServiceTests\RemoveGrabbedFixture.cs" />
<Compile Include="Download\Pending\PendingReleaseServiceTests\AddFixture.cs" /> <Compile Include="Download\Pending\PendingReleaseServiceTests\AddFixture.cs" />
<None Include="Files\Indexers\Gazelle\GazelleIndex.json">
<CopyToOutputDirectory>Always</CopyToOutputDirectory>
</None>
<None Include="Files\Indexers\Rarbg\RecentFeed_v1.json"> <None Include="Files\Indexers\Rarbg\RecentFeed_v1.json">
<CopyToOutputDirectory>Always</CopyToOutputDirectory> <CopyToOutputDirectory>Always</CopyToOutputDirectory>
</None> </None>
@ -239,6 +242,7 @@
<Compile Include="IndexerSearchTests\ArtistSearchServiceFixture.cs" /> <Compile Include="IndexerSearchTests\ArtistSearchServiceFixture.cs" />
<Compile Include="IndexerSearchTests\SearchDefinitionFixture.cs" /> <Compile Include="IndexerSearchTests\SearchDefinitionFixture.cs" />
<Compile Include="IndexerTests\BasicRssParserFixture.cs" /> <Compile Include="IndexerTests\BasicRssParserFixture.cs" />
<Compile Include="IndexerTests\GazelleTests\GazelleFixture.cs" />
<Compile Include="IndexerTests\HeadphonesTests\HeadphonesFixture.cs" /> <Compile Include="IndexerTests\HeadphonesTests\HeadphonesFixture.cs" />
<Compile Include="IndexerTests\HeadphonesTests\HeadphonesCapabilitiesProviderFixture.cs" /> <Compile Include="IndexerTests\HeadphonesTests\HeadphonesCapabilitiesProviderFixture.cs" />
<Compile Include="IndexerTests\IndexerServiceFixture.cs" /> <Compile Include="IndexerTests\IndexerServiceFixture.cs" />
@ -412,6 +416,9 @@
<Link>sqlite3.dll</Link> <Link>sqlite3.dll</Link>
<CopyToOutputDirectory>Always</CopyToOutputDirectory> <CopyToOutputDirectory>Always</CopyToOutputDirectory>
</Content> </Content>
<None Include="Files\Indexers\Gazelle\Gazelle.json">
<CopyToOutputDirectory>Always</CopyToOutputDirectory>
</None>
<Content Include="Files\Indexers\Headphones\Headphones.xml"> <Content Include="Files\Indexers\Headphones\Headphones.xml">
<CopyToOutputDirectory>Always</CopyToOutputDirectory> <CopyToOutputDirectory>Always</CopyToOutputDirectory>
</Content> </Content>

@ -40,30 +40,32 @@ namespace NzbDrone.Core.Indexers.Gazelle
throw new IndexerException(indexerResponse, $"Unexpected response header {indexerResponse.HttpResponse.Headers.ContentType} from API request, expected {HttpAccept.Json.Value}"); throw new IndexerException(indexerResponse, $"Unexpected response header {indexerResponse.HttpResponse.Headers.ContentType} from API request, expected {HttpAccept.Json.Value}");
} }
var jsonResponse = JsonConvert.DeserializeObject<GazelleResponse>(WebUtility.HtmlDecode(indexerResponse.Content)); var jsonResponse = new HttpResponse<GazelleResponse>(indexerResponse.HttpResponse);
if (jsonResponse.Status != "success" || if (jsonResponse.Resource.Status != "success" ||
jsonResponse.Status.IsNullOrWhiteSpace() || jsonResponse.Resource.Status.IsNullOrWhiteSpace() ||
jsonResponse.Response == null) jsonResponse.Resource.Response == null)
{ {
return torrentInfos; return torrentInfos;
} }
foreach (var result in jsonResponse.Response.Results) foreach (var result in jsonResponse.Resource.Response.Results)
{ {
if (result.Torrents != null) if (result.Torrents != null)
{ {
foreach (var torrent in result.Torrents) foreach (var torrent in result.Torrents)
{ {
var id = torrent.TorrentId; var id = torrent.TorrentId;
var artist = WebUtility.HtmlDecode(result.Artist);
var album = WebUtility.HtmlDecode(result.GroupName);
torrentInfos.Add(new GazelleInfo() torrentInfos.Add(new GazelleInfo()
{ {
Guid = string.Format("Gazelle-{0}", id), Guid = string.Format("Gazelle-{0}", id),
Artist = result.Artist, Artist = artist,
// Splice Title from info to avoid calling API again for every torrent. // Splice Title from info to avoid calling API again for every torrent.
Title = result.Artist + " - " + result.GroupName + " (" + result.GroupYear +") (" + torrent.Format + " " + torrent.Encoding + ")", Title = WebUtility.HtmlDecode(result.Artist + " - " + result.GroupName + " (" + result.GroupYear +") [" + torrent.Format + " " + torrent.Encoding + "]"),
Album = result.GroupName, Album = album,
Container = torrent.Encoding, Container = torrent.Encoding,
Codec = torrent.Format, Codec = torrent.Format,
Size = long.Parse(torrent.Size), Size = long.Parse(torrent.Size),

@ -72,7 +72,7 @@ namespace NzbDrone.Core.Indexers.Gazelle
}; };
indexRequestBuilder.SetCookies(cookies); indexRequestBuilder.SetCookies(cookies);
indexRequestBuilder.Method = HttpMethod.GET; indexRequestBuilder.Method = HttpMethod.POST;
indexRequestBuilder.Resource("ajax.php?action=index"); indexRequestBuilder.Resource("ajax.php?action=index");
var authIndexRequest = indexRequestBuilder var authIndexRequest = indexRequestBuilder

Loading…
Cancel
Save