Skip to content
This repository has been archived by the owner on Sep 22, 2022. It is now read-only.

Latest commit

 

History

History
67 lines (63 loc) · 3.16 KB

File metadata and controls

67 lines (63 loc) · 3.16 KB

RestEase.Serialization.Extensions

Build NuGet NuGet

Provides an implementation of RequestQueryParamSerializer that serializes object parameters in a format compatible with ASP.NET Core MVC model binding for complex types.

Why?

It seems a bit strange, but by default RestEase doesn't support serialization of complex type parameters, so that they could be correctly bound to controller method parameters by ASP.NET Core MVC at the server side. Imagine that we have a following controller:

[Route("[controller]")]
public class EmployeesController : Controller
{
    [HttpGet("bulk")]
    public Task<BulkRequest> GetEmployeeByRequest([FromQuery] BulkRequest bulkRequest) =>
        Task.FromResult(bulkRequest);
}

public class BulkRequest
{
    public string Value { get; set; }
    public int[] Ids { get; set; }
}

Let's suppose that we need to write an integration test for that conroller using RestEase to get a strongly-typed test code:

[BasePath("Employees")]
[SerializationMethods(Query = QuerySerializationMethod.Serialized)]
public interface IEmployeesController
{
    [Get("bulk")]
    Task<BulkRequest> GetEmployeeByRequest([Query] BulkRequest bulkRequest);
}
[Fact]
public async Task GetEmployeeByRequest_Success()
{
    var controller = RestClient.For<IEmployeesController>(_httpClient);
    var request = new BulkRequest { Ids = new[] { 1, 2, 3 }, Value = "Qwerty" };
    var response = await controller.GetEmployeeByRequest(request);
    Assert.Equal(request.Value, response.Value);
    Assert.True(request.Ids.SequenceEqual(response.Ids));
}

The problem is that RestEase supports only Json serialization or ToString and that's not what ASP.NET Core MVC expects according to the official documentation.

How to use

You just need to set a RequestQueryParamSerializer to ComplexTypeRequestQueryParamSerializer for the Requester that you're going to use. For the sample test code to work correctly:

[Fact]
public async Task GetEmployeeByRequest_Success()
{
    var requester = new Requester(_httpClient)
    {
        RequestQueryParamSerializer = new ComplexTypeRequestQueryParamSerializer(),
    };
    var controller = RestClient.For<IEmployeesController>(requester);
    var request = new BulkRequest { Ids = new[] { 1, 2, 3 }, Value = "Qwerty" };
    var response = await controller.GetEmployeeByRequest(request);
    Assert.Equal(request.Value, response.Value);
    Assert.True(request.Ids.SequenceEqual(response.Ids));
}