Invalid call, the last call has been used or no call has been made

后端 未结 5 948
夕颜
夕颜 2021-01-07 19:12

I am getting this error when I try to set a mock to have PropertyBehavior():

System.InvalidOperationException: System.InvalidOperationEx

相关标签:
5条回答
  • 2021-01-07 19:43

    I received this error when I tried to set an expectation on a non-virtual method.

    mockedObject.Expect(a => a.NonVirtualMethod()).Returns(null);
    

    The error went away when I made NonVirtualMethod virtual.

    0 讨论(0)
  • 2021-01-07 19:46

    I ran into this issue when I was trying to call an internal property (getter only) on an object in C#. In this case, adding .PropertyBehavior() did not help.

    My solution was to extract the logic out of the property and into an internal method which I then injected dependencies into this method (as parameters).

    0 讨论(0)
  • 2021-01-07 19:47

    Never used PropertyBehavior before, but is this the syntax you're looking for?

    form.Stub(x=>x.OKButtonEnabled).PropertyBehavior()
    

    Rhino Mocks works completely through extension methods now. The only static call I every make any more is to MockRepository.GenerateStub.

    0 讨论(0)
  • 2021-01-07 19:54

    I think you have to do MockRepository.ReplyAll() after you set up all expectations and before you start using this mock. So my guess in your case is that you have to move the Expect.Call line before mediator = new AddAddressMediator(form);, and stick the reply all right after that:

    [TestInitialize()]
    public void MyTestInitialize()
    {
        form = MockRepository.GenerateMock<IAddAddressForm>();
        // Make the properties work like a normal property
        Expect.Call(form.OKButtonEnabled).PropertyBehavior();
    
        //I tried this too.  I still get the exception
        //SetupResult.For(form.OKButtonEnabled).PropertyBehavior();
    
        MockRepository.ReplyAll();
        mediator = new AddAddressMediator(form);
    
    
    
    }
    
    0 讨论(0)
  • 2021-01-07 20:06

    You mentioned using a stub instead of a mock but before you go changing it I'd note that strangely, I get the Invalid Call exception when I used GenerateStub but not when I use GenerateMock.

    View = MockRepository.GenerateStub<IAddressView>();
    View.Stub(v => v.Message).PropertyBehavior();
    

    This throws the Invalid call exception and yes, IAddressView.Message does have a getter and setter.

    0 讨论(0)
提交回复
热议问题