|
|
@ -1,17 +1,13 @@
|
|
|
|
using System;
|
|
|
|
using System;
|
|
|
|
using System.Collections.Generic;
|
|
|
|
using System.Collections.Generic;
|
|
|
|
using System.Collections.Specialized;
|
|
|
|
|
|
|
|
using System.Globalization;
|
|
|
|
using System.Globalization;
|
|
|
|
using System.Text;
|
|
|
|
|
|
|
|
using System.Threading.Tasks;
|
|
|
|
using System.Threading.Tasks;
|
|
|
|
using Jellyfin.Api.ModelBinders;
|
|
|
|
using Jellyfin.Api.ModelBinders;
|
|
|
|
using MediaBrowser.Controller.Entities;
|
|
|
|
|
|
|
|
using Microsoft.AspNetCore.Http;
|
|
|
|
using Microsoft.AspNetCore.Http;
|
|
|
|
using Microsoft.AspNetCore.Mvc.ModelBinding;
|
|
|
|
using Microsoft.AspNetCore.Mvc.ModelBinding;
|
|
|
|
using Microsoft.Extensions.Primitives;
|
|
|
|
using Microsoft.Extensions.Primitives;
|
|
|
|
using Moq;
|
|
|
|
using Moq;
|
|
|
|
using Xunit;
|
|
|
|
using Xunit;
|
|
|
|
using Xunit.Sdk;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
namespace Jellyfin.Api.Tests.ModelBinders
|
|
|
|
namespace Jellyfin.Api.Tests.ModelBinders
|
|
|
|
{
|
|
|
|
{
|
|
|
@ -21,14 +17,14 @@ namespace Jellyfin.Api.Tests.ModelBinders
|
|
|
|
public async Task BindModelAsync_CorrectlyBindsValidCommaDelimitedStringArrayQuery()
|
|
|
|
public async Task BindModelAsync_CorrectlyBindsValidCommaDelimitedStringArrayQuery()
|
|
|
|
{
|
|
|
|
{
|
|
|
|
var queryParamName = "test";
|
|
|
|
var queryParamName = "test";
|
|
|
|
var queryParamValues = new string[] { "lol", "xd" };
|
|
|
|
var queryParamValues = new[] { "lol", "xd" };
|
|
|
|
var queryParamString = "lol,xd";
|
|
|
|
var queryParamString = "lol,xd";
|
|
|
|
var queryParamType = typeof(string[]);
|
|
|
|
var queryParamType = typeof(string[]);
|
|
|
|
|
|
|
|
|
|
|
|
var modelBinder = new CommaDelimitedArrayModelBinder();
|
|
|
|
var modelBinder = new CommaDelimitedArrayModelBinder();
|
|
|
|
var valueProvider = new QueryStringValueProvider(
|
|
|
|
var valueProvider = new QueryStringValueProvider(
|
|
|
|
new BindingSource(string.Empty, string.Empty, false, false),
|
|
|
|
new BindingSource(string.Empty, string.Empty, false, false),
|
|
|
|
new QueryCollection(new Dictionary<string, StringValues>() { { queryParamName, new StringValues(queryParamString) } }),
|
|
|
|
new QueryCollection(new Dictionary<string, StringValues> { { queryParamName, new StringValues(queryParamString) } }),
|
|
|
|
CultureInfo.InvariantCulture);
|
|
|
|
CultureInfo.InvariantCulture);
|
|
|
|
var bindingContextMock = new Mock<ModelBindingContext>();
|
|
|
|
var bindingContextMock = new Mock<ModelBindingContext>();
|
|
|
|
bindingContextMock.Setup(b => b.ValueProvider).Returns(valueProvider);
|
|
|
|
bindingContextMock.Setup(b => b.ValueProvider).Returns(valueProvider);
|
|
|
@ -46,14 +42,14 @@ namespace Jellyfin.Api.Tests.ModelBinders
|
|
|
|
public async Task BindModelAsync_CorrectlyBindsValidCommaDelimitedIntArrayQuery()
|
|
|
|
public async Task BindModelAsync_CorrectlyBindsValidCommaDelimitedIntArrayQuery()
|
|
|
|
{
|
|
|
|
{
|
|
|
|
var queryParamName = "test";
|
|
|
|
var queryParamName = "test";
|
|
|
|
var queryParamValues = new int[] { 42, 0 };
|
|
|
|
var queryParamValues = new[] { 42, 0 };
|
|
|
|
var queryParamString = "42,0";
|
|
|
|
var queryParamString = "42,0";
|
|
|
|
var queryParamType = typeof(int[]);
|
|
|
|
var queryParamType = typeof(int[]);
|
|
|
|
|
|
|
|
|
|
|
|
var modelBinder = new CommaDelimitedArrayModelBinder();
|
|
|
|
var modelBinder = new CommaDelimitedArrayModelBinder();
|
|
|
|
var valueProvider = new QueryStringValueProvider(
|
|
|
|
var valueProvider = new QueryStringValueProvider(
|
|
|
|
new BindingSource(string.Empty, string.Empty, false, false),
|
|
|
|
new BindingSource(string.Empty, string.Empty, false, false),
|
|
|
|
new QueryCollection(new Dictionary<string, StringValues>() { { queryParamName, new StringValues(queryParamString) } }),
|
|
|
|
new QueryCollection(new Dictionary<string, StringValues> { { queryParamName, new StringValues(queryParamString) } }),
|
|
|
|
CultureInfo.InvariantCulture);
|
|
|
|
CultureInfo.InvariantCulture);
|
|
|
|
var bindingContextMock = new Mock<ModelBindingContext>();
|
|
|
|
var bindingContextMock = new Mock<ModelBindingContext>();
|
|
|
|
bindingContextMock.Setup(b => b.ValueProvider).Returns(valueProvider);
|
|
|
|
bindingContextMock.Setup(b => b.ValueProvider).Returns(valueProvider);
|
|
|
@ -71,14 +67,14 @@ namespace Jellyfin.Api.Tests.ModelBinders
|
|
|
|
public async Task BindModelAsync_CorrectlyBindsValidCommaDelimitedEnumArrayQuery()
|
|
|
|
public async Task BindModelAsync_CorrectlyBindsValidCommaDelimitedEnumArrayQuery()
|
|
|
|
{
|
|
|
|
{
|
|
|
|
var queryParamName = "test";
|
|
|
|
var queryParamName = "test";
|
|
|
|
var queryParamValues = new TestType[] { TestType.How, TestType.Much };
|
|
|
|
var queryParamValues = new[] { TestType.How, TestType.Much };
|
|
|
|
var queryParamString = "How,Much";
|
|
|
|
var queryParamString = "How,Much";
|
|
|
|
var queryParamType = typeof(TestType[]);
|
|
|
|
var queryParamType = typeof(TestType[]);
|
|
|
|
|
|
|
|
|
|
|
|
var modelBinder = new CommaDelimitedArrayModelBinder();
|
|
|
|
var modelBinder = new CommaDelimitedArrayModelBinder();
|
|
|
|
var valueProvider = new QueryStringValueProvider(
|
|
|
|
var valueProvider = new QueryStringValueProvider(
|
|
|
|
new BindingSource(string.Empty, string.Empty, false, false),
|
|
|
|
new BindingSource(string.Empty, string.Empty, false, false),
|
|
|
|
new QueryCollection(new Dictionary<string, StringValues>() { { queryParamName, new StringValues(queryParamString) } }),
|
|
|
|
new QueryCollection(new Dictionary<string, StringValues> { { queryParamName, new StringValues(queryParamString) } }),
|
|
|
|
CultureInfo.InvariantCulture);
|
|
|
|
CultureInfo.InvariantCulture);
|
|
|
|
var bindingContextMock = new Mock<ModelBindingContext>();
|
|
|
|
var bindingContextMock = new Mock<ModelBindingContext>();
|
|
|
|
bindingContextMock.Setup(b => b.ValueProvider).Returns(valueProvider);
|
|
|
|
bindingContextMock.Setup(b => b.ValueProvider).Returns(valueProvider);
|
|
|
@ -96,14 +92,14 @@ namespace Jellyfin.Api.Tests.ModelBinders
|
|
|
|
public async Task BindModelAsync_CorrectlyBindsValidCommaDelimitedEnumArrayQueryWithDoubleCommas()
|
|
|
|
public async Task BindModelAsync_CorrectlyBindsValidCommaDelimitedEnumArrayQueryWithDoubleCommas()
|
|
|
|
{
|
|
|
|
{
|
|
|
|
var queryParamName = "test";
|
|
|
|
var queryParamName = "test";
|
|
|
|
var queryParamValues = new TestType[] { TestType.How, TestType.Much };
|
|
|
|
var queryParamValues = new[] { TestType.How, TestType.Much };
|
|
|
|
var queryParamString = "How,,Much";
|
|
|
|
var queryParamString = "How,,Much";
|
|
|
|
var queryParamType = typeof(TestType[]);
|
|
|
|
var queryParamType = typeof(TestType[]);
|
|
|
|
|
|
|
|
|
|
|
|
var modelBinder = new CommaDelimitedArrayModelBinder();
|
|
|
|
var modelBinder = new CommaDelimitedArrayModelBinder();
|
|
|
|
var valueProvider = new QueryStringValueProvider(
|
|
|
|
var valueProvider = new QueryStringValueProvider(
|
|
|
|
new BindingSource(string.Empty, string.Empty, false, false),
|
|
|
|
new BindingSource(string.Empty, string.Empty, false, false),
|
|
|
|
new QueryCollection(new Dictionary<string, StringValues>() { { queryParamName, new StringValues(queryParamString) } }),
|
|
|
|
new QueryCollection(new Dictionary<string, StringValues> { { queryParamName, new StringValues(queryParamString) } }),
|
|
|
|
CultureInfo.InvariantCulture);
|
|
|
|
CultureInfo.InvariantCulture);
|
|
|
|
var bindingContextMock = new Mock<ModelBindingContext>();
|
|
|
|
var bindingContextMock = new Mock<ModelBindingContext>();
|
|
|
|
bindingContextMock.Setup(b => b.ValueProvider).Returns(valueProvider);
|
|
|
|
bindingContextMock.Setup(b => b.ValueProvider).Returns(valueProvider);
|
|
|
@ -121,7 +117,7 @@ namespace Jellyfin.Api.Tests.ModelBinders
|
|
|
|
public async Task BindModelAsync_CorrectlyBindsValidEnumArrayQuery()
|
|
|
|
public async Task BindModelAsync_CorrectlyBindsValidEnumArrayQuery()
|
|
|
|
{
|
|
|
|
{
|
|
|
|
var queryParamName = "test";
|
|
|
|
var queryParamName = "test";
|
|
|
|
var queryParamValues = new TestType[] { TestType.How, TestType.Much };
|
|
|
|
var queryParamValues = new[] { TestType.How, TestType.Much };
|
|
|
|
var queryParamString1 = "How";
|
|
|
|
var queryParamString1 = "How";
|
|
|
|
var queryParamString2 = "Much";
|
|
|
|
var queryParamString2 = "Much";
|
|
|
|
var queryParamType = typeof(TestType[]);
|
|
|
|
var queryParamType = typeof(TestType[]);
|
|
|
@ -130,9 +126,9 @@ namespace Jellyfin.Api.Tests.ModelBinders
|
|
|
|
|
|
|
|
|
|
|
|
var valueProvider = new QueryStringValueProvider(
|
|
|
|
var valueProvider = new QueryStringValueProvider(
|
|
|
|
new BindingSource(string.Empty, string.Empty, false, false),
|
|
|
|
new BindingSource(string.Empty, string.Empty, false, false),
|
|
|
|
new QueryCollection(new Dictionary<string, StringValues>()
|
|
|
|
new QueryCollection(new Dictionary<string, StringValues>
|
|
|
|
{
|
|
|
|
{
|
|
|
|
{ queryParamName, new StringValues(new string[] { queryParamString1, queryParamString2 }) },
|
|
|
|
{ queryParamName, new StringValues(new[] { queryParamString1, queryParamString2 }) },
|
|
|
|
}),
|
|
|
|
}),
|
|
|
|
CultureInfo.InvariantCulture);
|
|
|
|
CultureInfo.InvariantCulture);
|
|
|
|
var bindingContextMock = new Mock<ModelBindingContext>();
|
|
|
|
var bindingContextMock = new Mock<ModelBindingContext>();
|
|
|
@ -158,7 +154,7 @@ namespace Jellyfin.Api.Tests.ModelBinders
|
|
|
|
|
|
|
|
|
|
|
|
var valueProvider = new QueryStringValueProvider(
|
|
|
|
var valueProvider = new QueryStringValueProvider(
|
|
|
|
new BindingSource(string.Empty, string.Empty, false, false),
|
|
|
|
new BindingSource(string.Empty, string.Empty, false, false),
|
|
|
|
new QueryCollection(new Dictionary<string, StringValues>()
|
|
|
|
new QueryCollection(new Dictionary<string, StringValues>
|
|
|
|
{
|
|
|
|
{
|
|
|
|
{ queryParamName, new StringValues(value: null) },
|
|
|
|
{ queryParamName, new StringValues(value: null) },
|
|
|
|
}),
|
|
|
|
}),
|
|
|
@ -171,7 +167,8 @@ namespace Jellyfin.Api.Tests.ModelBinders
|
|
|
|
|
|
|
|
|
|
|
|
await modelBinder.BindModelAsync(bindingContextMock.Object);
|
|
|
|
await modelBinder.BindModelAsync(bindingContextMock.Object);
|
|
|
|
|
|
|
|
|
|
|
|
Assert.False(bindingContextMock.Object.Result.IsModelSet);
|
|
|
|
Assert.True(bindingContextMock.Object.Result.IsModelSet);
|
|
|
|
|
|
|
|
Assert.Equal((TestType[])bindingContextMock.Object.Result.Model, queryParamValues);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
[Fact]
|
|
|
|
[Fact]
|
|
|
@ -184,7 +181,7 @@ namespace Jellyfin.Api.Tests.ModelBinders
|
|
|
|
var modelBinder = new CommaDelimitedArrayModelBinder();
|
|
|
|
var modelBinder = new CommaDelimitedArrayModelBinder();
|
|
|
|
var valueProvider = new QueryStringValueProvider(
|
|
|
|
var valueProvider = new QueryStringValueProvider(
|
|
|
|
new BindingSource(string.Empty, string.Empty, false, false),
|
|
|
|
new BindingSource(string.Empty, string.Empty, false, false),
|
|
|
|
new QueryCollection(new Dictionary<string, StringValues>() { { queryParamName, new StringValues(queryParamString) } }),
|
|
|
|
new QueryCollection(new Dictionary<string, StringValues> { { queryParamName, new StringValues(queryParamString) } }),
|
|
|
|
CultureInfo.InvariantCulture);
|
|
|
|
CultureInfo.InvariantCulture);
|
|
|
|
var bindingContextMock = new Mock<ModelBindingContext>();
|
|
|
|
var bindingContextMock = new Mock<ModelBindingContext>();
|
|
|
|
bindingContextMock.Setup(b => b.ValueProvider).Returns(valueProvider);
|
|
|
|
bindingContextMock.Setup(b => b.ValueProvider).Returns(valueProvider);
|
|
|
@ -201,7 +198,6 @@ namespace Jellyfin.Api.Tests.ModelBinders
|
|
|
|
public async Task BindModelAsync_ThrowsIfCommaDelimitedEnumArrayQueryIsInvalid2()
|
|
|
|
public async Task BindModelAsync_ThrowsIfCommaDelimitedEnumArrayQueryIsInvalid2()
|
|
|
|
{
|
|
|
|
{
|
|
|
|
var queryParamName = "test";
|
|
|
|
var queryParamName = "test";
|
|
|
|
var queryParamValues = new TestType[] { TestType.How, TestType.Much };
|
|
|
|
|
|
|
|
var queryParamString1 = "How";
|
|
|
|
var queryParamString1 = "How";
|
|
|
|
var queryParamString2 = "😱";
|
|
|
|
var queryParamString2 = "😱";
|
|
|
|
var queryParamType = typeof(TestType[]);
|
|
|
|
var queryParamType = typeof(TestType[]);
|
|
|
@ -210,9 +206,9 @@ namespace Jellyfin.Api.Tests.ModelBinders
|
|
|
|
|
|
|
|
|
|
|
|
var valueProvider = new QueryStringValueProvider(
|
|
|
|
var valueProvider = new QueryStringValueProvider(
|
|
|
|
new BindingSource(string.Empty, string.Empty, false, false),
|
|
|
|
new BindingSource(string.Empty, string.Empty, false, false),
|
|
|
|
new QueryCollection(new Dictionary<string, StringValues>()
|
|
|
|
new QueryCollection(new Dictionary<string, StringValues>
|
|
|
|
{
|
|
|
|
{
|
|
|
|
{ queryParamName, new StringValues(new string[] { queryParamString1, queryParamString2 }) },
|
|
|
|
{ queryParamName, new StringValues(new[] { queryParamString1, queryParamString2 }) },
|
|
|
|
}),
|
|
|
|
}),
|
|
|
|
CultureInfo.InvariantCulture);
|
|
|
|
CultureInfo.InvariantCulture);
|
|
|
|
var bindingContextMock = new Mock<ModelBindingContext>();
|
|
|
|
var bindingContextMock = new Mock<ModelBindingContext>();
|
|
|
|