You've already forked linux-packaging-mono
data
debian
docs
eglib
external
Lucene.Net
Newtonsoft.Json
aspnetwebstack
packages
src
test
Microsoft.TestCommon
Microsoft.Web.Helpers.Test
Microsoft.Web.Http.Data.Test
Microsoft.Web.Mvc.Test
Microsoft.Web.WebPages.OAuth.Test
SPA.Test
System.Json.Test.Integration
System.Json.Test.Unit
System.Net.Http.Formatting.Test.Integration
System.Net.Http.Formatting.Test.Unit
System.Web.Helpers.Test
System.Web.Http.Integration.Test
System.Web.Http.SelfHost.Test
System.Web.Http.Test
Common
Controllers
Dispatcher
Filters
Hosting
Internal
Metadata
ModelBinding
Properties
Query
Routing
Services
Tracing
Tracers
ActionFilterAttributeTracerTest.cs
ActionFilterTracerTest.cs
ActionValueBinderTracerTest.cs
AuthorizationFilterAttributeTracerTest.cs
AuthorizationFilterTracerTest.cs
ContentNegotiatorTracerTest.cs
ExceptionFilterAttributeTracerTest.cs
ExceptionFilterTracerTest.cs
FilterTracerTest.cs
FormatterParameterBindingTracerTest.cs
HttpActionBindingTracerTest.cs
HttpActionDescriptorTracerTest.cs
HttpActionInvokerTracerTest.cs
HttpActionSelectorTracerTest.cs
HttpControllerActivatorTracerTest.cs
HttpControllerDescriptorTracerTest.cs
HttpControllerSelectorTracerTest.cs
HttpControllerTracerTest.cs
HttpParameterBindingTracerTest.cs
MediaTypeFormatterTracerTest.cs
MessageHandlerTracerTest.cs
RequestMessageHandlerTracerTest.cs
FormattingUtilitiesTest.cs
HttpRequestMessageExtensionsTest.cs
ITraceWriterExtensionsTest.cs
TestTraceWriter.cs
TraceManagerTest.cs
TraceRecordComparer.cs
Util
Validation
ValueProviders
AuthorizeAttributeTest.cs
DictionaryExtensionsTest.cs
HttpRequestMessageExtensionsTest.cs
HttpResponseExceptionTest.cs
HttpResponseMessageExtensionsTest.cs
HttpRouteCollectionExtensionsTest.cs
HttpServerTest.cs
QueryableAttributeTest.cs
System.Web.Http.Test.csproj
packages.config
System.Web.Http.WebHost.Test
System.Web.Mvc.Test
System.Web.Razor.Test
System.Web.WebPages.Administration.Test
System.Web.WebPages.Deployment.Test
System.Web.WebPages.Razor.Test
System.Web.WebPages.Test
WebMatrix.Data.Test
WebMatrix.WebData.Test
Settings.StyleCop
tools
.gitattributes
.gitignore
License.txt
README.md
Runtime.msbuild
Runtime.sln
Runtime.xunit
Settings.StyleCop
build.cmd
binary-reference-assemblies
cecil
debian-snapshot
ikdasm
ikvm
referencesource
rx
ikvm-native
libgc
m4
man
mcs
mono
msvc
po
runtime
samples
scripts
support
tools
AUTHORS
COPYING.LIB
ChangeLog.REMOVED.git-id
LICENSE
Makefile.am
Makefile.in
NEWS
README.md
acinclude.m4
aclocal.m4
autogen.sh
build-mingw32.sh
compile
config.guess
config.h.in
config.rpath
config.sub
configure.REMOVED.git-id
configure.ac.REMOVED.git-id
depcomp
install-sh
ltmain.sh.REMOVED.git-id
missing
mkinstalldirs
mono-core.spec
mono-core.spec.in
mono-uninstalled.pc.in
test-driver
winconfig.h
153 lines
7.3 KiB
C#
153 lines
7.3 KiB
C#
![]() |
// Copyright (c) Microsoft Corporation. All rights reserved. See License.txt in the project root for license information.
|
|||
|
|
|||
|
using System.Net.Http;
|
|||
|
using System.Reflection;
|
|||
|
using System.Threading;
|
|||
|
using System.Threading.Tasks;
|
|||
|
using Xunit;
|
|||
|
using Assert = Microsoft.TestCommon.AssertEx;
|
|||
|
|
|||
|
namespace System.Web.Http.Tracing.Tracers
|
|||
|
{
|
|||
|
public class RequestMessageHandlerTracerTest
|
|||
|
{
|
|||
|
[Fact]
|
|||
|
public void SendAsync_Traces_And_Invokes_Inner()
|
|||
|
{
|
|||
|
// Arrange
|
|||
|
HttpResponseMessage response = new HttpResponseMessage();
|
|||
|
TestTraceWriter traceWriter = new TestTraceWriter();
|
|||
|
RequestMessageHandlerTracer tracer = new RequestMessageHandlerTracer(traceWriter);
|
|||
|
MockHttpMessageHandler mockInnerHandler = new MockHttpMessageHandler((rqst, cancellation) =>
|
|||
|
TaskHelpers.FromResult<HttpResponseMessage>(response));
|
|||
|
tracer.InnerHandler = mockInnerHandler;
|
|||
|
|
|||
|
HttpRequestMessage request = new HttpRequestMessage();
|
|||
|
TraceRecord[] expectedTraces = new TraceRecord[]
|
|||
|
{
|
|||
|
new TraceRecord(request, TraceCategories.RequestCategory, TraceLevel.Info) { Kind = TraceKind.Begin },
|
|||
|
new TraceRecord(request, TraceCategories.RequestCategory, TraceLevel.Info) { Kind = TraceKind.End }
|
|||
|
};
|
|||
|
|
|||
|
MethodInfo method = typeof(DelegatingHandler).GetMethod("SendAsync",
|
|||
|
BindingFlags.Public | BindingFlags.NonPublic |
|
|||
|
BindingFlags.Instance);
|
|||
|
|
|||
|
// Act
|
|||
|
Task<HttpResponseMessage> task = method.Invoke(tracer, new object[] { request, CancellationToken.None }) as Task<HttpResponseMessage>;
|
|||
|
HttpResponseMessage actualResponse = task.Result;
|
|||
|
|
|||
|
// Assert
|
|||
|
Assert.Equal<TraceRecord>(expectedTraces, traceWriter.Traces, new TraceRecordComparer());
|
|||
|
Assert.Same(response, actualResponse);
|
|||
|
}
|
|||
|
|
|||
|
[Fact]
|
|||
|
public void SendAsync_Traces_And_Throws_When_Inner_Throws()
|
|||
|
{
|
|||
|
// Arrange
|
|||
|
InvalidOperationException exception = new InvalidOperationException("test");
|
|||
|
TestTraceWriter traceWriter = new TestTraceWriter();
|
|||
|
RequestMessageHandlerTracer tracer = new RequestMessageHandlerTracer(traceWriter);
|
|||
|
|
|||
|
// DelegatingHandlers require an InnerHandler to run. We create a mock one to simulate what
|
|||
|
// would happen when a DelegatingHandler executing after the tracer throws.
|
|||
|
MockHttpMessageHandler mockInnerHandler = new MockHttpMessageHandler((rqst, cancellation) => { throw exception; });
|
|||
|
tracer.InnerHandler = mockInnerHandler;
|
|||
|
|
|||
|
HttpRequestMessage request = new HttpRequestMessage();
|
|||
|
TraceRecord[] expectedTraces = new TraceRecord[]
|
|||
|
{
|
|||
|
new TraceRecord(request, TraceCategories.RequestCategory, TraceLevel.Info) { Kind = TraceKind.Begin },
|
|||
|
new TraceRecord(request, TraceCategories.RequestCategory, TraceLevel.Error) { Kind = TraceKind.End }
|
|||
|
};
|
|||
|
|
|||
|
MethodInfo method = typeof(DelegatingHandler).GetMethod("SendAsync",
|
|||
|
BindingFlags.Public | BindingFlags.NonPublic |
|
|||
|
BindingFlags.Instance);
|
|||
|
|
|||
|
// Act
|
|||
|
Exception thrown =
|
|||
|
Assert.Throws<TargetInvocationException>(
|
|||
|
() => method.Invoke(tracer, new object[] { request, CancellationToken.None }));
|
|||
|
|
|||
|
// Assert
|
|||
|
Assert.Equal<TraceRecord>(expectedTraces, traceWriter.Traces, new TraceRecordComparer());
|
|||
|
Assert.Same(exception, thrown.InnerException);
|
|||
|
Assert.Same(exception, traceWriter.Traces[1].Exception);
|
|||
|
}
|
|||
|
|
|||
|
[Fact]
|
|||
|
public void SendAsync_Traces_And_Faults_When_Inner_Faults()
|
|||
|
{
|
|||
|
// Arrange
|
|||
|
InvalidOperationException exception = new InvalidOperationException("test");
|
|||
|
TaskCompletionSource<HttpResponseMessage> tcs = new TaskCompletionSource<HttpResponseMessage>();
|
|||
|
tcs.TrySetException(exception);
|
|||
|
TestTraceWriter traceWriter = new TestTraceWriter();
|
|||
|
RequestMessageHandlerTracer tracer = new RequestMessageHandlerTracer(traceWriter);
|
|||
|
|
|||
|
// DelegatingHandlers require an InnerHandler to run. We create a mock one to simulate what
|
|||
|
// would happen when a DelegatingHandler executing after the tracer returns a Task that throws.
|
|||
|
MockHttpMessageHandler mockInnerHandler = new MockHttpMessageHandler((rqst, cancellation) => { return tcs.Task; });
|
|||
|
tracer.InnerHandler = mockInnerHandler;
|
|||
|
|
|||
|
HttpRequestMessage request = new HttpRequestMessage();
|
|||
|
TraceRecord[] expectedTraces = new TraceRecord[]
|
|||
|
{
|
|||
|
new TraceRecord(request, TraceCategories.RequestCategory, TraceLevel.Info) { Kind = TraceKind.Begin },
|
|||
|
new TraceRecord(request, TraceCategories.RequestCategory, TraceLevel.Error) { Kind = TraceKind.End }
|
|||
|
};
|
|||
|
|
|||
|
MethodInfo method = typeof(DelegatingHandler).GetMethod("SendAsync",
|
|||
|
BindingFlags.Public | BindingFlags.NonPublic |
|
|||
|
BindingFlags.Instance);
|
|||
|
|
|||
|
// Act
|
|||
|
Task<HttpResponseMessage> task =
|
|||
|
method.Invoke(tracer, new object[] { request, CancellationToken.None }) as Task<HttpResponseMessage>;
|
|||
|
|
|||
|
// Assert
|
|||
|
Exception thrown = Assert.Throws<InvalidOperationException>(() => task.Wait());
|
|||
|
Assert.Equal<TraceRecord>(expectedTraces, traceWriter.Traces, new TraceRecordComparer());
|
|||
|
Assert.Same(exception, thrown);
|
|||
|
Assert.Same(exception, traceWriter.Traces[1].Exception);
|
|||
|
}
|
|||
|
|
|||
|
|
|||
|
// DelegatingHandler cannot be mocked with Moq
|
|||
|
private class MockDelegatingHandler : DelegatingHandler
|
|||
|
{
|
|||
|
private Func<HttpRequestMessage, CancellationToken, Task<HttpResponseMessage>> _callback;
|
|||
|
|
|||
|
public MockDelegatingHandler(Func<HttpRequestMessage, CancellationToken, Task<HttpResponseMessage>> callback)
|
|||
|
: base()
|
|||
|
{
|
|||
|
_callback = callback;
|
|||
|
}
|
|||
|
|
|||
|
protected override Task<HttpResponseMessage> SendAsync(HttpRequestMessage request, CancellationToken cancellationToken)
|
|||
|
{
|
|||
|
return _callback(request, cancellationToken);
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
// HttpMessageHandler cannot be mocked with Moq
|
|||
|
private class MockHttpMessageHandler : HttpMessageHandler
|
|||
|
{
|
|||
|
private Func<HttpRequestMessage, CancellationToken, Task<HttpResponseMessage>> _callback;
|
|||
|
|
|||
|
public MockHttpMessageHandler(Func<HttpRequestMessage, CancellationToken, Task<HttpResponseMessage>> callback)
|
|||
|
: base()
|
|||
|
{
|
|||
|
_callback = callback;
|
|||
|
}
|
|||
|
|
|||
|
protected override Task<HttpResponseMessage> SendAsync(HttpRequestMessage request, CancellationToken cancellationToken)
|
|||
|
{
|
|||
|
return _callback(request, cancellationToken);
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
}
|