private void SendOfflineBroadcastResponseMessage(string channelId, object broadcastMessage, int numberOfClients, int numberOfMessages, int openConnectionTimeout, int allMessagesReceivedTimeout) { ThreadPool.SetMinThreads(50, 2); ClientMockFarm aClientFarm = new ClientMockFarm(MessagingSystem, channelId, numberOfClients); ServiceMock aService = new ServiceMock(MessagingSystem, channelId); try { aService.InputChannel.StartListening(); // Send broadcasts. for (int i = 0; i < numberOfMessages; ++i) { aService.InputChannel.SendResponseMessage("*", broadcastMessage); } Thread.Sleep(500); aClientFarm.OpenConnectionsAsync(); aClientFarm.WaitUntilAllConnectionsAreOpen(openConnectionTimeout); aService.WaitUntilResponseReceiversConnectNotified(numberOfClients, openConnectionTimeout); Assert.AreEqual(aClientFarm.Clients.Count(), aService.ConnectedResponseReceivers.Count()); foreach (ClientMock aClient in aClientFarm.Clients) { Assert.IsTrue(aService.ConnectedResponseReceivers.Any(x => x.ResponseReceiverId == aClient.OutputChannel.ResponseReceiverId)); } PerformanceTimer aStopWatch = new PerformanceTimer(); aStopWatch.Start(); aClientFarm.WaitUntilAllResponsesAreReceived(numberOfMessages, allMessagesReceivedTimeout); aStopWatch.Stop(); foreach (DuplexChannelMessageEventArgs aResponseMessage in aClientFarm.ReceivedResponses) { Assert.AreEqual(broadcastMessage, aResponseMessage.Message); } } finally { EneterTrace.Debug("CLEANING AFTER TEST"); aClientFarm.CloseAllConnections(); aService.InputChannel.StopListening(); //EneterTrace.StopProfiler(); Thread.Sleep(500); } }
private void SendOfflineResponse(string channelId, object responseMessage, int numberOfClients, int numberOfMessages, int openConnectionTimeout, int allMessagesReceivedTimeout) { ThreadPool.SetMinThreads(100, 2); ClientMockFarm aClientFarm = new ClientMockFarm(MessagingSystem, channelId, numberOfClients); ServiceMock aService = new ServiceMock(MessagingSystem, channelId); aService.DoOnMessageReceived_SendResponse(responseMessage); try { //EneterTrace.StartProfiler(); aService.InputChannel.StartListening(); PerformanceTimer aStopWatch = new PerformanceTimer(); aStopWatch.Start(); foreach (ClientMock aClientMock in aClientFarm.Clients) { for (int i = 0; i < numberOfMessages; ++i) { aService.InputChannel.SendResponseMessage(aClientMock.OutputChannel.ResponseReceiverId, responseMessage); } } Thread.Sleep(500); aClientFarm.OpenConnectionsAsync(); aClientFarm.WaitUntilAllConnectionsAreOpen(openConnectionTimeout); aClientFarm.WaitUntilAllResponsesAreReceived(numberOfMessages, allMessagesReceivedTimeout); aStopWatch.Stop(); foreach (ClientMock aClient in aClientFarm.Clients) { Assert.IsTrue(aService.ConnectedResponseReceivers.Any(x => x.ResponseReceiverId == aClient.OutputChannel.ResponseReceiverId)); } // Wait little bit more for case there is an error that more messages are sent. Thread.Sleep(500); Assert.AreEqual(numberOfMessages * numberOfClients, aClientFarm.ReceivedResponses.Count()); foreach (DuplexChannelMessageEventArgs aResponseMessage in aClientFarm.ReceivedResponses) { Assert.AreEqual(responseMessage, aResponseMessage.Message); } } finally { EneterTrace.Debug("CLEANING AFTER TEST"); aClientFarm.CloseAllConnections(); aService.InputChannel.StopListening(); //EneterTrace.StopProfiler(); Thread.Sleep(200); } }