You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

RoundtripTime_Tests.cs 1.6 KiB

5 years ago
5 years ago
5 years ago
5 years ago
1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Diagnostics;
  4. using System.Threading.Tasks;
  5. using Microsoft.VisualStudio.TestTools.UnitTesting;
  6. using MQTTnet.Client;
  7. using MQTTnet.Tests.Mockups;
  8. namespace MQTTnet.Tests
  9. {
  10. [TestClass]
  11. public class RoundtripTime_Tests
  12. {
  13. [TestMethod]
  14. public async Task Round_Trip_Time()
  15. {
  16. using (var testEnvironment = new TestEnvironment())
  17. {
  18. await testEnvironment.StartServerAsync();
  19. var receiverClient = await testEnvironment.ConnectClientAsync();
  20. var senderClient = await testEnvironment.ConnectClientAsync();
  21. await receiverClient.SubscribeAsync("#");
  22. TaskCompletionSource<string> response = null;
  23. receiverClient.UseApplicationMessageReceivedHandler(e =>
  24. {
  25. response?.SetResult(e.ApplicationMessage.ConvertPayloadToString());
  26. });
  27. var times = new List<TimeSpan>();
  28. var stopwatch = Stopwatch.StartNew();
  29. await Task.Delay(1000);
  30. for (var i = 0; i < 100; i++)
  31. {
  32. response = new TaskCompletionSource<string>();
  33. await senderClient.PublishAsync("test", DateTime.UtcNow.Ticks.ToString());
  34. response.Task.GetAwaiter().GetResult();
  35. stopwatch.Stop();
  36. times.Add(stopwatch.Elapsed);
  37. stopwatch.Restart();
  38. }
  39. }
  40. }
  41. }
  42. }