引数によってデリゲートを取得するクラスを取得しました。このクラスはそのデリゲートを呼び出します。Moqでユニットテストしたいと思います。このメソッドが呼び出されたことを確認するにはどうすればよいですか?
クラスの例:
public delegate void Foo(int number);
public class A
{
int a = 5;
public A(Foo myFoo)
{
myFoo(a);
}
}
fooが呼び出されたことを確認したいと思います。ありがとうございました。
匿名関数の使用はどうですか?ここではインラインモックのように機能できます。モックフレームワークは必要ありません。
bool isDelegateCalled = false;
var a = new A(a => { isDelegateCalled = true});
//do something
Assert.True(isDelegateCalled);
このコミット 現在、Moqはデリゲートのモックをサポートしています。状況に応じて、次のようにします。
var fooMock = new Mock<Foo>();
var a = new A(fooMock.Object);
次に、デリゲートが呼び出されたことを確認できます。
fooMock.Verify(f => f(5), Times.Once);
または:
fooMock.Verify(f => f(It.IsAny<int>()), Times.Once);
Moqはモックデリゲートをサポートしていません。ただし、デリゲート署名に一致するメソッドを使用して、いくつかのインターフェースを作成できます。
public interface IBar
{
void M(int number);
}
次に、このインターフェイスを実装するモックを作成し、このモックオブジェクトを使用してデリゲートを作成します。
Mock<IBar> bar = new Mock<IBar>();
Foo foo = new Foo(bar.Object.M);
A a = new A(foo);
bar.Verify(x => x.M(5));
Sutを実行した後、モックされたオブジェクトに対する期待を確認できるようになります。
更新:実際には、Foo
デリゲートインスタンスを作成せずに、bar.Object.M
をsutに渡すことができます。しかしとにかく、デリゲートをモックするにはインターフェイスを作成する必要があります。
あなたはそのようなことをすることができます:
public interface IWithFOOMethod
{
void FooAlikeMethod(int number);
}
Mock<IWithFOOMethod> myMock = new Mock<IWithFOOMethod>();
A a = new A(myMock.Object.FooAlikeMethod);
myMock.Verify(call => call.Foo(It.IsAny<int>()), Times.Once())
Moqはモックデリゲートをサポートしていないため、通常は次のように処理します。
var list = new List<int> ();
var del = i => list.Add (i);
var a = new A(del);
list.ShouldContainOnly (new[] { 5 });
提供されたデリゲートは、いくつかの単純で検証可能なアクションを実行します。