Example #1
0
    public async Task QueueMonitor_GetCurrentState_MultipleMessages_ReadyMessagesGreaterZero()
    {
        var builder = RabbitMQTestBuilder
                      .CreateWithQueueDeclare(_fixture)
                      .WithMultipleRandomPublishedMessage()
                      .Build();

        var monitor = new RabbitMQQueueMonitor <string>(
            Mock.Of <ILogger <RabbitMQQueueMonitor <string> > >(),
            Opts.Create(new RabbitMQConsumerOptions <string>
        {
            Queue =
            {
                Name = builder.QueueName
            }
        }),
            _fixture.ConnectionFactory <string>()
            );

        var state = await monitor.GetCurrentState();

        Assert.Equal(builder.QueueName, state.QueueName);
        Assert.Equal(0, state.ConsumerCount);
        Assert.Equal(RabbitMQTestBuilder.PrefetchCount, state.ReadyMessages);
    }
Example #2
0
    public async Task ConsumerStartAsync_ConsumeMessage_ConsumedEqualsPublished()
    {
        const byte priority         = 111;
        var        message          = new byte[] { 1, 2, 3 };
        byte?      consumedPriority = null;
        var        consumedMessage  = (byte[])null;
        var        builder          = RabbitMQTestBuilder
                                      .CreateWithQueueDeclare(_fixture)
                                      .WithSinglePublishedMessage(priority, message)
                                      .WithConsumerCallback((motorEvent, _) =>
        {
            consumedPriority = motorEvent.GetRabbitMQPriority();
            consumedMessage  = motorEvent.TypedData;
            return(Task.FromResult(ProcessedMessageStatus.Success));
        })
                                      .Build();
        var consumer = builder.GetConsumer <string>();

        await consumer.StartAsync();

        await Task.Delay(TimeSpan.FromSeconds(5));

        Assert.NotNull(consumedMessage);
        Assert.Equal(priority, consumedPriority);
        Assert.Equal(message, consumedMessage);
    }
Example #3
0
    public async Task ConsumerStartAsync_WithQueueName_QueueExists()
    {
        var builder = RabbitMQTestBuilder
                      .CreateWithoutQueueDeclare(_fixture)
                      .WithConsumerCallback((_, _) => Task.FromResult(ProcessedMessageStatus.Success))
                      .Build();
        var consumer = builder.GetConsumer <string>();

        await consumer.StartAsync();

        Assert.True(builder.IsConsumerQueueDeclared());
    }
Example #4
0
    public async Task ConsumerStartAsync_OneMessageInQueueAndConsumeCallbackSuccess_QueueEmptyAfterAck()
    {
        var builder = RabbitMQTestBuilder
                      .CreateWithoutQueueDeclare(_fixture)
                      .WithSingleRandomPublishedMessage()
                      .WithConsumerCallback((_, _) => Task.FromResult(ProcessedMessageStatus.Success))
                      .Build();
        var consumer = builder.GetConsumer <string>();

        await consumer.StartAsync();

        await Task.Delay(TimeSpan.FromSeconds(2));

        Assert.Equal((uint)0, builder.MessageInConsumerQueue());
    }
Example #5
0
    public async Task ConsumerStartAsync_ConsumeCallbackReturnsACriticalStatus_CriticalExitCalled()
    {
        var builder = RabbitMQTestBuilder
                      .CreateWithQueueDeclare(_fixture)
                      .WithSingleRandomPublishedMessage()
                      .WithConsumerCallback((_, _) => Task.FromResult(ProcessedMessageStatus.CriticalFailure))
                      .Build();

        var applicationLifetimeMock = new Mock <IHostApplicationLifetime>();
        var consumer = builder.GetConsumer <string>(applicationLifetimeMock.Object);

        await consumer.StartAsync();

        applicationLifetimeMock.VerifyUntilTimeoutAsync(t => t.StopApplication(), Times.Once);
    }
Example #6
0
    public async Task ConsumerStartAsync_ConsumeCallbackAsyncThrows_CriticalExitCalled()
    {
        var builder = RabbitMQTestBuilder
                      .CreateWithQueueDeclare(_fixture)
                      .WithSingleRandomPublishedMessage()
                      .WithConsumerCallback((_, _) => throw new Exception())
                      .Build();

        var applicationLifetimeMock = new Mock <IHostApplicationLifetime>();
        var consumer = builder.GetConsumer <string>(applicationLifetimeMock.Object);

        await consumer.StartAsync();

        await Task.Delay(TimeSpan.FromSeconds(3));

        applicationLifetimeMock.VerifyUntilTimeoutAsync(t => t.StopApplication(), Times.Once);
    }
