QueueTest.cs 3.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225
  1. //
  2. // Queue.cs
  3. //
  4. // Author:
  5. // Ben Maurer ([email protected])
  6. //
  7. #if NET_2_0
  8. using System;
  9. using System.Collections;
  10. using System.Collections.Generic;
  11. using NUnit.Framework;
  12. namespace MonoTests.System.Collections.Generic {
  13. [TestFixture]
  14. public class QueueTest : Assertion
  15. {
  16. [Test]
  17. public void TestCtor ()
  18. {
  19. Queue <int> a = new Queue <int> ();
  20. Queue <int> b = new Queue <int> (1);
  21. Queue <object> c = new Queue <object> ();
  22. Queue <object> d = new Queue <object> (1);
  23. Queue <object> e = new Queue <object> (0);
  24. }
  25. [Test]
  26. [ExpectedException (typeof (ArgumentOutOfRangeException))]
  27. public void TestCtorEx ()
  28. {
  29. Queue <int> a = new Queue <int> (-1);
  30. }
  31. [Test]
  32. public void TestCtorEnum ()
  33. {
  34. List <int> l = new List <int> ();
  35. l.Add (1);
  36. l.Add (2);
  37. l.Add (3);
  38. Queue <int> s = new Queue <int> (l);
  39. AssertDequeue (s, 1);
  40. AssertDequeue (s, 2);
  41. AssertDequeue (s, 3);
  42. }
  43. [Test]
  44. [ExpectedException (typeof (ArgumentNullException))]
  45. public void TestCtorEnumNull ()
  46. {
  47. Queue <int> s = new Queue <int> (null);
  48. }
  49. [Test]
  50. public void TestClear()
  51. {
  52. Queue <int> s = new Queue <int> ();
  53. s.Clear ();
  54. AssertEquals (s.Count, 0);
  55. s.Enqueue (1);
  56. s.Enqueue (2);
  57. AssertEquals (s.Count, 2);
  58. s.Clear ();
  59. AssertEquals (s.Count, 0);
  60. }
  61. [Test]
  62. public void TestContains ()
  63. {
  64. Stack <int> s = new Stack <int> ();
  65. AssertEquals (s.Contains (1), false);
  66. s.Push (1);
  67. AssertEquals (s.Contains (1), true);
  68. AssertEquals (s.Contains (0), false);
  69. }
  70. [Test]
  71. public void TestCopyTo ()
  72. {
  73. int [] x = new int [3];
  74. Queue <int> z = new Queue <int> ();
  75. z.Enqueue (1);
  76. z.Enqueue (2);
  77. x [0] = 10;
  78. z.CopyTo (x, 1);
  79. AssertEquals (x [0], 10);
  80. AssertEquals (x [1], 1);
  81. AssertEquals (x [2], 2);
  82. }
  83. [Test]
  84. public void TestPeek ()
  85. {
  86. Queue <int> s = new Queue <int> ();
  87. s.Enqueue (1);
  88. AssertEquals (s.Peek (), 1);
  89. AssertEquals (s.Count, 1);
  90. }
  91. [Test]
  92. [ExpectedException (typeof (InvalidOperationException))]
  93. public void TestPeekEx ()
  94. {
  95. Queue <int> s = new Queue <int> ();
  96. s.Peek ();
  97. }
  98. [Test]
  99. [ExpectedException (typeof (InvalidOperationException))]
  100. public void TestPeekEx2 ()
  101. {
  102. Queue <int> s = new Queue <int> ();
  103. s.Enqueue (1);
  104. s.Dequeue ();
  105. s.Peek ();
  106. }
  107. [Test]
  108. public void TestDequeue ()
  109. {
  110. Queue <int> s = new Queue <int> ();
  111. s.Enqueue (1);
  112. AssertEquals (s.Dequeue (), 1);
  113. AssertEquals (s.Count, 0);
  114. }
  115. [Test]
  116. [ExpectedException (typeof (InvalidOperationException))]
  117. public void TestDequeueEx ()
  118. {
  119. Queue <int> s = new Queue <int> ();
  120. s.Dequeue ();
  121. }
  122. [Test]
  123. [ExpectedException (typeof (InvalidOperationException))]
  124. public void TestDequeueEx2 ()
  125. {
  126. Queue <int> s = new Queue <int> ();
  127. s.Enqueue (1);
  128. s.Dequeue ();
  129. s.Dequeue ();
  130. }
  131. [Test]
  132. public void TestEnqueue ()
  133. {
  134. Queue <int> s = new Queue <int> ();
  135. s.Enqueue (1);
  136. AssertEquals (s.Count, 1);
  137. s.Enqueue (2);
  138. AssertEquals (s.Count, 2);
  139. for (int i = 0; i < 100; i ++)
  140. s.Enqueue (i);
  141. AssertEquals (s.Count, 102);
  142. }
  143. [Test]
  144. public void TestToArray ()
  145. {
  146. Queue <int> s = new Queue <int> ();
  147. int [] x = s.ToArray ();
  148. AssertEquals (x.Length, 0);
  149. s.Enqueue (1);
  150. x = s.ToArray ();
  151. AssertEquals (x.Length, 1);
  152. AssertEquals (x [0], 1);
  153. }
  154. [Test]
  155. public void TestEnumerator ()
  156. {
  157. Queue <int> s = new Queue <int> ();
  158. foreach (int x in s)
  159. Fail ();
  160. s.Enqueue (1);
  161. int i = 0;
  162. foreach (int x in s) {
  163. AssertEquals (i, 0);
  164. AssertEquals (x, 1);
  165. i ++;
  166. }
  167. for (i = 2; i < 100; i ++)
  168. s.Enqueue (i);
  169. i = 1;
  170. foreach (int x in s) {
  171. AssertEquals (x, i);
  172. i ++;
  173. }
  174. }
  175. void AssertDequeue <T> (Queue <T> s, T t)
  176. {
  177. AssertEquals (s.Dequeue (), t);
  178. }
  179. }
  180. }
  181. #endif