PriorityQueueTest.cs 2.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119
  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 Microsoft.VisualStudio.TestTools.UnitTesting;
  6. using Assert = Xunit.Assert;
  7. namespace ReactiveTests.Tests
  8. {
  9. [TestClass]
  10. public class PriorityQueueTest
  11. {
  12. [TestMethod]
  13. public void Enqueue_dequeue()
  14. {
  15. var q = new PriorityQueue<int>();
  16. for (var i = 0; i < 16; i++)
  17. {
  18. Assert.Equal(0, q.Count);
  19. q.Enqueue(i);
  20. Assert.Equal(1, q.Count);
  21. Assert.Equal(i, q.Peek());
  22. Assert.Equal(1, q.Count);
  23. Assert.Equal(i, q.Dequeue());
  24. Assert.Equal(0, q.Count);
  25. }
  26. }
  27. [TestMethod]
  28. public void Enqueue_all_dequeue_all()
  29. {
  30. var q = new PriorityQueue<int>();
  31. for (var i = 0; i < 33; i++)
  32. {
  33. q.Enqueue(i);
  34. Assert.Equal(i + 1, q.Count);
  35. }
  36. Assert.Equal(33, q.Count);
  37. for (var i = 0; i < 33; i++)
  38. {
  39. Assert.Equal(33 - i, q.Count);
  40. Assert.Equal(i, q.Peek());
  41. Assert.Equal(i, q.Dequeue());
  42. }
  43. Assert.Equal(0, q.Count);
  44. }
  45. [TestMethod]
  46. public void Reverse_Enqueue_all_dequeue_all()
  47. {
  48. var q = new PriorityQueue<int>();
  49. for (var i = 32; i >= 0; i--)
  50. {
  51. q.Enqueue(i);
  52. Assert.Equal(33 - i, q.Count);
  53. }
  54. Assert.Equal(33, q.Count);
  55. for (var i = 0; i < 33; i++)
  56. {
  57. Assert.Equal(33 - i, q.Count);
  58. Assert.Equal(i, q.Peek());
  59. Assert.Equal(i, q.Dequeue());
  60. }
  61. Assert.Equal(0, q.Count);
  62. }
  63. [TestMethod]
  64. public void Remove_from_middle()
  65. {
  66. var q = new PriorityQueue<int>();
  67. for (var i = 0; i < 33; i++)
  68. {
  69. q.Enqueue(i);
  70. }
  71. q.Remove(16);
  72. for (var i = 0; i < 16; i++)
  73. {
  74. Assert.Equal(i, q.Dequeue());
  75. }
  76. for (var i = 16; i < 32; i++)
  77. {
  78. Assert.Equal(i + 1, q.Dequeue());
  79. }
  80. }
  81. [TestMethod]
  82. public void Repro_329()
  83. {
  84. var queue = new PriorityQueue<int>();
  85. queue.Enqueue(2);
  86. queue.Enqueue(1);
  87. queue.Enqueue(5);
  88. queue.Enqueue(2);
  89. Assert.Equal(1, queue.Dequeue());
  90. Assert.Equal(2, queue.Dequeue());
  91. Assert.Equal(2, queue.Dequeue());
  92. Assert.Equal(5, queue.Dequeue());
  93. }
  94. }
  95. }