#if NET_2_0 using System; using System.Collections.Generic; using System.IO; using System.Text; using System.Runtime.Serialization; using System.Runtime.Serialization.Formatters.Binary; using NUnit.Framework; namespace MonoTests.System.Collections.Generic { [TestFixture] public class LinkedListTest { class EquatableValue : IEquatable { public readonly string Value; public EquatableValue (string value) { this.Value = value; } public bool Equals (EquatableValue other) { if (other == null) return false; return string.Equals (Value, other.Value, StringComparison.OrdinalIgnoreCase); } } LinkedList intlist; LinkedList strings; [SetUp] public void Setup () { intlist = new LinkedList (); // 2 3 4 intlist.AddLast (3); intlist.AddLast (4); intlist.AddFirst (2); string [] tmpStrings = new string [] { "foo", "bar", "baz" }; // FIXME workaround for 74953 List workaround = new List (); foreach (string s in tmpStrings) workaround.Add (s); // strings = new LinkedList (tmpStrings); strings = new LinkedList (workaround); } [Test] public void AddedTest () { int i = 2; foreach (int current in intlist) { Assert.AreEqual (i, current); i++; } Assert.AreEqual (5, i); } [Test] public void CreatedTest () { string [] values = new string [] { "foo", "bar", "baz" }; int i = 0; foreach (string current in strings) { Assert.AreEqual (values [i], current); i++; } Assert.AreEqual (3, i); } [Test] public void NonCircularNodeTest () { LinkedListNode node = intlist.First; Assert.AreEqual (2, node.Value); LinkedListNode previous = node.Previous; Assert.IsNull (previous); node = node.Next; Assert.IsNotNull (node); Assert.AreEqual (3, node.Value); node = node.Next; Assert.IsNotNull (node); Assert.AreEqual (4, node.Value); node = node.Next; Assert.IsNull (node); } [Test] public void ClearTest () { LinkedListNode node = intlist.First; intlist.Clear (); Assert.AreEqual (0, intlist.Count); Assert.AreEqual (2, node.Value); Assert.IsNull (node.Next); Assert.IsNull (node.Previous); } [Test] public void ContainsTest () { Assert.IsTrue (intlist.Contains (3)); Assert.IsFalse (intlist.Contains (5)); } [Test] public void AddBeforeAndAfterTest () { LinkedListNode node = intlist.Find (3); intlist.AddAfter (node, new LinkedListNode (5)); LinkedListNode sixNode = intlist.AddAfter (node, 6); LinkedListNode sevenNode = intlist.AddBefore (node, 7); intlist.AddBefore (node, new LinkedListNode (8)); Assert.AreEqual (6, sixNode.Value); Assert.AreEqual (7, sevenNode.Value); // 2 7 8 3 6 5 4 int [] values = new int [] { 2, 7, 8, 3, 6, 5, 4 }; int i = 0; foreach (int current in intlist) { Assert.AreEqual (values [i], current); i++; } for (LinkedListNode current = intlist.First; current != null; current = current.Next ) Assert.AreSame (intlist, current.List); } [Test] public void CopyToTest () { int [] values = new int [] { 2, 3, 4 }; int [] output = new int [3]; intlist.CopyTo (output, 0); for (int i = 0; i < 3; i++) Assert.AreEqual (values [i], output [i]); LinkedList l = new LinkedList (); values = new int [l.Count]; l.CopyTo (values, 0); } [Test] public void FindTest () { intlist.AddFirst (4); LinkedListNode head, tail; head = intlist.Find (4); tail = intlist.FindLast (4); Assert.AreEqual (intlist.First, head); Assert.AreEqual (intlist.Last, tail); } [Test] public void RemoveTest () { Assert.IsTrue (intlist.Remove (3)); Assert.AreEqual (2, intlist.Count); int [] values = { 2, 4 }; int i = 0; foreach (int current in intlist) { Assert.AreEqual (values [i], current); i++; } Assert.IsFalse (intlist.Remove (5)); LinkedListNode node = strings.Find ("baz"); strings.Remove (node); Assert.IsNull (node.List); Assert.IsNull (node.Previous); Assert.IsNull (node.Next); string [] values2 = { "foo", "bar" }; i = 0; foreach (string current in strings) { Assert.AreEqual (values2 [i], current); i++; } } [Test, ExpectedException (typeof (ArgumentNullException))] public void RemoveNullNodeTest () { intlist.Remove (null); } [Test, ExpectedException (typeof (InvalidOperationException))] public void RemoveInvalidNodeTest () { intlist.Remove (new LinkedListNode (4)); } [Test] public void RemoveFirstLastTest () { strings.RemoveFirst (); strings.RemoveLast (); Assert.AreEqual (1, strings.Count); Assert.AreEqual ("bar", strings.First.Value); } [Test] public void ListSerializationTest () { BinaryFormatter formatter = new BinaryFormatter(); MemoryStream stream = new MemoryStream(); formatter.Serialize(stream, intlist); stream.Position = 0; object deserialized = formatter.Deserialize(stream); Assert.IsTrue(deserialized is LinkedList ); LinkedList dlist = deserialized as LinkedList ; int [] values = { 2, 3, 4 }; int i = 0; foreach (int value in dlist) { Assert.AreEqual (values [i], value); i++; } Assert.AreEqual(3, i); } /* FIXME: disabled pending fix for #75299 [Test] */ public void EnumeratorSerializationTest () { BinaryFormatter formatter = new BinaryFormatter (); MemoryStream stream = new MemoryStream (); LinkedList.Enumerator e = intlist.GetEnumerator (); formatter.Serialize (stream, e); stream.Position = 0; object deserialized = formatter.Deserialize(stream); Assert.IsTrue(deserialized is LinkedList .Enumerator); LinkedList .Enumerator d = (LinkedList .Enumerator) deserialized; int [] values = { 2, 3, 4 }; int i = 0; while (d.MoveNext ()) { Assert.AreEqual (values [i], d.Current); i++; } Assert.AreEqual(3, i); } public void EnumeratorAfterEnd () { var linkedList = new LinkedList (); linkedList.AddLast ("a"); var e = linkedList.GetEnumerator (); Assert.IsTrue (e.MoveNext (), "#1"); Assert.IsFalse (e.MoveNext (), "#2"); Assert.IsFalse (e.MoveNext (), "#3"); } [Test] //bug 481621 public void PlayWithNullValues () { LinkedList li = new LinkedList (); li.AddLast ((string)null); li.AddLast ("abcd"); li.AddLast ((string)null); li.AddLast ("efgh"); Assert.AreEqual (4, li.Count); Assert.AreEqual ("efgh", li.Last.Value); Assert.IsNull (li.First.Value); Assert.IsTrue (li.Remove ((string)null)); Assert.AreEqual (3, li.Count); Assert.AreEqual ("efgh", li.Last.Value); Assert.AreEqual ("abcd", li.First.Value); Assert.IsTrue (li.Remove ((string)null)); Assert.AreEqual (2, li.Count); Assert.AreEqual ("efgh", li.Last.Value); Assert.AreEqual ("abcd", li.First.Value); Assert.IsFalse (li.Remove ((string)null)); Assert.AreEqual (2, li.Count); Assert.AreEqual ("efgh", li.Last.Value); Assert.AreEqual ("abcd", li.First.Value); } [Test] public void EqualityComparer () { var list = new LinkedList (); var mv = new EquatableValue ("first"); list.AddFirst (mv); var test = new EquatableValue ("FIRST"); Assert.IsTrue (list.Contains (test), "#1"); Assert.AreSame (mv, list.Find (test).Value, "#2"); Assert.AreSame (mv, list.FindLast (test).Value, "#3"); } [Test] public void RemoveFromEmptyList () { var linkedList = new LinkedList (); try { linkedList.RemoveFirst (); Assert.Fail ("#1"); } catch (InvalidOperationException) { } try { linkedList.RemoveLast (); Assert.Fail ("#1"); } catch (InvalidOperationException) { } } } } #endif