mirror of
https://github.com/lidarr/lidarr.git
synced 2025-08-20 13:33:34 -07:00
parent
88298fbac8
commit
97a0daa1aa
6 changed files with 272 additions and 9 deletions
166
src/NzbDrone.Core.Test/Files/Indexers/Gazelle/Gazelle.json
Normal file
166
src/NzbDrone.Core.Test/Files/Indexers/Gazelle/Gazelle.json
Normal file
|
@ -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…
Add table
Add a link
Reference in a new issue