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
helix-binaries
ikdasm
ikvm
illinker-test-assets
linker
llvm
nuget-buildtasks
nunit-lite
roslyn-binaries
rx
xunit-binaries
how-to-bump-roslyn-binaries.md
ikvm-native
libgc
llvm
m4
man
mcs
mk
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
124 lines
6.7 KiB
C#
124 lines
6.7 KiB
C#
// Copyright (c) Microsoft Corporation. All rights reserved. See License.txt in the project root for license information.
|
|
|
|
using System.Threading;
|
|
using System.Threading.Tasks;
|
|
using System.Web.Http.Controllers;
|
|
using System.Web.Http.Metadata;
|
|
using System.Web.Http.Metadata.Providers;
|
|
using Moq;
|
|
using Xunit;
|
|
using Assert = Microsoft.TestCommon.AssertEx;
|
|
|
|
namespace System.Web.Http.Tracing.Tracers
|
|
{
|
|
public class HttpParameterBindingTracerTest
|
|
{
|
|
[Fact]
|
|
public void ExecuteBindingAsync_Traces_And_Invokes_Inner()
|
|
{
|
|
// Arrange
|
|
Mock<HttpParameterDescriptor> mockParamDescriptor = new Mock<HttpParameterDescriptor>() { CallBase = true };
|
|
mockParamDescriptor.Setup(d => d.ParameterName).Returns("paramName");
|
|
mockParamDescriptor.Setup(d => d.ParameterType).Returns(typeof(string));
|
|
Mock<HttpParameterBinding> mockBinding = new Mock<HttpParameterBinding>(mockParamDescriptor.Object) { CallBase = true };
|
|
bool innerInvoked = false;
|
|
mockBinding.Setup(
|
|
b =>
|
|
b.ExecuteBindingAsync(It.IsAny<ModelMetadataProvider>(), It.IsAny<HttpActionContext>(),
|
|
It.IsAny<CancellationToken>())).Returns(TaskHelpers.Completed()).Callback(() => innerInvoked = true);
|
|
|
|
TestTraceWriter traceWriter = new TestTraceWriter();
|
|
HttpParameterBindingTracer tracer = new HttpParameterBindingTracer(mockBinding.Object, traceWriter);
|
|
HttpActionContext actionContext = ContextUtil.CreateActionContext();
|
|
ModelMetadataProvider metadataProvider = new EmptyModelMetadataProvider();
|
|
|
|
TraceRecord[] expectedTraces = new TraceRecord[]
|
|
{
|
|
new TraceRecord(actionContext.Request, TraceCategories.ModelBindingCategory, TraceLevel.Info) { Kind = TraceKind.Begin, Operation = "ExecuteBindingAsync" },
|
|
new TraceRecord(actionContext.Request, TraceCategories.ModelBindingCategory, TraceLevel.Info) { Kind = TraceKind.End, Operation = "ExecuteBindingAsync" }
|
|
};
|
|
|
|
// Act
|
|
Task task = tracer.ExecuteBindingAsync(metadataProvider, actionContext, CancellationToken.None);
|
|
task.Wait();
|
|
|
|
// Assert
|
|
Assert.Equal<TraceRecord>(expectedTraces, traceWriter.Traces, new TraceRecordComparer());
|
|
Assert.True(innerInvoked);
|
|
}
|
|
|
|
[Fact]
|
|
public void ExecuteBindingAsync_Traces_And_Throws_When_Inner_Throws()
|
|
{
|
|
// Arrange
|
|
Mock<HttpParameterDescriptor> mockParamDescriptor = new Mock<HttpParameterDescriptor>() { CallBase = true };
|
|
mockParamDescriptor.Setup(d => d.ParameterName).Returns("paramName");
|
|
mockParamDescriptor.Setup(d => d.ParameterType).Returns(typeof(string));
|
|
Mock<HttpParameterBinding> mockBinding = new Mock<HttpParameterBinding>(mockParamDescriptor.Object) { CallBase = true };
|
|
InvalidOperationException exception = new InvalidOperationException("test");
|
|
mockBinding.Setup(
|
|
b =>
|
|
b.ExecuteBindingAsync(It.IsAny<ModelMetadataProvider>(), It.IsAny<HttpActionContext>(),
|
|
It.IsAny<CancellationToken>())).Throws(exception);
|
|
|
|
TestTraceWriter traceWriter = new TestTraceWriter();
|
|
HttpParameterBindingTracer tracer = new HttpParameterBindingTracer(mockBinding.Object, traceWriter);
|
|
HttpActionContext actionContext = ContextUtil.CreateActionContext();
|
|
ModelMetadataProvider metadataProvider = new EmptyModelMetadataProvider();
|
|
|
|
TraceRecord[] expectedTraces = new TraceRecord[]
|
|
{
|
|
new TraceRecord(actionContext.Request, TraceCategories.ModelBindingCategory, TraceLevel.Info) { Kind = TraceKind.Begin, Operation = "ExecuteBindingAsync" },
|
|
new TraceRecord(actionContext.Request, TraceCategories.ModelBindingCategory, TraceLevel.Error) { Kind = TraceKind.End, Operation = "ExecuteBindingAsync" }
|
|
};
|
|
|
|
// Act & Assert
|
|
Exception thrown = Assert.Throws<InvalidOperationException>(() => tracer.ExecuteBindingAsync(metadataProvider, actionContext, CancellationToken.None));
|
|
|
|
// Assert
|
|
Assert.Same(exception, thrown);
|
|
Assert.Same(exception, traceWriter.Traces[1].Exception);
|
|
Assert.Equal<TraceRecord>(expectedTraces, traceWriter.Traces, new TraceRecordComparer());
|
|
}
|
|
|
|
[Fact]
|
|
public void ExecuteBindingAsync_Traces_And_Faults_When_Inner_Faults()
|
|
{
|
|
// Arrange
|
|
|
|
Mock<HttpParameterDescriptor> mockParamDescriptor = new Mock<HttpParameterDescriptor>() { CallBase = true };
|
|
mockParamDescriptor.Setup(d => d.ParameterName).Returns("paramName");
|
|
mockParamDescriptor.Setup(d => d.ParameterType).Returns(typeof(string));
|
|
Mock<HttpParameterBinding> mockBinding = new Mock<HttpParameterBinding>(mockParamDescriptor.Object) { CallBase = true };
|
|
InvalidOperationException exception = new InvalidOperationException("test");
|
|
TaskCompletionSource<object> tcs = new TaskCompletionSource<object>();
|
|
tcs.TrySetException(exception);
|
|
|
|
mockBinding.Setup(
|
|
b =>
|
|
b.ExecuteBindingAsync(It.IsAny<ModelMetadataProvider>(), It.IsAny<HttpActionContext>(),
|
|
It.IsAny<CancellationToken>())).Returns(tcs.Task);
|
|
|
|
TestTraceWriter traceWriter = new TestTraceWriter();
|
|
HttpParameterBindingTracer tracer = new HttpParameterBindingTracer(mockBinding.Object, traceWriter);
|
|
HttpActionContext actionContext = ContextUtil.CreateActionContext();
|
|
ModelMetadataProvider metadataProvider = new EmptyModelMetadataProvider();
|
|
|
|
TraceRecord[] expectedTraces = new TraceRecord[]
|
|
{
|
|
new TraceRecord(actionContext.Request, TraceCategories.ModelBindingCategory, TraceLevel.Info) { Kind = TraceKind.Begin, Operation = "ExecuteBindingAsync" },
|
|
new TraceRecord(actionContext.Request, TraceCategories.ModelBindingCategory, TraceLevel.Error) { Kind = TraceKind.End, Operation = "ExecuteBindingAsync" }
|
|
};
|
|
|
|
// Act & Assert
|
|
Task task = tracer.ExecuteBindingAsync(metadataProvider, actionContext, CancellationToken.None);
|
|
|
|
// Assert
|
|
Exception thrown = Assert.Throws<InvalidOperationException>(() => task.Wait());
|
|
Assert.Same(exception, thrown);
|
|
Assert.Same(exception, traceWriter.Traces[1].Exception);
|
|
Assert.Equal<TraceRecord>(expectedTraces, traceWriter.Traces, new TraceRecordComparer());
|
|
}
|
|
}
|
|
}
|