3

Sim オブジェクトの状態に応じてイベントを発生させるアプリケーションがあります。特に、Sim の状態が変化した場合 (つまり、PinRequired から Accessible に変化した場合)、OnStatus イベントが発生します。イベントは、新しいスレッドでリスナーに通知します。

私は単体テストで Moq を使用しており、OnStatus が次のように発生していると主張できます。

        [Test]
    public void TestOnStatusIsRaised()
    {
        Sim sim = new Sim();

        sim.OnStatus += OnStatus;

        lock (this)
        {
            sim.UpdateSimInfo(new Info("a new status"));
            Monitor.Wait(this);
        }

        Assert.IsTrue(_onStatusCalled);
    }

    private void OnStatus(SimStatus obj)
    {
        lock (this)
        {
            _onStatusCalled = true;
            Monitor.Pulse(this);
        }
    }

ご覧のとおり、Monitor クラスを使用すると、イベントが発生するまで待ってから、処理を進めて _onStatusCalled フラグが true に設定されていることをアサートできます。

イベントが発生していないことを主張したいときに問題が発生します。テストが永遠に待機するため、モニターを使用してイベントが発生しないのを待つことはできません! 待機にタイムアウトを追加することもできましたが、それは汚いハックのようです。

私は次のことを試しました:

        [Test]
    public void TestOnStatusIsNotFired()
    {
        Sim sim = new Sim();
        sim.OnStatus += onStatus => Assert.Fail("OnStatus Was called");

        sim.UpdateSimInfo(new Info("the same status"));
    }

しかし、それは機能しません。イベントが発生しないようにコードを修正する前に、テストは常にパスします。コードをステップ実行して、 によってスローされる例外を確認しましたAssert.Fail()が、イベントが try/catch ブロックで発生し、NUnit 例外がキャッチされるため、テストが失敗することはありません。

何か案は?

4

3 に答える 3

5

つまり、マルチスレッド コードの単体テストは行いません。これをシングル スレッドのパーツに分割し、それぞれを個別にテストします。

于 2012-09-15T15:40:35.460 に答える
0

NoStatus のイベントもあるとしたらどうでしょう。

[Test]
public void TestOnStatusIsNotFired()
{
    Sim sim = new Sim();
    var mre = new ManualResetEvent(false);
    sim.OnStatus += onStatus => { mre.Set(); Assert.Fail("OnStatus Was called");}
    sim.NoStatus += () => { mre.Set();}

    sim.UpdateSimInfo(new Info("the same status"));
    mre.WaitOne()
}
于 2012-09-15T15:05:58.347 に答える
0

次のようなものを使用するのはどうですか:

mock.Verify(foo => foo.Execute("ping"), Times.Never());

OnStatus が呼び出されたことを確認することもできます。

mock.Verify(foo => foo.Execute("ping"), Times.AtLeastOnce());

多くの優れた短いサンプルについては、このリンクを試してください: http://code.google.com/p/moq/wiki/QuickStart

于 2012-09-15T15:40:07.413 に答える