You've already forked linux-packaging-mono
acceptance-tests
data
debian
docs
external
Newtonsoft.Json
api-doc-tools
api-snapshot
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
bockbuild
boringssl
cecil
cecil-legacy
corefx
corert
ikdasm
ikvm
linker
nuget-buildtasks
nunit-lite
roslyn-binaries
rx
xunit-binaries
ikvm-native
libgc
llvm
m4
man
mcs
mono
msvc
po
runtime
samples
scripts
support
tools
COPYING.LIB
LICENSE
Makefile.am
Makefile.in
NEWS
README.md
acinclude.m4
aclocal.m4
autogen.sh
code_of_conduct.md
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-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);
|
|
}
|
|
}
|
|
}
|
|
}
|