// // Queue.cs // // Author: // Ben Maurer (bmaurer@ximian.com) // #if NET_2_0 using System; using System.Collections; using System.Collections.Generic; using System.IO; using System.Runtime.Serialization.Formatters.Binary; using NUnit.Framework; namespace MonoTests.System.Collections.Generic { [TestFixture] public class QueueTest { [Test] public void TestCtor () { Queue a = new Queue (); Queue b = new Queue (1); Queue c = new Queue (); Queue d = new Queue (1); Queue e = new Queue (0); } [Test] [ExpectedException (typeof (ArgumentOutOfRangeException))] public void TestCtorEx () { Queue a = new Queue (-1); } [Test] public void TestCtorEnum () { List l = new List (); l.Add (1); l.Add (2); l.Add (3); Queue s = new Queue (l); AssertDequeue (s, 1); AssertDequeue (s, 2); AssertDequeue (s, 3); } [Test] [ExpectedException (typeof (ArgumentNullException))] public void TestCtorEnumNull () { Queue s = new Queue (null); } [Test] public void TestClear() { Queue s = new Queue (); s.Clear (); Assert.AreEqual (0, s.Count, "#1"); s.Enqueue (1); s.Enqueue (2); Assert.AreEqual (2, s.Count, "#2"); s.Clear (); Assert.AreEqual (0, s.Count, "#3"); IEnumerator enumerator = s.GetEnumerator(); s.Clear(); try { enumerator.Reset(); Assert.Fail ("#4"); } catch(InvalidOperationException) { } } [Test] public void TestContains () { Stack s = new Stack (); Assert.IsFalse (s.Contains (1), "#1"); s.Push (1); Assert.IsTrue (s.Contains (1), "#2"); Assert.IsFalse (s.Contains (0), "#3"); } [Test] public void TestCopyTo () { int [] x = new int [3]; Queue z = new Queue (); z.Enqueue (1); z.Enqueue (2); x [0] = 10; z.CopyTo (x, 1); Assert.AreEqual (10, x [0], "#1"); Assert.AreEqual (1, x [1], "#2"); Assert.AreEqual (2, x [2], "#3"); z = new Queue (); x = new int [z.Count]; z.CopyTo (x, 0); } [Test] public void TestICollectionCopyTo () { var queue = new Queue (); ((ICollection) queue).CopyTo (new int [0], 0); queue.Enqueue (1); queue.Enqueue (2); var array = new int [queue.Count]; ((ICollection) queue).CopyTo (array, 0); Assert.AreEqual (1, array [0]); Assert.AreEqual (2, array [1]); array = new int [queue.Count + 1]; array [0] = 42; ((ICollection) queue).CopyTo (array, 1); Assert.AreEqual (42, array [0]); Assert.AreEqual (1, array [1]); Assert.AreEqual (2, array [2]); } [Test] public void TestPeek () { Queue s = new Queue (); s.Enqueue (1); Assert.AreEqual (1, s.Peek (), "#1"); Assert.AreEqual (1, s.Count, "#2"); } [Test] [ExpectedException (typeof (InvalidOperationException))] public void TestPeekEx () { Queue s = new Queue (); s.Peek (); } [Test] [ExpectedException (typeof (InvalidOperationException))] public void TestPeekEx2 () { Queue s = new Queue (); s.Enqueue (1); s.Dequeue (); s.Peek (); } [Test] public void TestDequeue () { Queue s = new Queue (); s.Enqueue (1); Assert.AreEqual (1, s.Dequeue (), "#1"); Assert.AreEqual (0, s.Count, "#2"); } [Test] [ExpectedException (typeof (InvalidOperationException))] public void TestDequeueEx () { Queue s = new Queue (); s.Dequeue (); } [Test] [ExpectedException (typeof (InvalidOperationException))] public void TestDequeueEx2 () { Queue s = new Queue (); s.Enqueue (1); s.Dequeue (); s.Dequeue (); } [Test] public void TestEnqueue () { Queue s = new Queue (); s.Enqueue (1); Assert.AreEqual (1, s.Count, "#1"); s.Enqueue (2); Assert.AreEqual (2, s.Count, "#2"); for (int i = 0; i < 100; i ++) s.Enqueue (i); Assert.AreEqual (102, s.Count, "#3"); } [Test] public void TestToArray () { Queue s = new Queue (); int [] x = s.ToArray (); Assert.AreEqual (0, x.Length, "#1"); s.Enqueue (1); x = s.ToArray (); Assert.AreEqual (1, x.Length, "#2"); Assert.AreEqual (1, x [0], "#3"); } [Test] public void TestEnumerator () { Queue s = new Queue (); foreach (int x in s) Assert.Fail ("#1" + x); s.Enqueue (1); int i = 0; foreach (int x in s) { Assert.AreEqual (0, i, "#2"); Assert.AreEqual (1, x, "#3"); i ++; } for (i = 2; i < 100; i ++) s.Enqueue (i); i = 1; foreach (int x in s) { Assert.AreEqual (i, x, "#4"); i ++; } } [Test] public void TrimExcessTest () { Queue s = new Queue (); s.TrimExcess (); Assert.AreEqual (0, s.Count, "#1"); s.Enqueue (1); s.Enqueue (3); Assert.AreEqual (1, s.Dequeue (), "#2"); Assert.AreEqual (3, s.Peek (), "#3"); s.TrimExcess (); Assert.AreEqual (1, s.Count, "#4"); Assert.AreEqual (3, s.Peek (), "#5"); s.Enqueue (2); Assert.AreEqual (3, s.Dequeue (), "#6"); Assert.AreEqual (2, s.Dequeue (), "#7"); s.TrimExcess (); Assert.AreEqual (0, s.Count, "#8"); } [Test] public void TrimExcessDequeueEnqueue () { var queue = new Queue (); queue.Enqueue (1); queue.Enqueue (2); queue.Enqueue (3); queue.TrimExcess (); Assert.AreEqual (1, queue.Dequeue ()); queue.Enqueue (4); Assert.AreEqual (2, queue.Dequeue ()); Assert.AreEqual (3, queue.Dequeue ()); Assert.AreEqual (4, queue.Dequeue ()); Assert.AreEqual (0, queue.Count); } [Test] [Category ("NotWorking")] // bug #80649 public void SerializeTest () { Queue s = new Queue (); s.Enqueue (1); s.Enqueue (3); s.Enqueue (2); s.Dequeue (); BinaryFormatter bf = new BinaryFormatter (); MemoryStream ms = new MemoryStream (); bf.Serialize (ms, s); byte [] buffer = new byte [ms.Length]; ms.Position = 0; ms.Read (buffer, 0, buffer.Length); Assert.AreEqual (_serializedQueue, buffer); } [Test] #if TARGET_JVM [Category ("NotWorking")] #endif public void DeserializeTest () { MemoryStream ms = new MemoryStream (); ms.Write (_serializedQueue, 0, _serializedQueue.Length); ms.Position = 0; BinaryFormatter bf = new BinaryFormatter (); Queue s = (Queue) bf.Deserialize (ms); Assert.AreEqual (2, s.Count, "#1"); Assert.AreEqual (3, s.Dequeue (), "#2"); Assert.AreEqual (2, s.Dequeue (), "#3"); } void AssertDequeue (Queue s, T t) { Assert.AreEqual (t, s.Dequeue ()); } static byte [] _serializedQueue = new byte [] { 0x00, 0x01, 0x00, 0x00, 0x00, 0xff, 0xff, 0xff, 0xff, 0x01, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x0c, 0x02, 0x00, 0x00, 0x00, 0x49, 0x53, 0x79, 0x73, 0x74, 0x65, 0x6d, 0x2c, 0x20, 0x56, 0x65, 0x72, 0x73, 0x69, 0x6f, 0x6e, 0x3d, 0x32, 0x2e, 0x30, 0x2e, 0x30, 0x2e, 0x30, 0x2c, 0x20, 0x43, 0x75, 0x6c, 0x74, 0x75, 0x72, 0x65, 0x3d, 0x6e, 0x65, 0x75, 0x74, 0x72, 0x61, 0x6c, 0x2c, 0x20, 0x50, 0x75, 0x62, 0x6c, 0x69, 0x63, 0x4b, 0x65, 0x79, 0x54, 0x6f, 0x6b, 0x65, 0x6e, 0x3d, 0x62, 0x37, 0x37, 0x61, 0x35, 0x63, 0x35, 0x36, 0x31, 0x39, 0x33, 0x34, 0x65, 0x30, 0x38, 0x39, 0x05, 0x01, 0x00, 0x00, 0x00, 0x7f, 0x53, 0x79, 0x73, 0x74, 0x65, 0x6d, 0x2e, 0x43, 0x6f, 0x6c, 0x6c, 0x65, 0x63, 0x74, 0x69, 0x6f, 0x6e, 0x73, 0x2e, 0x47, 0x65, 0x6e, 0x65, 0x72, 0x69, 0x63, 0x2e, 0x51, 0x75, 0x65, 0x75, 0x65, 0x60, 0x31, 0x5b, 0x5b, 0x53, 0x79, 0x73, 0x74, 0x65, 0x6d, 0x2e, 0x49, 0x6e, 0x74, 0x33, 0x32, 0x2c, 0x20, 0x6d, 0x73, 0x63, 0x6f, 0x72, 0x6c, 0x69, 0x62, 0x2c, 0x20, 0x56, 0x65, 0x72, 0x73, 0x69, 0x6f, 0x6e, 0x3d, 0x32, 0x2e, 0x30, 0x2e, 0x30, 0x2e, 0x30, 0x2c, 0x20, 0x43, 0x75, 0x6c, 0x74, 0x75, 0x72, 0x65, 0x3d, 0x6e, 0x65, 0x75, 0x74, 0x72, 0x61, 0x6c, 0x2c, 0x20, 0x50, 0x75, 0x62, 0x6c, 0x69, 0x63, 0x4b, 0x65, 0x79, 0x54, 0x6f, 0x6b, 0x65, 0x6e, 0x3d, 0x62, 0x37, 0x37, 0x61, 0x35, 0x63, 0x35, 0x36, 0x31, 0x39, 0x33, 0x34, 0x65, 0x30, 0x38, 0x39, 0x5d, 0x5d, 0x05, 0x00, 0x00, 0x00, 0x06, 0x5f, 0x61, 0x72, 0x72, 0x61, 0x79, 0x05, 0x5f, 0x68, 0x65, 0x61, 0x64, 0x05, 0x5f, 0x74, 0x61, 0x69, 0x6c, 0x05, 0x5f, 0x73, 0x69, 0x7a, 0x65, 0x08, 0x5f, 0x76, 0x65, 0x72, 0x73, 0x69, 0x6f, 0x6e, 0x07, 0x00, 0x00, 0x00, 0x00, 0x08, 0x08, 0x08, 0x08, 0x08, 0x02, 0x00, 0x00, 0x00, 0x09, 0x03, 0x00, 0x00, 0x00, 0x01, 0x00, 0x00, 0x00, 0x03, 0x00, 0x00, 0x00, 0x02, 0x00, 0x00, 0x00, 0x05, 0x00, 0x00, 0x00, 0x0f, 0x03, 0x00, 0x00, 0x00, 0x04, 0x00, 0x00, 0x00, 0x08, 0x00, 0x00, 0x00, 0x00, 0x03, 0x00, 0x00, 0x00, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x0b }; } } #endif