0

enter code here我有一个方法可以在该方法中引发异常时记录错误。该方法在单例中是非静态的。

    public object MethodA()
    {
        try
        {
            //code
                             SomeObj.Print(); //updated
        }
        catch (Exception ex)
        {
            log.Error(ex);
        }
    }

下面的单元测试代码抛出 NullreferenceException:

                    var fakeLogger = A.Fake<ILog>();

        MySingleton.Instance.Initialize(fakeLogger);

        A.CallTo(() => MySingleton.Instance.MethodA()
            .Invokes((x) => { throw new Exception(); });
               //.Throws(new Exception()); --even this doesnt work
        A.CallTo(() => fakeLogger.Error(A<object>.Ignored)).MustHaveHappened();


Stack trace:
at FakeItEasy.Creation.CastleDynamicProxy.CastleDynamicProxyInterceptionValidator.GetReasonForWhyMethodCanNotBeIntercepted(MethodInfo method)
at FakeItEasy.Creation.CastleDynamicProxy.CastleDynamicProxyInterceptionValidator.MethodCanBeInterceptedOnInstance(MethodInfo method, Object callTarget, String& failReason)
at FakeItEasy.Creation.CastleDynamicProxy.CastleDynamicProxyGenerator.MethodCanBeInterceptedOnInstance(MethodInfo method, Object callTarget, String& failReason)
at FakeItEasy.Creation.ProxyGeneratorSelector.MethodCanBeInterceptedOnInstance(MethodInfo method, Object callTarget, String& failReason)
at FakeItEasy.Configuration.DefaultInterceptionAsserter.AssertThatMethodCanBeInterceptedOnInstance(MethodInfo method, Object callTarget)
at FakeItEasy.Configuration.FakeConfigurationManager.AssertThatMemberCanBeIntercepted(LambdaExpression callSpecification)
at FakeItEasy.Configuration.FakeConfigurationManager.CallTo(Expression`1 callSpecification)
at FakeItEasy.A.CallTo(Expression`1 callSpecification)

解决方案:我必须让我的非伪造方法抛出异常,这就是我所做的。

var fakeLogger = A.Fake<ILog>();
var someObject = A.Fake<SomeObject>();
MySingleton.Instance.Initialize(fakeLogger);
A.CallTo(() => someObject.Print()).Throws(new Exception()); //key
MySingleton.Instance.MethodA();
A.CallTo(() => fakeLogger.Error(A<object>.Ignored)).MustHaveHappened();
4

2 回答 2

3

MySingleton.Instance不指向你的 fake ,你伪造了 an ILog,而不是 a MySingleton,你只能在你的 fake 上配置方法。

例如:

A.CallTo(() => fakeLogger.MethodA()).Throws(new Exception());

您必须想办法在 try catch 块中引发异常。

于 2012-03-05T12:14:29.363 回答
2

试试这个:

A.CallTo(() => MySingleton.Instance.MethodA()).Throws(new Exception());
MySingleton.Instance.MethodA();
A.CallTo(() => fakeLogger.Error(A<object>.Ignored)).MustHaveHappened();
于 2012-03-03T06:41:19.437 回答