Example #7
0
    public async Task PublisherPublishMessageAsync_SomeMessage_PublishedEqualsConsumed()
    {
        var builder = RabbitMQTestBuilder
                      .CreateWithQueueDeclare(_fixture)
                      .Build();
        var publisher = builder.GetPublisher <byte[]>();

        const byte priority = 222;
        var        message  = new byte[] { 3, 2, 1 };

        var cloudEvent = MotorCloudEvent.CreateTestCloudEvent(message);

        cloudEvent.SetRabbitMQPriority(priority);

        await publisher.PublishMessageAsync(cloudEvent);

        var results = await builder.GetMessageFromQueue();

        Assert.Equal(priority, results.GetRabbitMQPriority());
        Assert.Equal(message, results.Data);
    }
Example #8
0
    public async Task ConsumerStopAsync_ConsumeCallbackShouldStopAsEarlyAsPossible_NoStopApplicationCalled()
    {
        var builder = RabbitMQTestBuilder
                      .CreateWithQueueDeclare(_fixture)
                      .WithConsumerCallback(async(_, token) =>
        {
            await Task.Delay(4000, token);
            return(ProcessedMessageStatus.CriticalFailure);
        })
                      .WithMultipleRandomPublishedMessage()
                      .Build();

        var consumer = builder.GetConsumer <string>();

        await consumer.StartAsync();

        await consumer.StopAsync();

        await Task.Delay(TimeSpan.FromSeconds(3));

        Assert.Equal(RabbitMQTestBuilder.PrefetchCount, builder.MessageInConsumerQueue());
    }
Example #9
0
    ConsumerStartAsync_OneMessageInQueueAndConsumeCallbackReturnsTempFailureAndAfterwardsSuccess_MessageConsumedTwice()
    {
        var consumerCounter = 0;
        var builder         = RabbitMQTestBuilder
                              .CreateWithQueueDeclare(_fixture)
                              .WithSingleRandomPublishedMessage()
                              .WithConsumerCallback((_, _) =>
        {
            consumerCounter++;
            return(Task.FromResult(consumerCounter == 1
                    ? ProcessedMessageStatus.TemporaryFailure
                    : ProcessedMessageStatus.Success));
        })
                              .Build();
        var consumer = builder.GetConsumer <string>();

        await consumer.StartAsync();

        await Task.Delay(TimeSpan.FromSeconds(2));

        Assert.Equal(2, consumerCounter);
    }
Example #10
0
    public async Task ConsumerStartAsync_CheckParallelProcessing_EnsureAllMessagesAreConsumed()
    {
        const int raceConditionTimeout         = 2;
        const int messageProcessingTimeSeconds = 2;

        var builder = RabbitMQTestBuilder
                      .CreateWithQueueDeclare(_fixture)
                      .WithConsumerCallback(async(_, _) =>
        {
            await Task.CompletedTask;
            await Task.Delay(TimeSpan.FromSeconds(messageProcessingTimeSeconds));
            return(ProcessedMessageStatus.Success);
        })
                      .WithMultipleRandomPublishedMessage()
                      .Build();
        var consumer = builder.GetConsumer <string>();

        await consumer.StartAsync();

        await Task.Delay(TimeSpan.FromSeconds(messageProcessingTimeSeconds + raceConditionTimeout));

        Assert.Equal((uint)0, builder.MessageInConsumerQueue());
    }
Example #11
0
    public async Task QueueMonitor_GetCurrentState_ActiveConsumer_ConsumerCountGreaterZero()
    {
        var builder = RabbitMQTestBuilder
                      .CreateWithQueueDeclare(_fixture)
                      .WithMultipleRandomPublishedMessage()
                      .Build();

        var random   = new Random();
        var consumer = builder.GetConsumer <string>();

        consumer.ConsumeCallbackAsync = async(_, token) =>
        {
            await Task.Delay(random.Next(500), token);

            return(ProcessedMessageStatus.Success);
        };

        await consumer.StartAsync();

        var monitor = new RabbitMQQueueMonitor <string>(
            Mock.Of <ILogger <RabbitMQQueueMonitor <string> > >(),
            Opts.Create(new RabbitMQConsumerOptions <string>
        {
            Queue =
            {
                Name = builder.QueueName
            }
        }),
            _fixture.ConnectionFactory <string>()
            );

        var state = await monitor.GetCurrentState();

        Assert.Equal(builder.QueueName, state.QueueName);
        Assert.Equal(1, state.ConsumerCount);
        Assert.InRange(state.ReadyMessages, 0, RabbitMQTestBuilder.PrefetchCount);
    }