// **************************************************************** // Copyright 2007, Charlie Poole // This is free software licensed under the NUnit license. You may // obtain a copy of the license at http://nunit.org/?p=license&r=2.4 // **************************************************************** using System; using System.Collections; using NUnit.Framework; namespace NUnit.Mocks { /// /// The MockMethod object represents one named method on a mock object. /// All overloads are represented by one MockMethod. A method may return /// a fixed value, throw a fixed exception or have an expected sequence /// of calls. If it has a call sequence, then the signature must match and /// each call provides it's own return value or exception. /// public class MockMethod : IMethod { #region Private Fields /// /// Name of this method /// private string methodName; /// /// Fixed return value /// private object returnVal; /// /// Exception to be thrown /// private Exception exception; /// /// Expected call sequence. If null, this method has no expectations /// and simply provides a fixed return value or exception. /// private ArrayList expectedCalls = null; /// /// Actual sequence of calls... currently not used /// //private ArrayList actualCalls = null; #endregion #region Constructors public MockMethod( string methodName ) : this( methodName, null, null ) { } public MockMethod( string methodName, object returnVal ) : this( methodName, returnVal, null ) { } public MockMethod( string methodName, object returnVal, Exception exception ) { this.methodName = methodName; this.returnVal = returnVal; this.exception = exception; } #endregion #region IMethod Members public string Name { get { return methodName; } } public void Expect( ICall call ) { if ( expectedCalls == null ) expectedCalls = new ArrayList(); expectedCalls.Add( call ); } #endregion #region ICall Members public object Call( object[] args ) { if ( expectedCalls == null ) { if ( exception != null ) throw exception; return returnVal; } else { //actualCalls.Add( new MethodCall( methodName, null, null, args ) ); Assert.IsTrue( expectedCalls.Count > 0, "Too many calls to " + Name ); MockCall mockCall = (MockCall)expectedCalls[0]; expectedCalls.RemoveAt( 0 ); return mockCall.Call( args ); } } #endregion #region IVerify Members public void Verify() { if ( expectedCalls != null ) Assert.IsTrue( expectedCalls.Count == 0, "Not all methods were called" ); } #endregion } }