#region CPL License
/*
Nuclex Framework
Copyright (C) 2002-2014 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