4

我有一个正在测试的对象,它引发了一个事件。使用 Rhino Mocks 检查它是否被饲养的最佳方法是什么?

我能想到的最好的(我确信它会比这更好):

public void MyCallback(object sender, EventArgs e) { _flag = true;}

[Test]
public void DoSomethingRaisesEvent() {
  _flag = false;
  using(_mocks.Record()) {
    Expect.Call(delegeate { _obj.DoSomething();});
  }
  using(_mocks.Playback()) {
    _obj = new SomethingDoer();
    _obj.SomethingWasDoneEvent += new EventHandler(MyHandler);
    Assert.IsTrue(_flag);
  }
}
4

2 回答 2

5

我发现了 Phil Haack 的这篇关于如何使用匿名委托测试事件的文章

这是代码,直接从他的博客中翻录给那些懒得点击的人:

[Test]
public void SettingValueRaisesEvent()
{
    bool eventRaised = false;
    Parameter param = new Parameter("num", "int", "1");
    param.ValueChanged += 
        delegate(object sender, ValueChangedEventArgs e)
        {
            Assert.AreEqual("42", e.NewValue);
            Assert.AreEqual("1", e.OldValue);
            Assert.AreEqual("num", e.ParameterName);
            eventRaised = true;
        };
    param.Value = "42"; //should fire event.

    Assert.IsTrue(eventRaised, "Event was not raised");
}
于 2008-09-29T18:03:03.347 回答
0

我不确定您的测试实际上是如何调用 DoSomething() 方法的。也许你错过了一些触发事件的东西。除此之外,我认为您在使用 Rhino Mocks 测试事件方面走在了正确的轨道上

无论如何,这是我喜欢处理事件的另一种方式:

[Test]
public void MyEventTest()
{

    IEventRaiser eventRaiser;

    mockView = _mocks.CreateMock<IView>();
    using (_mocks.Record())
    {
      mockView.DoSomethingEvent += null;
      eventRaiser = LastCall.IgnoreArguments();
    }
    using (_mocks.Playback())
    {
       new Controller(mockView, mockModel);
       eventRaiser.Raise(mockView, EventArgs.Empty);
    }
}
于 2008-09-29T15:05:42.383 回答