#region CPL License /* Nuclex Framework Copyright (C) 2002-2013 Nuclex Development Labs This library is free software; you can redistribute it and/or modify it under the terms of the IBM Common Public License as published by the IBM Corporation; either version 1.0 of the License, or (at your option) any later version. This library is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the IBM Common Public License for more details. You should have received a copy of the IBM Common Public License along with this library */ #endregion using System; using System.Collections.Generic; #if UNITTEST using NUnit.Framework; using NMock; namespace Nuclex.Support.Collections { /// Unit Test for the observable collection class [TestFixture] internal class ObservableCollectionTest { #region interface IObservableCollectionSubscriber /// Interface used to test the observable collection public interface IObservableCollectionSubscriber { /// Called when the collection is about to clear its contents /// Collection that is clearing its contents /// Not used void Clearing(object sender, EventArgs arguments); /// Called when the collection has been cleared of its contents /// Collection that was cleared of its contents /// Not used void Cleared(object sender, EventArgs arguments); /// Called when an item is added to the collection /// Collection to which an item is being added /// Contains the item that is being added void ItemAdded(object sender, ItemEventArgs arguments); /// Called when an item is removed from the collection /// Collection from which an item is being removed /// Contains the item that is being removed void ItemRemoved(object sender, ItemEventArgs arguments); } #endregion // interface IObservableCollectionSubscriber /// Initialization routine executed before each test is run [SetUp] public void Setup() { this.mockery = new MockFactory(); this.mockedSubscriber = this.mockery.CreateMock(); this.observedCollection = new ObservableCollection(); this.observedCollection.Clearing += new EventHandler( this.mockedSubscriber.MockObject.Clearing ); this.observedCollection.Cleared += new EventHandler( this.mockedSubscriber.MockObject.Cleared ); this.observedCollection.ItemAdded += new EventHandler>( this.mockedSubscriber.MockObject.ItemAdded ); this.observedCollection.ItemRemoved += new EventHandler>( this.mockedSubscriber.MockObject.ItemRemoved ); } /// Tests whether the Clearing event is fired [Test] public void TestClearingEvent() { this.mockedSubscriber.Expects.One.Method(m => m.Clearing(null, null)).WithAnyArguments(); this.mockedSubscriber.Expects.One.Method(m => m.Cleared(null, null)).WithAnyArguments(); this.observedCollection.Clear(); this.mockery.VerifyAllExpectationsHaveBeenMet(); } /// Tests whether the ItemAdded event is fired [Test] public void TestItemAddedEvent() { this.mockedSubscriber.Expects.One.Method(m => m.ItemAdded(null, null)).WithAnyArguments(); this.observedCollection.Add(123); this.mockery.VerifyAllExpectationsHaveBeenMet(); } /// Tests whether the ItemRemoved event is fired [Test] public void TestItemRemovedEvent() { this.mockedSubscriber.Expects.One.Method(m => m.ItemAdded(null, null)).WithAnyArguments(); this.observedCollection.Add(123); this.mockedSubscriber.Expects.One.Method(m => m.ItemRemoved(null, null)).WithAnyArguments(); this.observedCollection.Remove(123); this.mockery.VerifyAllExpectationsHaveBeenMet(); } /// Tests whether a the list constructor is working [Test] public void TestListConstructor() { int[] integers = new int[] { 12, 34, 56, 78 }; var testCollection = new ObservableCollection(integers); CollectionAssert.AreEqual(integers, testCollection); } /// Mock object factory private MockFactory mockery; /// The mocked observable collection subscriber private Mock mockedSubscriber; /// An observable collection to which a mock will be subscribed private ObservableCollection observedCollection; } } // namespace Nuclex.Support.Collections #endif // UNITTEST