Compare commits

...

1 Commits

Author SHA1 Message Date
Stef Heyenrath
43177d45c3 wip 2018-11-22 16:44:14 +01:00
4 changed files with 78 additions and 35 deletions

View File

@@ -0,0 +1,32 @@
using CommandLineParser.Arguments;
namespace WireMock.Net.StandAlone
{
public class CommandLineArguments
{
[ValueArgument(typeof(bool), "StartAdminInterface", DefaultValue = true, Description = "Start the AdminInterface")]
public bool StartAdminInterface { get; set; }
[ValueArgument(typeof(bool), "ReadStaticMappings", DefaultValue = false, Description = "Read StaticMappings")]
public bool ReadStaticMappings { get; set; }
[ValueArgument(typeof(bool), 'w', "WatchStaticMappings", DefaultValue = false, Description = "Watch the static mapping files + folder for changes when running.")]
public bool WatchStaticMappings { get; set; }
[ValueArgument(typeof(bool), 'm', "AllowPartialMapping", DefaultValue = false, Description = "Allow PartialMapping")]
public bool AllowPartialMapping { get; set; }
[ValueArgument(typeof(string), 'u', "AdminUsername", Description = "The username needed for __admin access.")]
public string AdminUsername { get; set; }
[ValueArgument(typeof(string), 'p', "AdminPassword", Description = "The password needed for __admin access.")]
public string AdminPassword { get; set; }
[BoundedValueArgument(typeof(int), 'o', "MaxRequestLogCount", MinValue = 0, Description = "The Maximum number of RequestLogs to keep")]
public int MaxRequestLogCount { get; set; }
[BoundedValueArgument(typeof(int), 'x', "RequestLogExpirationDuration", MinValue = 0, Description = "The RequestLog Expiration Duration in hours")]
public int RequestLogExpirationDuration { get; set; }
}
}

View File

@@ -38,8 +38,9 @@ namespace WireMock.Net.StandAlone
{
Check.NotNull(args, nameof(args));
var parser = new SimpleCommandLineParser();
parser.Parse(args);
var parser = new CommandLineParser.CommandLineParser();
var p = new CommandLineArguments();
parser.ExtractArgumentAttributes(p);
var settings = new FluentMockServerSettings
{

View File

@@ -41,6 +41,11 @@
</PropertyGroup>
<ItemGroup>
<Compile Remove="SimpleCommandLineParser.cs" />
</ItemGroup>
<ItemGroup>
<PackageReference Include="CommandLineArgumentsParser" Version="3.0.19" />
<PackageReference Include="JetBrains.Annotations" Version="2018.2.1">
<PrivateAssets>All</PrivateAssets>
</PackageReference>

View File

@@ -102,6 +102,14 @@ namespace WireMock.Serialization
mappingModel.Response.Headers = Map(response.ResponseMessage.Headers);
mappingModel.Response.UseTransformer = response.UseTransformer;
MapBodyData(response, mappingModel);
}
return mappingModel;
}
private static void MapBodyData(Response response, MappingModel mappingModel)
{
if (response.ResponseMessage.BodyData != null)
{
switch (response.ResponseMessage.BodyData?.DetectedBodyType)
@@ -137,9 +145,6 @@ namespace WireMock.Serialization
}
}
return mappingModel;
}
private static IDictionary<string, object> Map(IDictionary<string, WireMockList<string>> dictionary)
{
if (dictionary == null || dictionary.Count == 0)