LogarithmicTimeoutTests.cs 2.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081
  1. namespace ApplicationTests.Timeout;
  2. public class LogarithmicTimeoutTests
  3. {
  4. [Fact]
  5. public void Span_Should_Return_BaseDelay_When_Stage_Is_Zero ()
  6. {
  7. var baseDelay = TimeSpan.FromMilliseconds (1000);
  8. var timeout = new LogarithmicTimeout (baseDelay, () => true);
  9. Assert.Equal (TimeSpan.Zero, timeout.Span);
  10. }
  11. [Fact]
  12. public void Span_Should_Increase_Logarithmically ()
  13. {
  14. var baseDelay = TimeSpan.FromMilliseconds (1000);
  15. var timeout = new LogarithmicTimeout (baseDelay, () => true);
  16. var stage0 = timeout.Span;
  17. timeout.AdvanceStage (); // stage = 1
  18. var stage1 = timeout.Span;
  19. timeout.AdvanceStage (); // stage = 2
  20. var stage2 = timeout.Span;
  21. timeout.AdvanceStage (); // stage = 3
  22. var stage3 = timeout.Span;
  23. Assert.True (stage1 > stage0, "Stage 1 should be greater than stage 0");
  24. Assert.True (stage2 > stage1, "Stage 2 should be greater than stage 1");
  25. Assert.True (stage3 > stage2, "Stage 3 should be greater than stage 2");
  26. }
  27. [Theory]
  28. [MemberData (nameof (GetLogarithmicTestData))]
  29. public void Span_Should_Match_Expected_Logarithmic_Value (
  30. double baseDelayMs, int stage, double expectedMs)
  31. {
  32. var baseDelay = TimeSpan.FromMilliseconds (baseDelayMs);
  33. var timeout = new LogarithmicTimeout (baseDelay, () => true);
  34. for (int i = 0; i < stage; i++)
  35. {
  36. timeout.AdvanceStage ();
  37. }
  38. double actualMs = timeout.Span.TotalMilliseconds;
  39. double tolerance = 0.001; // Allow minor rounding error
  40. Assert.InRange (actualMs, expectedMs - tolerance, expectedMs + tolerance);
  41. }
  42. public static IEnumerable<object []> GetLogarithmicTestData ()
  43. {
  44. // baseDelayMs, stage, expectedSpanMs
  45. double baseMs = 1000;
  46. yield return new object [] { baseMs, 0, 0 };
  47. yield return new object [] { baseMs, 1, baseMs * Math.Log (2) };
  48. yield return new object [] { baseMs, 2, baseMs * Math.Log (3) };
  49. yield return new object [] { baseMs, 5, baseMs * Math.Log (6) };
  50. yield return new object [] { baseMs, 10, baseMs * Math.Log (11) };
  51. }
  52. [Fact]
  53. public void Reset_Should_Set_Stage_Back_To_Zero ()
  54. {
  55. var baseDelay = TimeSpan.FromMilliseconds (1000);
  56. var timeout = new LogarithmicTimeout (baseDelay, () => true);
  57. timeout.AdvanceStage ();
  58. timeout.AdvanceStage ();
  59. Assert.NotEqual (baseDelay, timeout.Span);
  60. timeout.Reset ();
  61. Assert.Equal (TimeSpan.Zero, timeout.Span);
  62. }
  63. }