public async Task AdvancedCreatePublishAndConsume() { var connectionFactory = CreateConnectionFactory(); using (var queueClient = new RabbitMQClient(connectionFactory)) { var queueName = $"IntegratedTestQueue_{Guid.NewGuid()}"; queueClient.EnsureQueueExists(queueName, autoDelete: true); queueClient.Publish("", queueName, "TestValue123"); var receivedMessage = ""; var worker = await AdvancedMessageProcessingWorker <string> .CreateAndStartAsync(queueClient, queueName, message => DoSomething(message, out receivedMessage), CancellationToken.None); const int timeLimit = 10000; var elapsedTime = 0; while (receivedMessage == "" && elapsedTime < timeLimit) { await Task.Delay(100); elapsedTime += 100; } worker.Stop(); receivedMessage.ShouldBe("TestValue123"); } }
public async Task AdvancedCreateBatchPublishAndConsume() { var connectionFactory = CreateConnectionFactory(); const int messageAmount = 100; var messages = GenerateMessages(messageAmount); using (var queueClient = new RabbitMQClient(connectionFactory)) { var queueName = $"IntegratedTestQueue_{Guid.NewGuid()}"; queueClient.EnsureQueueExists(queueName); queueClient.BatchPublish("", queueName, messages); var receivedMessages = new ConcurrentBag <string>(); var worker = await AdvancedMessageProcessingWorker <string> .CreateAndStartAsync(queueClient, queueName, message => BatchDoSomething(message, receivedMessages), CancellationToken.None); const int timeLimit = 10000; var elapsedTime = 0; while (receivedMessages.Count < messageAmount && elapsedTime < timeLimit) { await Task.Delay(100); elapsedTime += 100; } worker.Stop(); queueClient.QueueDelete(queueName); receivedMessages.Count.ShouldBe(messages.Count); receivedMessages.ShouldBeSubsetOf(messages); } }