mirror of
https://github.com/wiremock/WireMock.Net.git
synced 2026-04-19 15:31:39 +02:00
@@ -4,7 +4,7 @@
|
|||||||
</PropertyGroup>
|
</PropertyGroup>
|
||||||
|
|
||||||
<PropertyGroup>
|
<PropertyGroup>
|
||||||
<VersionPrefix>1.0.5</VersionPrefix>
|
<VersionPrefix>1.0.6</VersionPrefix>
|
||||||
</PropertyGroup>
|
</PropertyGroup>
|
||||||
|
|
||||||
<Choose>
|
<Choose>
|
||||||
|
|||||||
@@ -1,3 +1,3 @@
|
|||||||
https://github.com/StefH/GitHubReleaseNotes
|
https://github.com/StefH/GitHubReleaseNotes
|
||||||
|
|
||||||
GitHubReleaseNotes.exe --output CHANGELOG.md --skip-empty-releases --version 1.0.5
|
GitHubReleaseNotes.exe --output CHANGELOG.md --skip-empty-releases --version 1.0.6
|
||||||
@@ -58,6 +58,14 @@ namespace WireMock.Client
|
|||||||
[Header("Content-Type", "application/json")]
|
[Header("Content-Type", "application/json")]
|
||||||
Task<StatusModel> PostMappingAsync([Body] MappingModel mapping);
|
Task<StatusModel> PostMappingAsync([Body] MappingModel mapping);
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Add new mappings.
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="mappings">MappingModels</param>
|
||||||
|
[Post("__admin/mappings")]
|
||||||
|
[Header("Content-Type", "application/json")]
|
||||||
|
Task<StatusModel> PostMappingsAsync([Body] IList<MappingModel> mappings);
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Delete all mappings.
|
/// Delete all mappings.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
|
|||||||
@@ -1,3 +1,6 @@
|
|||||||
|
using JetBrains.Annotations;
|
||||||
|
using Newtonsoft.Json;
|
||||||
|
using Newtonsoft.Json.Linq;
|
||||||
using System;
|
using System;
|
||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
using System.IO;
|
using System.IO;
|
||||||
@@ -5,9 +8,6 @@ using System.Linq;
|
|||||||
using System.Net.Http;
|
using System.Net.Http;
|
||||||
using System.Text;
|
using System.Text;
|
||||||
using System.Threading.Tasks;
|
using System.Threading.Tasks;
|
||||||
using JetBrains.Annotations;
|
|
||||||
using Newtonsoft.Json;
|
|
||||||
using Newtonsoft.Json.Linq;
|
|
||||||
using WireMock.Admin.Mappings;
|
using WireMock.Admin.Mappings;
|
||||||
using WireMock.Admin.Scenarios;
|
using WireMock.Admin.Scenarios;
|
||||||
using WireMock.Admin.Settings;
|
using WireMock.Admin.Settings;
|
||||||
@@ -412,11 +412,21 @@ namespace WireMock.Server
|
|||||||
|
|
||||||
private ResponseMessage MappingsPost(RequestMessage requestMessage)
|
private ResponseMessage MappingsPost(RequestMessage requestMessage)
|
||||||
{
|
{
|
||||||
Guid? guid;
|
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
var mappingModel = DeserializeObject<MappingModel>(requestMessage);
|
var mappingModels = DeserializeObjectArray<MappingModel>(requestMessage);
|
||||||
guid = DeserializeAndAddOrUpdateMapping(mappingModel);
|
if (mappingModels.Length == 1)
|
||||||
|
{
|
||||||
|
Guid? guid = DeserializeAndAddOrUpdateMapping(mappingModels[0]);
|
||||||
|
return ResponseMessageBuilder.Create("Mapping added", 201, guid);
|
||||||
|
}
|
||||||
|
|
||||||
|
foreach (var mappingModel in mappingModels)
|
||||||
|
{
|
||||||
|
DeserializeAndAddOrUpdateMapping(mappingModel);
|
||||||
|
}
|
||||||
|
|
||||||
|
return ResponseMessageBuilder.Create("Mappings added", 201);
|
||||||
}
|
}
|
||||||
catch (ArgumentException a)
|
catch (ArgumentException a)
|
||||||
{
|
{
|
||||||
@@ -428,8 +438,6 @@ namespace WireMock.Server
|
|||||||
_logger.Error("HttpStatusCode set to 500 {0}", e);
|
_logger.Error("HttpStatusCode set to 500 {0}", e);
|
||||||
return ResponseMessageBuilder.Create(e.ToString(), 500);
|
return ResponseMessageBuilder.Create(e.ToString(), 500);
|
||||||
}
|
}
|
||||||
|
|
||||||
return ResponseMessageBuilder.Create("Mapping added", 201, guid);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private Guid? DeserializeAndAddOrUpdateMapping(MappingModel mappingModel, Guid? guid = null, string path = null)
|
private Guid? DeserializeAndAddOrUpdateMapping(MappingModel mappingModel, Guid? guid = null, string path = null)
|
||||||
@@ -793,5 +801,23 @@ namespace WireMock.Server
|
|||||||
|
|
||||||
return default(T);
|
return default(T);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private T[] DeserializeObjectArray<T>(RequestMessage requestMessage)
|
||||||
|
{
|
||||||
|
if (requestMessage?.BodyData?.DetectedBodyType == BodyType.Json)
|
||||||
|
{
|
||||||
|
var bodyAsJson = requestMessage.BodyData.BodyAsJson;
|
||||||
|
|
||||||
|
if (bodyAsJson is JArray jArray)
|
||||||
|
{
|
||||||
|
return jArray.ToObject<T[]>();
|
||||||
|
}
|
||||||
|
|
||||||
|
var value = ((JObject)requestMessage.BodyData.BodyAsJson).ToObject<T>();
|
||||||
|
return new[] { value };
|
||||||
|
}
|
||||||
|
|
||||||
|
return default(T[]);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -1,9 +1,9 @@
|
|||||||
using System.Linq;
|
using NFluent;
|
||||||
|
using RestEase;
|
||||||
|
using System.Linq;
|
||||||
using System.Net.Http;
|
using System.Net.Http;
|
||||||
using System.Net.Http.Headers;
|
using System.Net.Http.Headers;
|
||||||
using System.Threading.Tasks;
|
using System.Threading.Tasks;
|
||||||
using NFluent;
|
|
||||||
using RestEase;
|
|
||||||
using WireMock.Admin.Mappings;
|
using WireMock.Admin.Mappings;
|
||||||
using WireMock.Admin.Settings;
|
using WireMock.Admin.Settings;
|
||||||
using WireMock.Client;
|
using WireMock.Client;
|
||||||
@@ -19,7 +19,7 @@ namespace WireMock.Net.Tests
|
|||||||
[Fact]
|
[Fact]
|
||||||
public async Task IFluentMockServerAdmin_GetSettingsAsync()
|
public async Task IFluentMockServerAdmin_GetSettingsAsync()
|
||||||
{
|
{
|
||||||
// Assign
|
// Arrange
|
||||||
var server = FluentMockServer.StartWithAdminInterface();
|
var server = FluentMockServer.StartWithAdminInterface();
|
||||||
var api = RestClient.For<IFluentMockServerAdmin>(server.Urls[0]);
|
var api = RestClient.For<IFluentMockServerAdmin>(server.Urls[0]);
|
||||||
|
|
||||||
@@ -31,7 +31,7 @@ namespace WireMock.Net.Tests
|
|||||||
[Fact]
|
[Fact]
|
||||||
public async Task IFluentMockServerAdmin_PostSettingsAsync()
|
public async Task IFluentMockServerAdmin_PostSettingsAsync()
|
||||||
{
|
{
|
||||||
// Assign
|
// Arrange
|
||||||
var server = FluentMockServer.StartWithAdminInterface();
|
var server = FluentMockServer.StartWithAdminInterface();
|
||||||
var api = RestClient.For<IFluentMockServerAdmin>(server.Urls[0]);
|
var api = RestClient.For<IFluentMockServerAdmin>(server.Urls[0]);
|
||||||
|
|
||||||
@@ -44,7 +44,7 @@ namespace WireMock.Net.Tests
|
|||||||
[Fact]
|
[Fact]
|
||||||
public async Task IFluentMockServerAdmin_PutSettingsAsync()
|
public async Task IFluentMockServerAdmin_PutSettingsAsync()
|
||||||
{
|
{
|
||||||
// Assign
|
// Arrange
|
||||||
var server = FluentMockServer.StartWithAdminInterface();
|
var server = FluentMockServer.StartWithAdminInterface();
|
||||||
var api = RestClient.For<IFluentMockServerAdmin>(server.Urls[0]);
|
var api = RestClient.For<IFluentMockServerAdmin>(server.Urls[0]);
|
||||||
|
|
||||||
@@ -57,22 +57,15 @@ namespace WireMock.Net.Tests
|
|||||||
[Fact]
|
[Fact]
|
||||||
public async Task IFluentMockServerAdmin_PostMappingAsync()
|
public async Task IFluentMockServerAdmin_PostMappingAsync()
|
||||||
{
|
{
|
||||||
// Assign
|
// Arrange
|
||||||
var server = FluentMockServer.StartWithAdminInterface();
|
var server = FluentMockServer.StartWithAdminInterface();
|
||||||
var api = RestClient.For<IFluentMockServerAdmin>(server.Urls[0]);
|
var api = RestClient.For<IFluentMockServerAdmin>(server.Urls[0]);
|
||||||
|
|
||||||
// Act
|
// Act
|
||||||
var model = new MappingModel
|
var model = new MappingModel
|
||||||
{
|
{
|
||||||
Request = new RequestModel
|
Request = new RequestModel { Path = "/1" },
|
||||||
{
|
Response = new ResponseModel { Body = "txt", StatusCode = 200 },
|
||||||
Path = "/1"
|
|
||||||
},
|
|
||||||
Response = new ResponseModel
|
|
||||||
{
|
|
||||||
Body = "txt",
|
|
||||||
StatusCode = 200
|
|
||||||
},
|
|
||||||
Priority = 500,
|
Priority = 500,
|
||||||
Title = "test"
|
Title = "test"
|
||||||
};
|
};
|
||||||
@@ -90,10 +83,41 @@ namespace WireMock.Net.Tests
|
|||||||
server.Stop();
|
server.Stop();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
[Fact]
|
||||||
|
public async Task IFluentMockServerAdmin_PostMappingsAsync()
|
||||||
|
{
|
||||||
|
// Arrange
|
||||||
|
var server = FluentMockServer.StartWithAdminInterface();
|
||||||
|
var api = RestClient.For<IFluentMockServerAdmin>(server.Urls[0]);
|
||||||
|
|
||||||
|
// Act
|
||||||
|
var model1 = new MappingModel
|
||||||
|
{
|
||||||
|
Request = new RequestModel { Path = "/1" },
|
||||||
|
Response = new ResponseModel { Body = "txt 1" },
|
||||||
|
Title = "test 1"
|
||||||
|
};
|
||||||
|
var model2 = new MappingModel
|
||||||
|
{
|
||||||
|
Request = new RequestModel { Path = "/2" },
|
||||||
|
Response = new ResponseModel { Body = "txt 2" },
|
||||||
|
Title = "test 2"
|
||||||
|
};
|
||||||
|
var result = await api.PostMappingsAsync(new[] { model1, model2 });
|
||||||
|
|
||||||
|
// Assert
|
||||||
|
Check.That(result).IsNotNull();
|
||||||
|
Check.That(result.Status).IsNotNull();
|
||||||
|
Check.That(result.Guid).IsNull();
|
||||||
|
Check.That(server.Mappings.Where(m => !m.IsAdminInterface)).HasSize(2);
|
||||||
|
|
||||||
|
server.Stop();
|
||||||
|
}
|
||||||
|
|
||||||
[Fact]
|
[Fact]
|
||||||
public async Task IFluentMockServerAdmin_FindRequestsAsync()
|
public async Task IFluentMockServerAdmin_FindRequestsAsync()
|
||||||
{
|
{
|
||||||
// given
|
// Arrange
|
||||||
var server = FluentMockServer.Start(new FluentMockServerSettings
|
var server = FluentMockServer.Start(new FluentMockServerSettings
|
||||||
{
|
{
|
||||||
StartAdminInterface = true,
|
StartAdminInterface = true,
|
||||||
@@ -103,10 +127,10 @@ namespace WireMock.Net.Tests
|
|||||||
await new HttpClient().GetAsync(serverUrl + "/foo");
|
await new HttpClient().GetAsync(serverUrl + "/foo");
|
||||||
var api = RestClient.For<IFluentMockServerAdmin>(serverUrl);
|
var api = RestClient.For<IFluentMockServerAdmin>(serverUrl);
|
||||||
|
|
||||||
// when
|
// Act
|
||||||
var requests = await api.FindRequestsAsync(new RequestModel { Methods = new[] { "GET" } });
|
var requests = await api.FindRequestsAsync(new RequestModel { Methods = new[] { "GET" } });
|
||||||
|
|
||||||
// then
|
// Assert
|
||||||
Check.That(requests).HasSize(1);
|
Check.That(requests).HasSize(1);
|
||||||
var requestLogged = requests.First();
|
var requestLogged = requests.First();
|
||||||
Check.That(requestLogged.Request.Method).IsEqualTo("GET");
|
Check.That(requestLogged.Request.Method).IsEqualTo("GET");
|
||||||
@@ -117,7 +141,7 @@ namespace WireMock.Net.Tests
|
|||||||
[Fact]
|
[Fact]
|
||||||
public async Task IFluentMockServerAdmin_GetRequestsAsync()
|
public async Task IFluentMockServerAdmin_GetRequestsAsync()
|
||||||
{
|
{
|
||||||
// given
|
// Arrange
|
||||||
var server = FluentMockServer.Start(new FluentMockServerSettings
|
var server = FluentMockServer.Start(new FluentMockServerSettings
|
||||||
{
|
{
|
||||||
StartAdminInterface = true,
|
StartAdminInterface = true,
|
||||||
@@ -127,10 +151,10 @@ namespace WireMock.Net.Tests
|
|||||||
await new HttpClient().GetAsync(serverUrl + "/foo");
|
await new HttpClient().GetAsync(serverUrl + "/foo");
|
||||||
var api = RestClient.For<IFluentMockServerAdmin>(serverUrl);
|
var api = RestClient.For<IFluentMockServerAdmin>(serverUrl);
|
||||||
|
|
||||||
// when
|
// Act
|
||||||
var requests = await api.GetRequestsAsync();
|
var requests = await api.GetRequestsAsync();
|
||||||
|
|
||||||
// then
|
// Assert
|
||||||
Check.That(requests).HasSize(1);
|
Check.That(requests).HasSize(1);
|
||||||
var requestLogged = requests.First();
|
var requestLogged = requests.First();
|
||||||
Check.That(requestLogged.Request.Method).IsEqualTo("GET");
|
Check.That(requestLogged.Request.Method).IsEqualTo("GET");
|
||||||
@@ -141,7 +165,7 @@ namespace WireMock.Net.Tests
|
|||||||
[Fact]
|
[Fact]
|
||||||
public async Task IFluentMockServerAdmin_GetRequestsAsync_JsonApi()
|
public async Task IFluentMockServerAdmin_GetRequestsAsync_JsonApi()
|
||||||
{
|
{
|
||||||
// given
|
// Arrange
|
||||||
var server = FluentMockServer.Start(new FluentMockServerSettings
|
var server = FluentMockServer.Start(new FluentMockServerSettings
|
||||||
{
|
{
|
||||||
StartAdminInterface = true,
|
StartAdminInterface = true,
|
||||||
@@ -159,13 +183,14 @@ namespace WireMock.Net.Tests
|
|||||||
request.Content.Headers.ContentType = MediaTypeHeaderValue.Parse(jsonApiContentType);
|
request.Content.Headers.ContentType = MediaTypeHeaderValue.Parse(jsonApiContentType);
|
||||||
|
|
||||||
var response = await new HttpClient().SendAsync(request);
|
var response = await new HttpClient().SendAsync(request);
|
||||||
|
Check.That(response).IsNotNull();
|
||||||
|
|
||||||
var api = RestClient.For<IFluentMockServerAdmin>(serverUrl);
|
var api = RestClient.For<IFluentMockServerAdmin>(serverUrl);
|
||||||
|
|
||||||
// when
|
// Act
|
||||||
var requests = await api.GetRequestsAsync();
|
var requests = await api.GetRequestsAsync();
|
||||||
|
|
||||||
// then
|
// Assert
|
||||||
Check.That(requests).HasSize(1);
|
Check.That(requests).HasSize(1);
|
||||||
var requestLogged = requests.First();
|
var requestLogged = requests.First();
|
||||||
Check.That(requestLogged.Request.Method).IsEqualTo("POST");
|
Check.That(requestLogged.Request.Method).IsEqualTo("POST");
|
||||||
@@ -176,7 +201,7 @@ namespace WireMock.Net.Tests
|
|||||||
[Fact]
|
[Fact]
|
||||||
public async Task IFluentMockServerAdmin_GetRequestsAsync_Json()
|
public async Task IFluentMockServerAdmin_GetRequestsAsync_Json()
|
||||||
{
|
{
|
||||||
// given
|
// Arrange
|
||||||
var server = FluentMockServer.Start(new FluentMockServerSettings
|
var server = FluentMockServer.Start(new FluentMockServerSettings
|
||||||
{
|
{
|
||||||
StartAdminInterface = true,
|
StartAdminInterface = true,
|
||||||
@@ -193,13 +218,14 @@ namespace WireMock.Net.Tests
|
|||||||
request.Content = new StringContent(data);
|
request.Content = new StringContent(data);
|
||||||
request.Content.Headers.ContentType = MediaTypeHeaderValue.Parse(jsonApiContentType);
|
request.Content.Headers.ContentType = MediaTypeHeaderValue.Parse(jsonApiContentType);
|
||||||
var response = await new HttpClient().SendAsync(request);
|
var response = await new HttpClient().SendAsync(request);
|
||||||
|
Check.That(response).IsNotNull();
|
||||||
|
|
||||||
var api = RestClient.For<IFluentMockServerAdmin>(serverUrl);
|
var api = RestClient.For<IFluentMockServerAdmin>(serverUrl);
|
||||||
|
|
||||||
// when
|
// Act
|
||||||
var requests = await api.GetRequestsAsync();
|
var requests = await api.GetRequestsAsync();
|
||||||
|
|
||||||
// then
|
// Assert
|
||||||
Check.That(requests).HasSize(1);
|
Check.That(requests).HasSize(1);
|
||||||
var requestLogged = requests.First();
|
var requestLogged = requests.First();
|
||||||
Check.That(requestLogged.Request.Method).IsEqualTo("POST");
|
Check.That(requestLogged.Request.Method).IsEqualTo("POST");
|
||||||
|
|||||||
Reference in New Issue
Block a user