mirror of
https://github.com/lidarr/lidarr.git
synced 2025-07-14 00:53:57 -07:00
Fixed: Handle download clients sending invalid content-type header.
DownloadStation incorrectly surrounds charset with double-quotes. whereas the http standard specifies they must be without quotes. fixes #1586
This commit is contained in:
parent
7f8093de92
commit
8d776abb48
3 changed files with 44 additions and 1 deletions
42
src/NzbDrone.Common.Test/Http/HttpHeaderFixture.cs
Normal file
42
src/NzbDrone.Common.Test/Http/HttpHeaderFixture.cs
Normal file
|
@ -0,0 +1,42 @@
|
|||
using NUnit.Framework;
|
||||
using FluentAssertions;
|
||||
using NzbDrone.Test.Common;
|
||||
using System;
|
||||
using System.Collections.Generic;
|
||||
using System.Linq;
|
||||
using System.Text;
|
||||
using NzbDrone.Common.Http;
|
||||
using System.Collections.Specialized;
|
||||
|
||||
namespace NzbDrone.Common.Test.Http
|
||||
{
|
||||
[TestFixture]
|
||||
public class HttpHeaderFixture : TestBase
|
||||
{
|
||||
[TestCase("text/html; charset=\"utf-8\"", "utf-8")]
|
||||
[TestCase("text/html; charset=utf-8", "utf-8")]
|
||||
public void should_get_encoding_from_content_type_header(string contentType, string charsetExpected)
|
||||
{
|
||||
var headers = new NameValueCollection();
|
||||
|
||||
headers.Add("Content-Type", contentType);
|
||||
|
||||
var httpheader = new HttpHeader(headers);
|
||||
|
||||
httpheader.GetEncodingFromContentType().Should().Be(Encoding.GetEncoding(charsetExpected));
|
||||
}
|
||||
|
||||
[TestCase("text/html; charset=asdasd")]
|
||||
public void should_throw_when_invalid_encoding_is_in_content_type_header(string contentType)
|
||||
{
|
||||
var headers = new NameValueCollection();
|
||||
|
||||
headers.Add("Content-Type", contentType);
|
||||
|
||||
var httpheader = new HttpHeader(headers);
|
||||
|
||||
Action action = () => httpheader.GetEncodingFromContentType();
|
||||
action.ShouldThrow<ArgumentException>();
|
||||
}
|
||||
}
|
||||
}
|
Loading…
Add table
Add a link
Reference in a new issue