mirror of
https://github.com/wiremock/WireMock.Net.git
synced 2026-01-18 08:07:09 +01:00
* wip * HandlebarsRegistrationCallback * HandlebarsContextFactoryTests * 1.0.21.0 * fix sonar * LocalFileSystemHandler * readme * Fix System.IO.IOException
100 lines
3.6 KiB
C#
100 lines
3.6 KiB
C#
using Moq;
|
|
using Newtonsoft.Json.Linq;
|
|
using NFluent;
|
|
using System;
|
|
using System.Threading.Tasks;
|
|
using WireMock.Handlers;
|
|
using WireMock.Models;
|
|
using WireMock.ResponseBuilders;
|
|
using WireMock.Settings;
|
|
using Xunit;
|
|
|
|
namespace WireMock.Net.Tests.ResponseBuilders
|
|
{
|
|
public class ResponseWithHandlebarsFileTests
|
|
{
|
|
private readonly Mock<IFileSystemHandler> _filesystemHandlerMock;
|
|
private readonly Mock<IFluentMockServerSettings> _settingsMock;
|
|
private const string ClientIp = "::1";
|
|
|
|
public ResponseWithHandlebarsFileTests()
|
|
{
|
|
_filesystemHandlerMock = new Mock<IFileSystemHandler>(MockBehavior.Strict);
|
|
_filesystemHandlerMock.Setup(fs => fs.ReadResponseBodyAsString(It.IsAny<string>())).Returns("abc");
|
|
|
|
_settingsMock = new Mock<IFluentMockServerSettings>();
|
|
_settingsMock.SetupGet(s => s.FileSystemHandler).Returns(_filesystemHandlerMock.Object);
|
|
}
|
|
|
|
[Fact]
|
|
public async Task Response_ProvideResponseAsync_Handlebars_File()
|
|
{
|
|
// Assign
|
|
var request = new RequestMessage(new UrlDetails("http://localhost:1234"), "GET", ClientIp);
|
|
|
|
var response = Response.Create()
|
|
.WithBodyAsJson(new
|
|
{
|
|
Data = "{{File \"x.json\"}}"
|
|
})
|
|
.WithTransformer();
|
|
|
|
// Act
|
|
var responseMessage = await response.ProvideResponseAsync(request, _settingsMock.Object);
|
|
|
|
// Assert
|
|
JObject j = JObject.FromObject(responseMessage.BodyData.BodyAsJson);
|
|
Check.That(j["Data"].Value<string>()).Equals("abc");
|
|
|
|
// Verify
|
|
_filesystemHandlerMock.Verify(fs => fs.ReadResponseBodyAsString("x.json"), Times.Once);
|
|
_filesystemHandlerMock.VerifyNoOtherCalls();
|
|
}
|
|
|
|
[Fact]
|
|
public async Task Response_ProvideResponseAsync_Handlebars_File_Replace()
|
|
{
|
|
// Assign
|
|
var request = new RequestMessage(new UrlDetails("http://localhost:1234?id=x"), "GET", ClientIp);
|
|
|
|
var response = Response.Create()
|
|
.WithBodyAsJson(new
|
|
{
|
|
Data = "{{File \"{{request.query.id}}.json\"}}"
|
|
})
|
|
.WithTransformer();
|
|
|
|
// Act
|
|
var responseMessage = await response.ProvideResponseAsync(request, _settingsMock.Object);
|
|
|
|
// Assert
|
|
JObject j = JObject.FromObject(responseMessage.BodyData.BodyAsJson);
|
|
Check.That(j["Data"].Value<string>()).Equals("abc");
|
|
|
|
// Verify
|
|
_filesystemHandlerMock.Verify(fs => fs.ReadResponseBodyAsString("x.json"), Times.Once);
|
|
_filesystemHandlerMock.VerifyNoOtherCalls();
|
|
}
|
|
|
|
[Fact]
|
|
public void Response_ProvideResponseAsync_Handlebars_File_WithMissingArgument_ThrowsArgumentOutOfRangeException()
|
|
{
|
|
// Assign
|
|
var request = new RequestMessage(new UrlDetails("http://localhost:1234"), "GET", ClientIp);
|
|
|
|
var response = Response.Create()
|
|
.WithBodyAsJson(new
|
|
{
|
|
Data = "{{File}}"
|
|
})
|
|
.WithTransformer();
|
|
|
|
// Act
|
|
Check.ThatAsyncCode(() => response.ProvideResponseAsync(request, _settingsMock.Object)).Throws<ArgumentOutOfRangeException>();
|
|
|
|
// Verify
|
|
_filesystemHandlerMock.Verify(fs => fs.ReadResponseBodyAsString(It.IsAny<string>()), Times.Never);
|
|
_filesystemHandlerMock.VerifyNoOtherCalls();
|
|
}
|
|
}
|
|
} |