mirror of
https://github.com/wiremock/WireMock.Net.git
synced 2026-01-16 07:06:54 +01:00
* Add TIOBE + include SonarAnalyzer.CSharp * . * cp * Copyright © WireMock.Net * more fixes * fix * xpath * if (Matchers == null || !Matchers.Any()) * if (Matchers != null) * ? * . * .
39 lines
1.5 KiB
C#
39 lines
1.5 KiB
C#
// Copyright © WireMock.Net
|
|
|
|
using System;
|
|
using System.Linq;
|
|
using FluentAssertions;
|
|
using FluentAssertions.Execution;
|
|
using WireMock.FluentAssertions;
|
|
|
|
namespace WireMock.Net.Tests.FluentAssertions;
|
|
|
|
public static class WireMockAssertionsExtensions
|
|
{
|
|
[CustomAssertion]
|
|
public static AndWhichConstraint<WireMockAssertions, string> AtAbsoluteUrl2(this WireMockAssertions assertions,
|
|
string absoluteUrl, string because = "", params object[] becauseArgs)
|
|
{
|
|
var (filter, condition) = assertions.BuildFilterAndCondition(request => string.Equals(request.AbsoluteUrl, absoluteUrl, StringComparison.OrdinalIgnoreCase));
|
|
|
|
Execute.Assertion
|
|
.BecauseOf(because, becauseArgs)
|
|
.Given(() => assertions.RequestMessages)
|
|
.ForCondition(requests => assertions.CallsCount == 0 || requests.Any())
|
|
.FailWith(
|
|
"Expected {context:wiremockserver} to have been called at address matching the absolute url {0}{reason}, but no calls were made.",
|
|
absoluteUrl
|
|
)
|
|
.Then
|
|
.ForCondition(condition)
|
|
.FailWith(
|
|
"Expected {context:wiremockserver} to have been called at address matching the absolute url {0}{reason}, but didn't find it among the calls to {1}.",
|
|
_ => absoluteUrl,
|
|
requests => requests.Select(request => request.AbsoluteUrl)
|
|
);
|
|
|
|
assertions.FilterRequestMessages(filter);
|
|
|
|
return new AndWhichConstraint<WireMockAssertions, string>(assertions, absoluteUrl);
|
|
}
|
|
} |