Пример #1
0
        public async Task Should_prefetch_one_message_when_set_to_zero()
        {
            //arrange
            var settings = new TestMessageSettings
            {
                DeadLetterDeliveryLimit = 1,
                PrefetchCount           = 0
            };
            var messages = new List <StorageQueueMessage>
            {
                new StorageQueueMessage(new LongRunningTestCommand {
                    Message = 1.ToString()
                })
            };


            _clientMock.Setup(x => x.GetMessagesAsync <LongRunningTestCommand>(1, It.IsAny <TimeSpan?>()))
            .ReturnsAsync(messages);
            var pump        = new StorageQueueMessagePump(_clientMock.Object, settings, Mock.Of <ILog>());
            var invokations = 0;
            Func <StorageQueueMessage, CancellationToken, Task> function = (a, b) => Task.FromResult(invokations++);
            //act
            await pump.PumpAsync <LongRunningTestCommand>(function);

            //assert
            invokations.Should().Be(1);
        }
Пример #2
0
        public async Task Should_release_semaphore_if_exception()
        {
            //arrange
            var settings = new TestMessageSettings
            {
                DeadLetterDeliveryLimit = 1,
                PrefetchCount           = 10,
                MaxConcurrentCalls      = 1
            };
            var messages = new List <StorageQueueMessage>();

            for (var i = 0; i < 10; i++)
            {
                messages.Add(new StorageQueueMessage(new LongRunningTestCommand {
                    Message = i.ToString()
                }));
            }

            _clientMock.Setup(x => x.GetMessagesAsync <LongRunningTestCommand>(10, It.IsAny <TimeSpan?>()))
            .ReturnsAsync(messages);
            var pump        = new StorageQueueMessagePump(_clientMock.Object, settings, Mock.Of <ILog>());
            var invokations = 0;
            Func <StorageQueueMessage, CancellationToken, Task> function = (a, b) =>
            {
                invokations++;
                return(Task.FromException <Exception>(new Exception()));
            };
            //act
            await pump.PumpAsync <LongRunningTestCommand>(function);

            //assert
            invokations.Should().Be(10);
        }
Пример #3
0
        public async Task Should_prefetch_messages()
        {
            //arrange
            var settings = new TestMessageSettings
            {
                DeadLetterDeliveryLimit = 1,
                PrefetchCount           = 10
            };
            var messages = new List <StorageQueueMessage>();

            for (var i = 0; i < 10; i++)
            {
                messages.Add(new StorageQueueMessage(new LongRunningTestCommand {
                    Message = i.ToString()
                }));
            }

            _clientMock.Setup(x => x.GetMessagesAsync <LongRunningTestCommand>(10, It.IsAny <TimeSpan?>()))
            .ReturnsAsync(messages);
            var pump        = new StorageQueueMessagePump(_clientMock.Object, settings, Mock.Of <ILog>());
            var invocations = 0;

            Task Function(StorageQueueMessage a, CancellationToken b) => Task.FromResult(invocations++);

            //act
            await pump.PumpAsync <LongRunningTestCommand>(Function);

            //assert
            invocations.Should().Be(10);
        }
        public async Task Should_release_semaphore_when_message_lock_timeout_expires()
        {
            //arrange
            var settings = new TestMessageSettings
            {
                DeadLetterDeliveryLimit = 1,
                PrefetchCount           = 1,
                MaxConcurrentCalls      = 1,
                MessageLockTimeout      = TimeSpan.FromMilliseconds(50)
            };
            var messageCount = 1;
            var messages     = new List <StorageQueueMessage>();

            for (var i = 0; i < messageCount; i++)
            {
                messages.Add(new StorageQueueMessage(new LongRunningTestCommand {
                    Message = i.ToString()
                }));
            }

            _clientMock.Setup(x => x.GetMessagesAsync <LongRunningTestCommand>(messageCount, It.IsAny <TimeSpan?>()))
            .ReturnsAsync(messages);
            var countable = new Mock <ICountable>();
            var pump      = new StorageQueueMessagePump(_clientMock.Object, settings, Mock.Of <ILog>());

            async Task Function(StorageQueueMessage a, CancellationToken b)
            {
                await Task.Delay(100, b);

                countable.Object.Count();
            }

            //act
#pragma warning disable CS4014 // Because this call is not awaited, execution of the current method continues before the call is completed
            pump.PumpAsync <LongRunningTestCommand>(Function);
#pragma warning restore CS4014 // Because this call is not awaited, execution of the current method continues before the call is completed
            await Task.Delay(150);

            //assert
            pump._maxConcurrent.CurrentCount.Should().Be(1);
            countable.Verify(x => x.Count(), Times.Never);
        }
Пример #5
0
        public async Task Should_not_exceed_max_concurrent_when_prefetch_is_high()
        {
            //arrange
            var settings = new TestMessageSettings
            {
                DeadLetterDeliveryLimit = 1,
                PrefetchCount           = 20,
                MaxConcurrentCalls      = 10
            };
            var messages = new List <StorageQueueMessage>();

            for (var i = 0; i < 20; i++)
            {
                messages.Add(new StorageQueueMessage(new LongRunningTestCommand {
                    Message = i.ToString()
                }));
            }


            _clientMock.Setup(x => x.GetMessagesAsync <LongRunningTestCommand>(20, It.IsAny <TimeSpan?>()))
            .ReturnsAsync(messages);
            var pump        = new StorageQueueMessagePump(_clientMock.Object, settings, Mock.Of <ILog>());
            var invocations = 0;

            Task Function(StorageQueueMessage a, CancellationToken b)
            {
                invocations++;
                return(Task.Delay(1000));
            }

            //act
#pragma warning disable CS4014 // Because this call is not awaited, execution of the current method continues before the call is completed
            pump.PumpAsync <LongRunningTestCommand>(Function);
#pragma warning restore CS4014 // Because this call is not awaited, execution of the current method continues before the call is completed
            await Task.Delay(100);

            //assert
            invocations.Should().Be(10);
        }
Пример #6
0
        public async Task Should_not_release_semaphore_until_task_is_completed()
        {
            //arrange
            var settings = new TestMessageSettings
            {
                DeadLetterDeliveryLimit = 1,
                PrefetchCount           = 1,
                MaxConcurrentCalls      = 1
            };
            var messageCount = 1;
            var messages     = new List <StorageQueueMessage>();

            for (var i = 0; i < messageCount; i++)
            {
                messages.Add(new StorageQueueMessage(new LongRunningTestCommand {
                    Message = i.ToString()
                }));
            }

            _clientMock.Setup(x => x.GetMessagesAsync <LongRunningTestCommand>(messageCount, It.IsAny <TimeSpan?>()))
            .ReturnsAsync(messages);
            var pump = new StorageQueueMessagePump(_clientMock.Object, settings, Mock.Of <ILog>());

            Task Function(StorageQueueMessage a, CancellationToken b)
            {
                return(Task.Delay(1000));
            }

            //act
#pragma warning disable CS4014 // Because this call is not awaited, execution of the current method continues before the call is completed
            pump.PumpAsync <LongRunningTestCommand>(Function, CancellationToken.None);
#pragma warning restore CS4014 // Because this call is not awaited, execution of the current method continues before the call is completed
            await Task.Delay(100);

            //assert
            pump._maxConcurrent.CurrentCount.Should().Be(0);
        }