PriorityQueueTest.cs 2.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116
  1. // Licensed to the .NET Foundation under one or more agreements.
  2. // The .NET Foundation licenses this file to you under the MIT License.
  3. // See the LICENSE file in the project root for more information.
  4. using System.Reactive;
  5. using Xunit;
  6. namespace ReactiveTests.Tests
  7. {
  8. public class PriorityQueueTest
  9. {
  10. [Fact]
  11. public void Enqueue_dequeue()
  12. {
  13. var q = new PriorityQueue<int>();
  14. for (var i = 0; i < 16; i++)
  15. {
  16. Assert.Equal(0, q.Count);
  17. q.Enqueue(i);
  18. Assert.Equal(1, q.Count);
  19. Assert.Equal(i, q.Peek());
  20. Assert.Equal(1, q.Count);
  21. Assert.Equal(i, q.Dequeue());
  22. Assert.Equal(0, q.Count);
  23. }
  24. }
  25. [Fact]
  26. public void Enqueue_all_dequeue_all()
  27. {
  28. var q = new PriorityQueue<int>();
  29. for (var i = 0; i < 33; i++)
  30. {
  31. q.Enqueue(i);
  32. Assert.Equal(i + 1, q.Count);
  33. }
  34. Assert.Equal(33, q.Count);
  35. for (var i = 0; i < 33; i++)
  36. {
  37. Assert.Equal(33 - i, q.Count);
  38. Assert.Equal(i, q.Peek());
  39. Assert.Equal(i, q.Dequeue());
  40. }
  41. Assert.Equal(0, q.Count);
  42. }
  43. [Fact]
  44. public void Reverse_Enqueue_all_dequeue_all()
  45. {
  46. var q = new PriorityQueue<int>();
  47. for (var i = 32; i >= 0; i--)
  48. {
  49. q.Enqueue(i);
  50. Assert.Equal(33 - i, q.Count);
  51. }
  52. Assert.Equal(33, q.Count);
  53. for (var i = 0; i < 33; i++)
  54. {
  55. Assert.Equal(33 - i, q.Count);
  56. Assert.Equal(i, q.Peek());
  57. Assert.Equal(i, q.Dequeue());
  58. }
  59. Assert.Equal(0, q.Count);
  60. }
  61. [Fact]
  62. public void Remove_from_middle()
  63. {
  64. var q = new PriorityQueue<int>();
  65. for (var i = 0; i < 33; i++)
  66. {
  67. q.Enqueue(i);
  68. }
  69. q.Remove(16);
  70. for (var i = 0; i < 16; i++)
  71. {
  72. Assert.Equal(i, q.Dequeue());
  73. }
  74. for (var i = 16; i < 32; i++)
  75. {
  76. Assert.Equal(i + 1, q.Dequeue());
  77. }
  78. }
  79. [Fact]
  80. public void Repro_329()
  81. {
  82. var queue = new PriorityQueue<int>();
  83. queue.Enqueue(2);
  84. queue.Enqueue(1);
  85. queue.Enqueue(5);
  86. queue.Enqueue(2);
  87. Assert.Equal(1, queue.Dequeue());
  88. Assert.Equal(2, queue.Dequeue());
  89. Assert.Equal(2, queue.Dequeue());
  90. Assert.Equal(5, queue.Dequeue());
  91. }
  92. }
  93. }