mirror of
https://github.com/wiremock/WireMock.Net.git
synced 2026-01-11 21:10:32 +01:00
Fix FormUrlEncodedMatcher (MatchOperator.And) (#1157)
This commit is contained in:
@@ -45,7 +45,7 @@
|
|||||||
|
|
||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
<PackageReference Include="JetBrains.Annotations" Version="2023.3.0" PrivateAssets="All" />
|
<PackageReference Include="JetBrains.Annotations" Version="2023.3.0" PrivateAssets="All" />
|
||||||
<PackageReference Include="Microsoft.SourceLink.GitHub" Version="1.1.1" PrivateAssets="All" />
|
<PackageReference Include="Microsoft.SourceLink.GitHub" Version="8.0.0" PrivateAssets="All" />
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
|
|
||||||
<ItemGroup Condition=" '$(TargetFramework)' == 'net8.0' ">
|
<ItemGroup Condition=" '$(TargetFramework)' == 'net8.0' ">
|
||||||
|
|||||||
@@ -37,7 +37,6 @@
|
|||||||
|
|
||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
<PackageReference Include="Aspire.Hosting" Version="8.0.0" />
|
<PackageReference Include="Aspire.Hosting" Version="8.0.0" />
|
||||||
<PackageReference Include="Microsoft.SourceLink.GitHub" Version="8.0.0" PrivateAssets="All" />
|
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
|
|
||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
|
|||||||
@@ -1,6 +1,7 @@
|
|||||||
// Copyright © WireMock.Net
|
// Copyright © WireMock.Net
|
||||||
|
|
||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
|
using System.Linq;
|
||||||
using AnyOfTypes;
|
using AnyOfTypes;
|
||||||
using Stef.Validation;
|
using Stef.Validation;
|
||||||
using WireMock.Models;
|
using WireMock.Models;
|
||||||
@@ -27,7 +28,7 @@ public class FormUrlEncodedMatcher : IStringMatcher, IIgnoreCaseMatcher
|
|||||||
/// </summary>
|
/// </summary>
|
||||||
/// <param name="pattern">The pattern.</param>
|
/// <param name="pattern">The pattern.</param>
|
||||||
/// <param name="ignoreCase">Ignore the case from the pattern.</param>
|
/// <param name="ignoreCase">Ignore the case from the pattern.</param>
|
||||||
/// <param name="matchOperator">The <see cref="Matchers.MatchOperator"/> to use. (default = "Or")</param>
|
/// <param name="matchOperator">The <see cref="MatchOperator"/> to use. (default = "Or")</param>
|
||||||
public FormUrlEncodedMatcher(
|
public FormUrlEncodedMatcher(
|
||||||
AnyOf<string, StringPattern> pattern,
|
AnyOf<string, StringPattern> pattern,
|
||||||
bool ignoreCase = false,
|
bool ignoreCase = false,
|
||||||
@@ -42,7 +43,7 @@ public class FormUrlEncodedMatcher : IStringMatcher, IIgnoreCaseMatcher
|
|||||||
/// <param name="matchBehaviour">The match behaviour.</param>
|
/// <param name="matchBehaviour">The match behaviour.</param>
|
||||||
/// <param name="pattern">The pattern.</param>
|
/// <param name="pattern">The pattern.</param>
|
||||||
/// <param name="ignoreCase">Ignore the case from the pattern.</param>
|
/// <param name="ignoreCase">Ignore the case from the pattern.</param>
|
||||||
/// <param name="matchOperator">The <see cref="Matchers.MatchOperator"/> to use. (default = "Or")</param>
|
/// <param name="matchOperator">The <see cref="MatchOperator"/> to use. (default = "Or")</param>
|
||||||
public FormUrlEncodedMatcher(
|
public FormUrlEncodedMatcher(
|
||||||
MatchBehaviour matchBehaviour,
|
MatchBehaviour matchBehaviour,
|
||||||
AnyOf<string, StringPattern> pattern,
|
AnyOf<string, StringPattern> pattern,
|
||||||
@@ -57,7 +58,7 @@ public class FormUrlEncodedMatcher : IStringMatcher, IIgnoreCaseMatcher
|
|||||||
/// </summary>
|
/// </summary>
|
||||||
/// <param name="patterns">The patterns.</param>
|
/// <param name="patterns">The patterns.</param>
|
||||||
/// <param name="ignoreCase">Ignore the case from the pattern.</param>
|
/// <param name="ignoreCase">Ignore the case from the pattern.</param>
|
||||||
/// <param name="matchOperator">The <see cref="Matchers.MatchOperator"/> to use. (default = "Or")</param>
|
/// <param name="matchOperator">The <see cref="MatchOperator"/> to use. (default = "Or")</param>
|
||||||
public FormUrlEncodedMatcher(
|
public FormUrlEncodedMatcher(
|
||||||
AnyOf<string, StringPattern>[] patterns,
|
AnyOf<string, StringPattern>[] patterns,
|
||||||
bool ignoreCase = false,
|
bool ignoreCase = false,
|
||||||
@@ -72,7 +73,7 @@ public class FormUrlEncodedMatcher : IStringMatcher, IIgnoreCaseMatcher
|
|||||||
/// <param name="matchBehaviour">The match behaviour.</param>
|
/// <param name="matchBehaviour">The match behaviour.</param>
|
||||||
/// <param name="patterns">The patterns.</param>
|
/// <param name="patterns">The patterns.</param>
|
||||||
/// <param name="ignoreCase">Ignore the case from the pattern.</param>
|
/// <param name="ignoreCase">Ignore the case from the pattern.</param>
|
||||||
/// <param name="matchOperator">The <see cref="Matchers.MatchOperator"/> to use. (default = "Or")</param>
|
/// <param name="matchOperator">The <see cref="MatchOperator"/> to use. (default = "Or")</param>
|
||||||
public FormUrlEncodedMatcher(
|
public FormUrlEncodedMatcher(
|
||||||
MatchBehaviour matchBehaviour,
|
MatchBehaviour matchBehaviour,
|
||||||
AnyOf<string, StringPattern>[] patterns,
|
AnyOf<string, StringPattern>[] patterns,
|
||||||
@@ -112,7 +113,20 @@ public class FormUrlEncodedMatcher : IStringMatcher, IIgnoreCaseMatcher
|
|||||||
return new MatchResult(MatchScores.Mismatch);
|
return new MatchResult(MatchScores.Mismatch);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
var matches = GetMatches(inputNameValueCollection);
|
||||||
|
|
||||||
|
var score = MatchScores.ToScore(matches, MatchOperator);
|
||||||
|
return new MatchResult(MatchBehaviourHelper.Convert(MatchBehaviour, score));
|
||||||
|
}
|
||||||
|
|
||||||
|
private bool[] GetMatches(IDictionary<string, string> inputNameValueCollection)
|
||||||
|
{
|
||||||
var matches = new List<bool>();
|
var matches = new List<bool>();
|
||||||
|
if (_pairs.Count > inputNameValueCollection.Count)
|
||||||
|
{
|
||||||
|
matches.AddRange(Enumerable.Repeat(false, _pairs.Count - inputNameValueCollection.Count));
|
||||||
|
}
|
||||||
|
|
||||||
foreach (var inputKeyValuePair in inputNameValueCollection)
|
foreach (var inputKeyValuePair in inputNameValueCollection)
|
||||||
{
|
{
|
||||||
var match = false;
|
var match = false;
|
||||||
@@ -132,8 +146,7 @@ public class FormUrlEncodedMatcher : IStringMatcher, IIgnoreCaseMatcher
|
|||||||
matches.Add(match);
|
matches.Add(match);
|
||||||
}
|
}
|
||||||
|
|
||||||
var score = MatchScores.ToScore(matches.ToArray(), MatchOperator);
|
return matches.ToArray();
|
||||||
return new MatchResult(MatchBehaviourHelper.Convert(MatchBehaviour, score));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <inheritdoc />
|
/// <inheritdoc />
|
||||||
|
|||||||
@@ -75,4 +75,25 @@ public class FormUrlEncodedMatcherTest
|
|||||||
// Assert
|
// Assert
|
||||||
score.Should().Be(expected);
|
score.Should().Be(expected);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
[Fact]
|
||||||
|
public async Task FormUrlEncodedMatcher_IsMatch_And_MatchAllProperties()
|
||||||
|
{
|
||||||
|
// Arrange
|
||||||
|
var content = new FormUrlEncodedContent(new[]
|
||||||
|
{
|
||||||
|
new KeyValuePair<string, string>("name", "John Doe"),
|
||||||
|
new KeyValuePair<string, string>("email", "johndoe@example.com")
|
||||||
|
});
|
||||||
|
var contentAsString = await content.ReadAsStringAsync();
|
||||||
|
|
||||||
|
// The expectation is that the matcher requires all properties to be present in the content.
|
||||||
|
var matcher = new FormUrlEncodedMatcher(["name=*", "email=*", "required=*"], matchOperator: MatchOperator.And);
|
||||||
|
|
||||||
|
// Act
|
||||||
|
var score = matcher.IsMatch(contentAsString).IsPerfect();
|
||||||
|
|
||||||
|
// Assert
|
||||||
|
score.Should().BeFalse();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
Reference in New Issue
Block a user