mirror of
https://github.com/wiremock/WireMock.Net.git
synced 2026-01-17 00:46:54 +01:00
* Fix recorded requests skipped request logger. - When proxy is enabled the recorded requests are mistaken (IMO) for admin requests and skipped * Add unit test * Use different solution * Introduce IsRecordedByProxy property on Mapping class * Cleanup empty lines * Refactored fix suggested way
105 lines
3.1 KiB
C#
105 lines
3.1 KiB
C#
using JetBrains.Annotations;
|
|
using System;
|
|
using System.Threading.Tasks;
|
|
using WireMock.Matchers.Request;
|
|
using WireMock.ResponseProviders;
|
|
using WireMock.Settings;
|
|
|
|
namespace WireMock
|
|
{
|
|
/// <summary>
|
|
/// The IMapping interface.
|
|
/// </summary>
|
|
public interface IMapping
|
|
{
|
|
/// <summary>
|
|
/// Gets the unique identifier.
|
|
/// </summary>
|
|
Guid Guid { get; }
|
|
|
|
/// <summary>
|
|
/// Gets the unique title.
|
|
/// </summary>
|
|
string Title { get; }
|
|
|
|
/// <summary>
|
|
/// The full filename path for this mapping (only defined for static mappings).
|
|
/// </summary>
|
|
string Path { get; set; }
|
|
|
|
/// <summary>
|
|
/// Gets the priority.
|
|
/// </summary>
|
|
int Priority { get; }
|
|
|
|
/// <summary>
|
|
/// Scenario.
|
|
/// </summary>
|
|
[CanBeNull]
|
|
string Scenario { get; }
|
|
|
|
/// <summary>
|
|
/// Execution state condition for the current mapping.
|
|
/// </summary>
|
|
[CanBeNull]
|
|
string ExecutionConditionState { get; }
|
|
|
|
/// <summary>
|
|
/// The next state which will be signaled after the current mapping execution.
|
|
/// In case the value is null, state will not be changed.
|
|
/// </summary>
|
|
[CanBeNull]
|
|
string NextState { get; }
|
|
|
|
/// <summary>
|
|
/// The Request matcher.
|
|
/// </summary>
|
|
IRequestMatcher RequestMatcher { get; }
|
|
|
|
/// <summary>
|
|
/// The Provider.
|
|
/// </summary>
|
|
IResponseProvider Provider { get; }
|
|
|
|
/// <summary>
|
|
/// The FluentMockServerSettings.
|
|
/// </summary>
|
|
IFluentMockServerSettings Settings { get; }
|
|
|
|
/// <summary>
|
|
/// Is State started ?
|
|
/// </summary>
|
|
bool IsStartState { get; }
|
|
|
|
/// <summary>
|
|
/// Gets a value indicating whether this mapping is an Admin Interface.
|
|
/// </summary>
|
|
/// <value>
|
|
/// <c>true</c> if this mapping is an Admin Interface; otherwise, <c>false</c>.
|
|
/// </value>
|
|
bool IsAdminInterface { get; }
|
|
|
|
/// <summary>
|
|
/// Gets a value indicating whether this mapping to be logged.
|
|
/// </summary>
|
|
/// <value>
|
|
/// <c>true</c> if this mapping to be logged; otherwise, <c>false</c>.
|
|
/// </value>
|
|
bool LogMapping { get; }
|
|
|
|
/// <summary>
|
|
/// ProvideResponseAsync
|
|
/// </summary>
|
|
/// <param name="requestMessage">The request message.</param>
|
|
/// <returns>The <see cref="ResponseMessage"/>.</returns>
|
|
Task<ResponseMessage> ProvideResponseAsync(RequestMessage requestMessage);
|
|
|
|
/// <summary>
|
|
/// Gets the RequestMatchResult based on the RequestMessage.
|
|
/// </summary>
|
|
/// <param name="requestMessage">The request message.</param>
|
|
/// <param name="nextState">The Next State.</param>
|
|
/// <returns>The <see cref="RequestMatchResult"/>.</returns>
|
|
RequestMatchResult GetRequestMatchResult(RequestMessage requestMessage, [CanBeNull] string nextState);
|
|
}
|
|
} |