public async Task Should_send_context_to_next_pipe() { // Arrange. var mockConsumeContext = new Mock <ConsumeContext <PingMessage> >(); mockConsumeContext.Setup(c => c.Headers).Returns(_mockHeaders.Object); mockConsumeContext.Setup(c => c.ReceiveContext).Returns(_mockReceiveContext.Object); var filter = new ApplicationInsightsConsumeFilter <PingMessage>(new TelemetryClient(), "", "", null); var mockPipe = new Mock <IPipe <ConsumeContext <PingMessage> > >(); // Act. await filter.Send(mockConsumeContext.Object, mockPipe.Object); // Assert. mockPipe.Verify(action => action.Send(mockConsumeContext.Object), Times.Once); }
public async Task Should_invoke_the_configure_operation() { // Arrange. var mockConsumeContext = new Mock <ConsumeContext <PingMessage> >(); mockConsumeContext.Setup(c => c.Headers).Returns(_mockHeaders.Object); mockConsumeContext.Setup(c => c.ReceiveContext).Returns(_mockReceiveContext.Object); bool configureOperationHasBeenCalled = false; var filter = new ApplicationInsightsConsumeFilter <PingMessage>(new TelemetryClient(), "", "", (holder, context) => configureOperationHasBeenCalled = true); // Act. await filter.Send(mockConsumeContext.Object, new Mock <IPipe <ConsumeContext <PingMessage> > >().Object); // Assert. Assert.IsTrue(configureOperationHasBeenCalled); }
public async Task Should_add_the_expected_properties_to_the_dependency_telemetry() { // Arrange. var messageId = Guid.NewGuid(); var conversationId = Guid.NewGuid(); var correlationId = Guid.NewGuid(); var requestId = Guid.NewGuid(); var inputAddress = new Uri("http://masstransit-project.com/"); var destinationAddress = new Uri("sb://my-organization.servicebus.windows.net/MyNamespace/MyMessage"); var mockReceiveContext = new Mock <ReceiveContext>(); mockReceiveContext.Setup(c => c.InputAddress).Returns(inputAddress); var mockConsumeContext = new Mock <ConsumeContext <PingMessage> >(); mockConsumeContext.Setup(c => c.ReceiveContext).Returns(mockReceiveContext.Object); mockConsumeContext.Setup(c => c.Headers).Returns(_mockHeaders.Object); mockConsumeContext.Setup(c => c.MessageId).Returns(messageId); mockConsumeContext.Setup(c => c.ConversationId).Returns(conversationId); mockConsumeContext.Setup(c => c.CorrelationId).Returns(correlationId); mockConsumeContext.Setup(c => c.RequestId).Returns(requestId); mockConsumeContext.Setup(c => c.DestinationAddress).Returns(destinationAddress); var consumeContextProxy = new ConsumeContextProxy <PingMessage>(mockConsumeContext.Object, new Mock <IPayloadCache>().Object); var capturedRequestTelemetry = default(RequestTelemetry); var filter = new ApplicationInsightsConsumeFilter <PingMessage>(new TelemetryClient(), "", "", (holder, context) => capturedRequestTelemetry = holder.Telemetry); // Act. await filter.Send(consumeContextProxy, new Mock <IPipe <ConsumeContext <PingMessage> > >().Object); // Assert. Assert.IsNotNull(capturedRequestTelemetry); Assert.AreEqual(capturedRequestTelemetry.Properties["MessageId"], messageId.ToString()); Assert.AreEqual(capturedRequestTelemetry.Properties["MessageType"], TypeMetadataCache <PingMessage> .ShortName); Assert.AreEqual(capturedRequestTelemetry.Properties["ConversationId"], conversationId.ToString()); Assert.AreEqual(capturedRequestTelemetry.Properties["CorrelationId"], correlationId.ToString()); Assert.AreEqual(capturedRequestTelemetry.Properties["DestinationAddress"], destinationAddress.ToString()); Assert.AreEqual(capturedRequestTelemetry.Properties["InputAddress"], inputAddress.ToString()); Assert.AreEqual(capturedRequestTelemetry.Properties["RequestId"], requestId.ToString()); }
public async Task Should_not_fail_if_properties_are_already_defined() { var messageId = Guid.NewGuid(); var conversationId = Guid.NewGuid(); var correlationId = Guid.NewGuid(); var requestId = Guid.NewGuid(); var inputAddress = new Uri("http://masstransit-project.com/"); var destinationAddress = new Uri("sb://my-organization.servicebus.windows.net/MyNamespace/MyMessage"); var mockReceiveContext = new Mock <ReceiveContext>(); mockReceiveContext.Setup(c => c.InputAddress).Returns(inputAddress); var mockConsumeContext = new Mock <ConsumeContext <PingMessage> >(); mockConsumeContext.Setup(c => c.ReceiveContext).Returns(mockReceiveContext.Object); mockConsumeContext.Setup(c => c.Headers).Returns(_mockHeaders.Object); mockConsumeContext.Setup(c => c.MessageId).Returns(messageId); mockConsumeContext.Setup(c => c.ConversationId).Returns(conversationId); mockConsumeContext.Setup(c => c.CorrelationId).Returns(correlationId); mockConsumeContext.Setup(c => c.RequestId).Returns(requestId); mockConsumeContext.Setup(c => c.DestinationAddress).Returns(destinationAddress); var consumeContextProxy = new ConsumeContextProxy <PingMessage>(mockConsumeContext.Object, new Mock <IPayloadCache>().Object); var capturedTelemetry = default(RequestTelemetry); var filter = new ApplicationInsightsConsumeFilter <PingMessage>(new TelemetryClient(), "", "", (holder, context) => capturedTelemetry = holder.Telemetry); await filter.Send(consumeContextProxy, new Mock <IPipe <ConsumeContext <PingMessage> > >().Object); var configuration = TelemetryConfiguration.CreateDefault(); configuration.TelemetryInitializers.Add(new CopyPropertiesTelemetryInitializer(capturedTelemetry)); var telemetryClient = new TelemetryClient(configuration); filter = new ApplicationInsightsConsumeFilter <PingMessage>(telemetryClient, "", "", (h, c) => { }); // Act, Assert Assert.That(async() => await filter.Send(consumeContextProxy, new Mock <IPipe <ConsumeContext <PingMessage> > >().Object), Throws.Nothing); }