mirror of
https://github.com/wiremock/WireMock.Net.git
synced 2026-01-15 23:03:55 +01:00
* Improved relative path checking based on file existence If the file exists at the relative path, then use it. If not, then use the path as is. * Apply File.Exists logic to ReadResponseBodyAsString as well * Make path handling more robust since path is user defined * Unit tests for relative path feature * Replace all back and forward slashes with system dependent DirectorySeparatorChar * Attempt fix broken directory separator chars for Unix platforms * Revert wrapping GetMappingFolder with CleanPath * Move CleanPath logic to its own class * Remove whitespace * Remove more whitespace * Improve CleanPath method * Move PathUtils tests to separate class Add another test to ResponseWithBodyFromFileTests * Fix Response_ProvideResponse_WithBodyFromFile_InAdminMappingFolder * Debug Linux CI build * Debug Linux CI * print all files from admin mappings folder * Debug CleanPath * Fix removed leading directory separator char in Linux breaks file path Remove debugging statements * Move combine to PathUtils * PathUtils + PathUtilsTests * Remove replicated (3x) tests throughout ResponseWithBodyFromFileTests Co-authored-by: Stef Heyenrath <Stef.Heyenrath@gmail.com>
104 lines
3.3 KiB
C#
104 lines
3.3 KiB
C#
using FluentAssertions;
|
|
using System;
|
|
using System.Collections.Generic;
|
|
using System.IO;
|
|
using System.Net;
|
|
using System.Net.Http;
|
|
using System.Threading.Tasks;
|
|
using WireMock.RequestBuilders;
|
|
using WireMock.ResponseBuilders;
|
|
using WireMock.Server;
|
|
using Xunit;
|
|
|
|
namespace WireMock.Net.Tests.ResponseBuilders
|
|
{
|
|
public class ResponseWithBodyFromFileTests
|
|
{
|
|
[Fact]
|
|
public async Task Response_ProvideResponse_WithBodyFromFile_AbsolutePath()
|
|
{
|
|
// Arrange
|
|
var server = WireMockServer.Start();
|
|
string path = Path.Combine(Directory.GetCurrentDirectory(), "__admin", "mappings", "MyXmlResponse.xml");
|
|
|
|
server
|
|
.Given(
|
|
Request
|
|
.Create()
|
|
.UsingGet()
|
|
.WithPath("/v1/content")
|
|
)
|
|
.RespondWith(
|
|
Response
|
|
.Create()
|
|
.WithStatusCode(HttpStatusCode.OK)
|
|
.WithHeader("Content-Type", "application/xml")
|
|
.WithBodyFromFile(path)
|
|
);
|
|
|
|
// Act
|
|
var response = await new HttpClient().GetStringAsync("http://localhost:" + server.Ports[0] + "/v1/content");
|
|
|
|
// Assert
|
|
response.Should().Contain("<hello>world</hello>");
|
|
}
|
|
|
|
[Fact]
|
|
public async Task Response_ProvideResponse_WithBodyFromFile_InSubDirectory()
|
|
{
|
|
// Arrange
|
|
var server = WireMockServer.Start();
|
|
string path = @"subdirectory/MyXmlResponse.xml";
|
|
|
|
server
|
|
.Given(
|
|
Request
|
|
.Create()
|
|
.UsingGet()
|
|
.WithPath("/v1/content")
|
|
)
|
|
.RespondWith(
|
|
Response
|
|
.Create()
|
|
.WithStatusCode(HttpStatusCode.OK)
|
|
.WithHeader("Content-Type", "application/xml")
|
|
.WithBodyFromFile(path)
|
|
);
|
|
|
|
// Act
|
|
var response = await new HttpClient().GetStringAsync("http://localhost:" + server.Ports[0] + "/v1/content");
|
|
|
|
// Assert
|
|
response.Should().Contain("<hello>world</hello>");
|
|
}
|
|
|
|
[Fact]
|
|
public async Task Response_ProvideResponse_WithBodyFromFile_InAdminMappingFolder()
|
|
{
|
|
// Arrange
|
|
var server = WireMockServer.Start();
|
|
string path = @"MyXmlResponse.xml";
|
|
|
|
server
|
|
.Given(
|
|
Request
|
|
.Create()
|
|
.UsingGet()
|
|
.WithPath("/v1/content")
|
|
)
|
|
.RespondWith(
|
|
Response
|
|
.Create()
|
|
.WithStatusCode(HttpStatusCode.OK)
|
|
.WithHeader("Content-Type", "application/xml")
|
|
.WithBodyFromFile(path)
|
|
);
|
|
|
|
// Act
|
|
var response = await new HttpClient().GetStringAsync("http://localhost:" + server.Ports[0] + "/v1/content");
|
|
|
|
// Assert
|
|
response.Should().Contain("<hello>world</hello>");
|
|
}
|
|
}
|
|
} |