mirror of
https://github.com/wiremock/WireMock.Net.git
synced 2026-03-12 21:35:55 +01:00
* Version 2.x * Setup .NET 9 * 12 * cleanup some #if for NETSTANDARD1_3 * cleanup + fix tests for net8 * openapi * NO ConfigureAwait(false) + cleanup * . * #endif * HashSet * WireMock.Net.NUnit * HttpContext * Add WebSockets (#1423) * Add WebSockets * Add tests * fix * more tests * Add tests * ... * remove IOwin * - * tests * fluent * ok * match * . * byte[] * x * func * func * byte * trans * ... * frameworks......... * jmes * xxx * sc * using var httpClient = new HttpClient(); * usings * maxRetries * up * xunit v3 * ct * --- * ct * ct2 * T Unit * WireMock.Net.TUnitTests / 10 * t unit first * --project * no tunit * t2 * --project * --project * ci - --project * publish ./test/wiremock-coverage.xml * windows * . * log * ... * log * goed * BodyType * . * . * --scenario * ... * pact * ct * . * WireMock.Net.RestClient.AwesomeAssertions (#1427) * WireMock.Net.RestClient.AwesomeAssertions * ok * atpath * fix test * sonar fixes * ports * proxy test * FIX? * --- * await Task.Delay(100, _ct); * ? * --project * Aspire: use IDistributedApplicationEventingSubscriber (#1428) * broadcast * ok * more tsts * . * Collection * up * . * 2 * remove nfluent * <VersionPrefix>2.0.0-preview-02</VersionPrefix> * ... * . * nuget icon * . * <PackageReference Include="JmesPath.Net" Version="1.1.0" /> * x * 500 * . * fix some warnings * ws
119 lines
3.4 KiB
C#
119 lines
3.4 KiB
C#
// Copyright © WireMock.Net
|
|
|
|
using System.Text.RegularExpressions;
|
|
using AnyOfTypes;
|
|
using Newtonsoft.Json;
|
|
using WireMock.Matchers;
|
|
using WireMock.Models;
|
|
|
|
namespace WireMock.Net.Tests.Serialization;
|
|
|
|
/// <summary>
|
|
/// This matcher is only for unit test purposes
|
|
/// </summary>
|
|
public class CustomPathParamMatcher : IStringMatcher
|
|
{
|
|
public string Name => nameof(CustomPathParamMatcher);
|
|
|
|
public MatchBehaviour MatchBehaviour { get; }
|
|
|
|
private readonly string _path;
|
|
private readonly string[] _pathParts;
|
|
private readonly Dictionary<string, string> _pathParams;
|
|
|
|
public CustomPathParamMatcher(string path, Dictionary<string, string> pathParams) : this(MatchBehaviour.AcceptOnMatch, path, pathParams)
|
|
{
|
|
}
|
|
|
|
public CustomPathParamMatcher(
|
|
MatchBehaviour matchBehaviour,
|
|
string path,
|
|
Dictionary<string, string> pathParams,
|
|
MatchOperator matchOperator = MatchOperator.Or)
|
|
{
|
|
MatchBehaviour = matchBehaviour;
|
|
_path = path;
|
|
_pathParts = GetPathParts(path);
|
|
_pathParams = pathParams.ToDictionary(x => x.Key, x => x.Value, StringComparer.OrdinalIgnoreCase);
|
|
MatchOperator = matchOperator;
|
|
}
|
|
|
|
public MatchResult IsMatch(string? input)
|
|
{
|
|
var inputParts = GetPathParts(input);
|
|
if (inputParts.Length != _pathParts.Length)
|
|
{
|
|
return MatchResult.From(Name);
|
|
}
|
|
|
|
try
|
|
{
|
|
for (int i = 0; i < inputParts.Length; i++)
|
|
{
|
|
var inputPart = inputParts[i];
|
|
var pathPart = _pathParts[i];
|
|
if (pathPart.StartsWith("{") && pathPart.EndsWith("}"))
|
|
{
|
|
var pathParamName = pathPart.Trim('{').Trim('}');
|
|
if (!_pathParams.ContainsKey(pathParamName))
|
|
{
|
|
return MatchResult.From(Name);
|
|
}
|
|
|
|
if (!Regex.IsMatch(inputPart, _pathParams[pathParamName], RegexOptions.IgnoreCase))
|
|
{
|
|
return MatchResult.From(Name);
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (!inputPart.Equals(pathPart, StringComparison.InvariantCultureIgnoreCase))
|
|
{
|
|
return MatchResult.From(Name);
|
|
}
|
|
}
|
|
}
|
|
}
|
|
catch
|
|
{
|
|
return MatchResult.From(Name);
|
|
}
|
|
|
|
return MatchResult.From(Name, MatchScores.Perfect);
|
|
}
|
|
|
|
public AnyOf<string, StringPattern>[] GetPatterns()
|
|
{
|
|
return new[] { new AnyOf<string, StringPattern>(JsonConvert.SerializeObject(new CustomPathParamMatcherModel(_path, _pathParams))) };
|
|
}
|
|
|
|
public MatchOperator MatchOperator { get; }
|
|
|
|
/// <inheritdoc />
|
|
public string GetCSharpCodeArguments()
|
|
{
|
|
return "// TODO: CustomPathParamMatcher";
|
|
}
|
|
|
|
private static string[] GetPathParts(string? path)
|
|
{
|
|
if (path is null)
|
|
{
|
|
return [];
|
|
}
|
|
|
|
var hashMarkIndex = path.IndexOf('#');
|
|
if (hashMarkIndex != -1)
|
|
{
|
|
path = path.Substring(0, hashMarkIndex);
|
|
}
|
|
|
|
var queryParamsIndex = path.IndexOf('?');
|
|
if (queryParamsIndex != -1)
|
|
{
|
|
path = path.Substring(0, queryParamsIndex);
|
|
}
|
|
|
|
return path.Trim().Trim('/').ToLower().Split('/');
|
|
}
|
|
} |