Ejemplo n.º 1
0
        public async Task QueueMessageBatchAsyncWithSingleEventPublishesToRedisChannel()
        {
            var logger = new Mock <ILogger>()
            {
                DefaultValue = DefaultValue.Mock
            };
            var mockConnectionMultiplexer = new Mock <IConnectionMultiplexer> {
                DefaultValue = DefaultValue.Mock
            };
            var mockSubscriber = new Mock <ISubscriber> {
                DefaultValue = DefaultValue.Mock
            };

            mockConnectionMultiplexer.Setup(x => x.GetSubscriber(It.IsAny <object>())).Returns(mockSubscriber.Object);

            var actualMessages = new List <RedisValue>();

            mockSubscriber
            .Setup(x => x.PublishAsync(It.IsAny <RedisChannel>(), It.IsAny <RedisValue>(), It.IsAny <CommandFlags>()))
            .Callback((RedisChannel channel, RedisValue redisValue, CommandFlags commandFlags) => actualMessages.Add(redisValue))
            .ReturnsAsync(0);

            var mockRedisDataAdapter = new Mock <IRedisDataAdapter> {
                DefaultValue = DefaultValue.Mock
            };

            mockRedisDataAdapter
            .Setup(x => x.ToRedisValue <string>(ValidStreamGuid, ValidStreamNamespace, It.IsAny <IEnumerable <string> >(), null))
            .Returns((Guid streamGuid, string streamNamespace, IEnumerable <string> events, Dictionary <string, object> requestContext) => JsonConvert.SerializeObject(events));

            var mockQueueStreamMapper = new Mock <IStreamQueueMapper> {
                DefaultValue = DefaultValue.Mock
            };

            mockQueueStreamMapper
            .Setup(x => x.GetQueueForStream(ValidStreamGuid, ValidStreamNamespace))
            .Returns(QueueId.GetQueueId(null, 0, 0));

            var rqa = new RedisQueueAdapter(
                ValidRedisStreamOptions,
                MockConnectionMultiplexerFactory.Returns(mockConnectionMultiplexer.Object),
                mockRedisDataAdapter.Object,
                mockQueueStreamMapper.Object,
                logger.Object,
                ValidServiceId,
                ValidClusterId,
                ValidProviderName);

            var expectedMessages = new List <RedisValue>();

            for (var i = 0; i < 100; i++)
            {
                var message = new[] { i.ToString() };
                expectedMessages.Add(JsonConvert.SerializeObject(message));
                await rqa.QueueMessageBatchAsync(ValidStreamGuid, ValidStreamNamespace, message, null, null);
            }

            AssertEx.Equal(expectedMessages, actualMessages);
        }
Ejemplo n.º 2
0
        public async Task PassingNonNullTokenThrownsArgumentException()
        {
            var rqa = new RedisQueueAdapter(ValidRedisStreamOptions, CachedConnectionMultiplexerFactory.Default, Mock.Of <IRedisDataAdapter>(), Mock.Of <IStreamQueueMapper>(), MockLogger(), ValidServiceId, ValidClusterId, ValidProviderName);

            await AssertEx.ThrowsAnyAsync <ArgumentException>(
                () => rqa.QueueMessageBatchAsync(ValidStreamGuid, ValidStreamNamespace, new[] { "Something" }, new EventSequenceTokenV2(0), null),
                e => e.ParamName == "token");
        }