Ocelot/test/Ocelot.UnitTests/Headers/AddHeadersToResponseTests.cs

148 lines
4.6 KiB
C#

using Moq;
using Ocelot.Configuration.Creator;
using Ocelot.Headers;
using Ocelot.Infrastructure;
using Ocelot.Logging;
using Ocelot.Middleware;
using Ocelot.Responses;
using Ocelot.UnitTests.Responder;
using Shouldly;
using System.Collections.Generic;
using System.Linq;
using System.Net.Http;
using TestStack.BDDfy;
using Xunit;
namespace Ocelot.UnitTests.Headers
{
public class AddHeadersToResponseTests
{
private readonly IAddHeadersToResponse _adder;
private readonly Mock<IPlaceholders> _placeholders;
private DownstreamResponse _response;
private List<AddHeader> _addHeaders;
private Mock<IOcelotLoggerFactory> _factory;
private readonly Mock<IOcelotLogger> _logger;
public AddHeadersToResponseTests()
{
_factory = new Mock<IOcelotLoggerFactory>();
_logger = new Mock<IOcelotLogger>();
_factory.Setup(x => x.CreateLogger<AddHeadersToResponse>()).Returns(_logger.Object);
_placeholders = new Mock<IPlaceholders>();
_adder = new AddHeadersToResponse(_placeholders.Object, _factory.Object);
}
[Fact]
public void should_add_header()
{
var addHeaders = new List<AddHeader>
{
new AddHeader("Laura", "Tom")
};
this.Given(_ => GivenAResponseMessage())
.And(_ => GivenTheAddHeaders(addHeaders))
.When(_ => WhenIAdd())
.And(_ => ThenTheHeaderIsReturned("Laura", "Tom"))
.BDDfy();
}
[Fact]
public void should_add_trace_id_placeholder()
{
var addHeaders = new List<AddHeader>
{
new AddHeader("Trace-Id", "{TraceId}")
};
var traceId = "123";
this.Given(_ => GivenAResponseMessage())
.And(_ => GivenTheTraceIdIs(traceId))
.And(_ => GivenTheAddHeaders(addHeaders))
.When(_ => WhenIAdd())
.Then(_ => ThenTheHeaderIsReturned("Trace-Id", traceId))
.BDDfy();
}
[Fact]
public void should_add_trace_id_placeholder_and_normal()
{
var addHeaders = new List<AddHeader>
{
new AddHeader("Trace-Id", "{TraceId}"),
new AddHeader("Tom", "Laura")
};
var traceId = "123";
this.Given(_ => GivenAResponseMessage())
.And(_ => GivenTheTraceIdIs(traceId))
.And(_ => GivenTheAddHeaders(addHeaders))
.When(_ => WhenIAdd())
.Then(_ => ThenTheHeaderIsReturned("Trace-Id", traceId))
.Then(_ => ThenTheHeaderIsReturned("Tom", "Laura"))
.BDDfy();
}
[Fact]
public void should_do_nothing_and_log_error()
{
var addHeaders = new List<AddHeader>
{
new AddHeader("Trace-Id", "{TraceId}")
};
this.Given(_ => GivenAResponseMessage())
.And(_ => GivenTheTraceIdErrors())
.And(_ => GivenTheAddHeaders(addHeaders))
.When(_ => WhenIAdd())
.Then(_ => ThenTheHeaderIsNotAdded("Trace-Id"))
.And(_ => ThenTheErrorIsLogged())
.BDDfy();
}
private void ThenTheErrorIsLogged()
{
_logger.Verify(x => x.LogWarning("Unable to add header to response Trace-Id: {TraceId}"), Times.Once);
}
private void ThenTheHeaderIsNotAdded(string key)
{
_response.Headers.Any(x => x.Key == key).ShouldBeFalse();
}
private void GivenTheTraceIdIs(string traceId)
{
_placeholders.Setup(x => x.Get("{TraceId}")).Returns(new OkResponse<string>(traceId));
}
private void GivenTheTraceIdErrors()
{
_placeholders.Setup(x => x.Get("{TraceId}")).Returns(new ErrorResponse<string>(new AnyError()));
}
private void ThenTheHeaderIsReturned(string key, string value)
{
var values = _response.Headers.First(x => x.Key == key);
values.Values.First().ShouldBe(value);
}
private void WhenIAdd()
{
_adder.Add(_addHeaders, _response);
}
private void GivenAResponseMessage()
{
_response = new DownstreamResponse(new HttpResponseMessage());
}
private void GivenTheAddHeaders(List<AddHeader> addHeaders)
{
_addHeaders = addHeaders;
}
}
}