| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469 |
- using System;
- using System.Collections.Generic;
- using System.Linq;
- using Microsoft.VisualStudio.TestTools.UnitTesting;
- namespace Renci.SshNet.Tests.Classes
- {
- [TestClass]
- public class OrderedDictionaryTest
- {
- private static void AssertEqual<TKey, TValue>(List<KeyValuePair<TKey, TValue>> expected, OrderedDictionary<TKey, TValue> o)
- {
- Assert.AreEqual(expected.Count, o.Count);
- CollectionAssert.AreEqual(expected, ToList(o)); // Test the enumerator
- for (int i = 0; i < expected.Count; i++)
- {
- Assert.AreEqual(expected[i], o.GetAt(i));
- Assert.AreEqual(expected[i].Value, o[expected[i].Key]);
- Assert.IsTrue(o.TryGetValue(expected[i].Key, out TValue value));
- Assert.AreEqual(expected[i].Value, value);
- Assert.IsTrue(o.TryGetValue(expected[i].Key, out value, out int index));
- Assert.AreEqual(expected[i].Value, value);
- Assert.AreEqual(i, index);
- Assert.IsTrue(((ICollection<KeyValuePair<TKey, TValue>>)o).Contains(expected[i]));
- Assert.IsTrue(o.ContainsKey(expected[i].Key));
- Assert.IsTrue(o.ContainsValue(expected[i].Value));
- Assert.IsTrue(o.Keys.Contains(expected[i].Key));
- Assert.IsTrue(o.Values.Contains(expected[i].Value));
- Assert.AreEqual(i, o.IndexOf(expected[i].Key));
- Assert.IsFalse(o.TryAdd(expected[i].Key, default));
- Assert.IsFalse(o.TryAdd(expected[i].Key, default, out index));
- Assert.AreEqual(i, index);
- }
- Assert.AreEqual(expected.Count, o.Keys.Count);
- CollectionAssert.AreEqual(expected.Select(kvp => kvp.Key).ToList(), ToList(o.Keys));
- CollectionAssert.AreEqual(ToList(o.Keys), ToList(((IReadOnlyDictionary<TKey, TValue>)o).Keys));
- Assert.AreEqual(expected.Count, o.Values.Count);
- CollectionAssert.AreEqual(expected.Select(kvp => kvp.Value).ToList(), ToList(o.Values));
- CollectionAssert.AreEqual(ToList(o.Values), ToList(((IReadOnlyDictionary<TKey, TValue>)o).Values));
- // Test CopyTo
- var kvpArray = new KeyValuePair<TKey, TValue>[1 + expected.Count + 1];
- ((ICollection<KeyValuePair<TKey, TValue>>)o).CopyTo(kvpArray, 1);
- CollectionAssert.AreEqual(
- (List<KeyValuePair<TKey, TValue>>)[default, .. expected, default],
- kvpArray);
- var keysArray = new TKey[1 + expected.Count + 1];
- o.Keys.CopyTo(keysArray, 1);
- CollectionAssert.AreEqual(
- (List<TKey>)[default, .. expected.Select(kvp => kvp.Key), default],
- keysArray);
- var valuesArray = new TValue[1 + expected.Count + 1];
- o.Values.CopyTo(valuesArray, 1);
- CollectionAssert.AreEqual(
- (List<TValue>)[default, .. expected.Select(kvp => kvp.Value), default],
- valuesArray);
- // Creates a List<T> via enumeration, avoiding the ICollection<T>.CopyTo
- // optimisation in the List<T> constructor.
- static List<T> ToList<T>(IEnumerable<T> values)
- {
- List<T> list = new();
- foreach (T t in values)
- {
- list.Add(t);
- }
- return list;
- }
- }
- [TestMethod]
- public void NullKey_ThrowsArgumentNull()
- {
- OrderedDictionary<string, int> o = new() { { "a", 4 } };
- Assert.ThrowsException<ArgumentNullException>(() => o[null]);
- Assert.ThrowsException<ArgumentNullException>(() => o.Add(null, 1));
- Assert.ThrowsException<ArgumentNullException>(() => ((ICollection<KeyValuePair<string, int>>)o).Add(new KeyValuePair<string, int>(null, 1)));
- Assert.ThrowsException<ArgumentNullException>(() => ((ICollection<KeyValuePair<string, int>>)o).Contains(new KeyValuePair<string, int>(null, 1)));
- Assert.ThrowsException<ArgumentNullException>(() => o.ContainsKey(null));
- Assert.ThrowsException<ArgumentNullException>(() => o.IndexOf(null));
- Assert.ThrowsException<ArgumentNullException>(() => o.Insert(0, null, 1));
- Assert.ThrowsException<ArgumentNullException>(() => o.Remove(null, out _));
- Assert.ThrowsException<ArgumentNullException>(() => o.Remove(null));
- Assert.ThrowsException<ArgumentNullException>(() => ((ICollection<KeyValuePair<string, int>>)o).Remove(new KeyValuePair<string, int>(null, 1)));
- Assert.ThrowsException<ArgumentNullException>(() => o.SetAt(0, null, 1));
- Assert.ThrowsException<ArgumentNullException>(() => o.SetPosition(null, 0));
- Assert.ThrowsException<ArgumentNullException>(() => o.TryAdd(null, 1));
- Assert.ThrowsException<ArgumentNullException>(() => o.TryAdd(null, 1, out _));
- Assert.ThrowsException<ArgumentNullException>(() => o.TryGetValue(null, out _));
- Assert.ThrowsException<ArgumentNullException>(() => o.TryGetValue(null, out _, out _));
- }
- [TestMethod]
- public void Indexer_Match_GetterReturnsValue()
- {
- OrderedDictionary<string, int> o = new() { { "a", 4 }, { "b", 8 } };
- Assert.AreEqual(8, o["b"]);
- }
- [TestMethod]
- public void Indexer_Match_SetterChangesValue()
- {
- OrderedDictionary<string, int> o = new() { { "a", 4 }, { "b", 8 } };
- o["a"] = 5;
- AssertEqual([new("a", 5), new("b", 8)], o);
- }
- [TestMethod]
- public void Indexer_NoMatch_GetterThrowsKeyNotFound()
- {
- OrderedDictionary<string, int> o = new() { { "a", 4 } };
- Assert.ThrowsException<KeyNotFoundException>(() => o["b"]);
- }
- [TestMethod]
- public void Indexer_NoMatch_SetterAddsItem()
- {
- OrderedDictionary<string, int> o = new() { { "a", 4 } };
- o["b"] = 8;
- AssertEqual([new("a", 4), new("b", 8)], o);
- }
- [TestMethod]
- public void Add_Match()
- {
- OrderedDictionary<string, int> o = new() { { "a", 4 } };
- Assert.ThrowsException<ArgumentException>(() => o.Add("a", 8));
- Assert.ThrowsException<ArgumentException>(() => ((ICollection<KeyValuePair<string, int>>)o).Add(new KeyValuePair<string, int>("a", 8)));
- }
- [TestMethod]
- public void Clear()
- {
- OrderedDictionary<string, int> o = new() { { "a", 4 }, { "b", 8 } };
- AssertEqual([new("a", 4), new("b", 8)], o);
- o.Clear();
- AssertEqual([], o);
- }
- [TestMethod]
- public void CopyTo()
- {
- OrderedDictionary<string, int> o = new() { { "a", 4 }, { "b", 8 } };
- Assert.ThrowsException<ArgumentNullException>(() => ((ICollection<KeyValuePair<string, int>>)o).CopyTo(null, 0));
- Assert.ThrowsException<ArgumentOutOfRangeException>(() => ((ICollection<KeyValuePair<string, int>>)o).CopyTo(new KeyValuePair<string, int>[3], -1));
- Assert.ThrowsException<ArgumentException>(() => ((ICollection<KeyValuePair<string, int>>)o).CopyTo(new KeyValuePair<string, int>[3], 3));
- Assert.ThrowsException<ArgumentException>(() => ((ICollection<KeyValuePair<string, int>>)o).CopyTo(new KeyValuePair<string, int>[3], 2));
- Assert.ThrowsException<ArgumentNullException>(() => o.Keys.CopyTo(null, 0));
- Assert.ThrowsException<ArgumentOutOfRangeException>(() => o.Keys.CopyTo(new string[3], -1));
- Assert.ThrowsException<ArgumentException>(() => o.Keys.CopyTo(new string[3], 3));
- Assert.ThrowsException<ArgumentException>(() => o.Keys.CopyTo(new string[3], 2));
- Assert.ThrowsException<ArgumentNullException>(() => o.Values.CopyTo(null, 0));
- Assert.ThrowsException<ArgumentOutOfRangeException>(() => o.Values.CopyTo(new int[3], -1));
- Assert.ThrowsException<ArgumentException>(() => o.Values.CopyTo(new int[3], 3));
- Assert.ThrowsException<ArgumentException>(() => o.Values.CopyTo(new int[3], 2));
- }
- [TestMethod]
- public void ContainsKvp_ChecksKeyAndValue()
- {
- OrderedDictionary<string, int> o = new() { { "a", 4 } };
- Assert.IsFalse(((ICollection<KeyValuePair<string, int>>)o).Contains(new KeyValuePair<string, int>("a", 8)));
- Assert.IsTrue(((ICollection<KeyValuePair<string, int>>)o).Contains(new KeyValuePair<string, int>("a", 4)));
- }
- [TestMethod]
- public void NullValues_Permitted()
- {
- OrderedDictionary<string, string> o = new() { { "a", "1" } };
- Assert.IsFalse(o.ContainsValue(null));
- o.Add("b", null);
- AssertEqual([new("a", "1"), new("b", null)], o);
- }
- [TestMethod]
- public void GetAt_OutOfRange()
- {
- OrderedDictionary<string, string> o = new() { { "a", "1" } };
- Assert.ThrowsException<ArgumentOutOfRangeException>(() => o.GetAt(-2));
- Assert.ThrowsException<ArgumentOutOfRangeException>(() => o.GetAt(-1));
- Assert.ThrowsException<ArgumentOutOfRangeException>(() => o.GetAt(1));
- }
- [TestMethod]
- public void RemoveKvp_ChecksKeyAndValue()
- {
- OrderedDictionary<string, int> o = new() { { "a", 4 } };
- Assert.IsFalse(((ICollection<KeyValuePair<string, int>>)o).Remove(new KeyValuePair<string, int>("a", 8)));
- AssertEqual([new("a", 4)], o);
- Assert.IsTrue(((ICollection<KeyValuePair<string, int>>)o).Remove(new KeyValuePair<string, int>("a", 4)));
- AssertEqual([], o);
- }
- [TestMethod]
- public void SetAt()
- {
- OrderedDictionary<string, double> o = new();
- Assert.ThrowsException<ArgumentOutOfRangeException>(() => o.SetAt(-2, 1.1));
- Assert.ThrowsException<ArgumentOutOfRangeException>(() => o.SetAt(-1, 1.1));
- Assert.ThrowsException<ArgumentOutOfRangeException>(() => o.SetAt(0, 1.1));
- Assert.ThrowsException<ArgumentOutOfRangeException>(() => o.SetAt(1, 1.1));
- o.Add("a", 4);
- Assert.ThrowsException<ArgumentOutOfRangeException>(() => o.SetAt(-2, 1.1));
- Assert.ThrowsException<ArgumentOutOfRangeException>(() => o.SetAt(-1, 1.1));
- o.SetAt(0, 1.1);
- AssertEqual([new("a", 1.1)], o);
- Assert.ThrowsException<ArgumentOutOfRangeException>(() => o.SetAt(1, 5.5));
- }
- [TestMethod]
- public void SetAt3Params_OutOfRange()
- {
- OrderedDictionary<string, int> o = new() { { "a", 4 }, { "b", 8 }, { "c", 12 } };
- Assert.ThrowsException<ArgumentOutOfRangeException>(() => o.SetAt(-1, "d", 16));
- Assert.ThrowsException<ArgumentOutOfRangeException>(() => o.SetAt(3, "d", 16));
- }
- [TestMethod]
- public void SetAt3Params_ExistingKeyCorrectIndex_PermitsChangingValue()
- {
- OrderedDictionary<string, int> o = new() { { "a", 4 }, { "b", 8 }, { "c", 12 } };
- o.SetAt(2, "c", 16);
- AssertEqual([new("a", 4), new("b", 8), new("c", 16)], o);
- }
- [TestMethod]
- public void SetAt3Params_ExistingKeyDifferentIndex_Throws()
- {
- OrderedDictionary<string, int> o = new() { { "a", 4 }, { "b", 8 }, { "c", 12 } };
- Assert.ThrowsException<ArgumentException>(() => o.SetAt(1, "c", 16));
- }
- [TestMethod]
- public void SetAt3Params_PermitsChangingToNewKey()
- {
- OrderedDictionary<string, int> o = new() { { "a", 4 }, { "b", 8 }, { "c", 12 } };
- o.SetAt(1, "d", 16);
- AssertEqual([new("a", 4), new("d", 16), new("c", 12)], o);
- }
- [TestMethod]
- public void Get_NonExistent()
- {
- OrderedDictionary<string, float> o = new() { { "a", 4 } };
- Assert.ThrowsException<KeyNotFoundException>(() => o["doesn't exist"]);
- Assert.IsFalse(((ICollection<KeyValuePair<string, float>>)o).Contains(new KeyValuePair<string, float>("doesn't exist", 1)));
- Assert.IsFalse(o.ContainsKey("doesn't exist"));
- Assert.IsFalse(o.ContainsValue(999));
- Assert.AreEqual(-1, o.IndexOf("doesn't exist"));
- Assert.IsFalse(o.Remove("doesn't exist", out float value));
- Assert.AreEqual(default, value);
- Assert.IsFalse(o.Remove("doesn't exist"));
- Assert.IsFalse(((ICollection<KeyValuePair<string, float>>)o).Remove(new KeyValuePair<string, float>("doesn't exist", 1)));
- Assert.IsFalse(o.TryGetValue("doesn't exist", out value));
- Assert.AreEqual(default, value);
- Assert.IsFalse(o.TryGetValue("doesn't exist", out value, out int index));
- Assert.AreEqual(default, value);
- Assert.AreEqual(-1, index);
- AssertEqual([new("a", 4)], o);
- }
- [TestMethod]
- public void Insert()
- {
- OrderedDictionary<string, float> o = new() { { "a", 4 }, { "b", 8 } };
- Assert.ThrowsException<ArgumentOutOfRangeException>(() => o.Insert(-1, "c", 12));
- o.Insert(0, "c", 12); // Start
- AssertEqual([new("c", 12), new("a", 4), new("b", 8)], o);
- o.Insert(2, "d", 12); // Middle
- AssertEqual([new("c", 12), new("a", 4), new("d", 12), new("b", 8)], o);
- o.Insert(o.Count, "e", 16); // End
- AssertEqual([new("c", 12), new("a", 4), new("d", 12), new("b", 8), new("e", 16)], o);
- Assert.ThrowsException<ArgumentOutOfRangeException>(() => o.Insert(o.Count + 1, "f", 16));
- // Existing key
- Assert.ThrowsException<ArgumentException>(() => o.Insert(0, "a", 12));
- }
- [TestMethod]
- public void Remove_Success()
- {
- OrderedDictionary<string, float> o = new() { { "a", 4 }, { "b", 8 }, { "c", 12 } };
- Assert.IsTrue(o.Remove("b"));
- AssertEqual([new("a", 4), new("c", 12)], o);
- Assert.IsTrue(o.Remove("a", out float value));
- Assert.AreEqual(4, value);
- AssertEqual([new("c", 12)], o);
- // ICollection.Remove must match Key and Value
- Assert.IsFalse(((ICollection<KeyValuePair<string, float>>)o).Remove(new KeyValuePair<string, float>("c", -1)));
- AssertEqual([new("c", 12)], o);
- Assert.IsTrue(((ICollection<KeyValuePair<string, float>>)o).Remove(new KeyValuePair<string, float>("c", 12)));
- AssertEqual([], o);
- }
- [TestMethod]
- public void RemoveAt()
- {
- OrderedDictionary<string, float> o = new() { { "a", 4 }, { "b", 8 }, { "c", 12 }, { "d", 16 } };
- Assert.ThrowsException<ArgumentOutOfRangeException>(() => o.RemoveAt(-2));
- Assert.ThrowsException<ArgumentOutOfRangeException>(() => o.RemoveAt(-1));
- o.RemoveAt(0); // Start
- AssertEqual([new("b", 8), new("c", 12), new("d", 16)], o);
- o.RemoveAt(1); // Middle
- AssertEqual([new("b", 8), new("d", 16)], o);
- o.RemoveAt(1); // End
- AssertEqual([new("b", 8)], o);
- Assert.ThrowsException<ArgumentOutOfRangeException>(() => o.RemoveAt(1));
- }
- [TestMethod]
- public void SetPosition_ByIndex()
- {
- OrderedDictionary<string, float> o = new() { { "a", 4 }, { "b", 8 }, { "c", 12 }, { "d", 16 } };
- ArgumentOutOfRangeException ex;
- ex = Assert.ThrowsException<ArgumentOutOfRangeException>(() => o.SetPosition(-1, 0));
- Assert.AreEqual("index", ex.ParamName);
- ex = Assert.ThrowsException<ArgumentOutOfRangeException>(() => o.SetPosition(0, -1));
- Assert.AreEqual("newIndex", ex.ParamName);
- ex = Assert.ThrowsException<ArgumentOutOfRangeException>(() => o.SetPosition(0, 4));
- Assert.AreEqual("newIndex", ex.ParamName);
- ex = Assert.ThrowsException<ArgumentOutOfRangeException>(() => o.SetPosition(4, 0));
- Assert.AreEqual("index", ex.ParamName);
- o.SetPosition(1, 0);
- AssertEqual([new("b", 8), new("a", 4), new("c", 12), new("d", 16)], o);
- o.SetPosition(0, 1);
- AssertEqual([new("a", 4), new("b", 8), new("c", 12), new("d", 16)], o);
- o.SetPosition(1, 2);
- AssertEqual([new("a", 4), new("c", 12), new("b", 8), new("d", 16)], o);
- o.SetPosition(2, 1);
- AssertEqual([new("a", 4), new("b", 8), new("c", 12), new("d", 16)], o);
- o.SetPosition(0, 3);
- AssertEqual([new("b", 8), new("c", 12), new("d", 16), new("a", 4)], o);
- o.SetPosition(3, 1);
- AssertEqual([new("b", 8), new("a", 4), new("c", 12), new("d", 16)], o);
- o.SetPosition(1, 1); // No-op
- AssertEqual([new("b", 8), new("a", 4), new("c", 12), new("d", 16)], o);
- }
- [TestMethod]
- public void SetPosition_ByKey()
- {
- OrderedDictionary<string, float> o = new() { { "a", 4 }, { "b", 8 }, { "c", 12 }, { "d", 16 } };
- Assert.ThrowsException<ArgumentOutOfRangeException>(() => o.SetPosition("a", -1));
- Assert.ThrowsException<ArgumentOutOfRangeException>(() => o.SetPosition("a", 4));
- Assert.ThrowsException<KeyNotFoundException>(() => o.SetPosition("e", 0));
- o.SetPosition("b", 0);
- AssertEqual([new("b", 8), new("a", 4), new("c", 12), new("d", 16)], o);
- o.SetPosition("b", 1);
- AssertEqual([new("a", 4), new("b", 8), new("c", 12), new("d", 16)], o);
- o.SetPosition("a", 3);
- AssertEqual([new("b", 8), new("c", 12), new("d", 16), new("a", 4)], o);
- o.SetPosition("d", 2); // No-op
- AssertEqual([new("b", 8), new("c", 12), new("d", 16), new("a", 4)], o);
- }
- [TestMethod]
- public void TryAdd_Success()
- {
- OrderedDictionary<string, float> o = new() { { "a", 4 }, { "b", 8 } };
- Assert.IsTrue(o.TryAdd("c", 12));
- AssertEqual([new("a", 4), new("b", 8), new("c", 12)], o);
- Assert.IsTrue(o.TryAdd("d", 16, out int index));
- Assert.AreEqual(3, index);
- AssertEqual([new("a", 4), new("b", 8), new("c", 12), new("d", 16)], o);
- }
- [TestMethod]
- public void KeysAndValuesAreReadOnly()
- {
- OrderedDictionary<string, int> o = new() { { "a", 4 }, { "b", 8 } };
- Assert.IsTrue(o.Keys.IsReadOnly);
- Assert.ThrowsException<NotSupportedException>(() => o.Keys.Add("c"));
- Assert.ThrowsException<NotSupportedException>(o.Keys.Clear);
- Assert.ThrowsException<NotSupportedException>(() => o.Keys.Remove("a"));
- Assert.IsTrue(o.Values.IsReadOnly);
- Assert.ThrowsException<NotSupportedException>(() => o.Values.Add(12));
- Assert.ThrowsException<NotSupportedException>(o.Values.Clear);
- Assert.ThrowsException<NotSupportedException>(() => o.Values.Remove(4));
- }
- }
- }
|